binxie
2023-06-20 39644c307e98c90e45aea98292c86d70740989e3
backup
4个文件已修改
4747 ■■■■■ 已修改文件
force-app/main/default/aura/WeeklyReport/WeeklyReport.cmp 717 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
force-app/main/default/aura/WeeklyReport/WeeklyReportController.js 137 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
force-app/main/default/aura/WeeklyReport/WeeklyReportHelper.js 2664 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
force-app/main/default/classes/WeeklyReportCmp.cls 1229 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
force-app/main/default/aura/WeeklyReport/WeeklyReport.cmp
@@ -1,10 +1,30 @@
<aura:component controller="WeeklyReportCmp" implements="force:appHostable,flexipage:availableForAllPageTypes,flexipage:availableForRecordHome,force:hasRecordId,force:lightningQuickAction,forceCommunity:availableForAllPageTypes" access="global" >
<aura:component
  controller="WeeklyReportCmp"
  implements="force:appHostable,flexipage:availableForAllPageTypes,flexipage:availableForRecordHome,force:hasRecordId,force:lightningQuickAction,forceCommunity:availableForAllPageTypes"
  access="global"
>
    <ltng:require styles="{!$Resource.multilineToastCSS}" /> 
    <aura:handler name="init" value="{!this}" action="{!c.doInit}"/>
    <aura:handler event="c:strike_evt" action="{!c.createAopp}" name="strike_evt_addNewRecord"/>
    <aura:attribute name="data" type="Agency_Report__c" default="{sobjectType:'Agency_Report__c'}"/>
    <aura:attribute name="oppdata" type="Agency_Opportunity__c" default="{sobjectType:'Agency_Opportunity__c'}"/>
    <aura:attribute name="acondata" type="Agency_Contact__c" default="{sobjectType:'Agency_Contact__c'}"/>
  <aura:handler
    event="c:strike_evt"
    action="{!c.createAopp}"
    name="strike_evt_addNewRecord"
  />
  <aura:attribute
    name="data"
    type="Agency_Report__c"
    default="{sobjectType:'Agency_Report__c'}"
  />
  <aura:attribute
    name="oppdata"
    type="Agency_Opportunity__c"
    default="{sobjectType:'Agency_Opportunity__c'}"
  />
  <aura:attribute
    name="acondata"
    type="Agency_Contact__c"
    default="{sobjectType:'Agency_Contact__c'}"
  />
    <!-- <aura:attribute name="oppdata_old" type="Agency_Opportunity__c" default="{sobjectType:'Agency_Opportunity__c'}"/> -->
    <aura:attribute name="Close_Forecasted_Date__c_o" type="Date"/>
    <aura:attribute name="Amount__c_o" type="String"/>
@@ -33,7 +53,11 @@
    <aura:attribute name="doctor_list" type="Map"/>
    <aura:attribute name="doctor_title" type="String"/>
    <aura:attribute name="opportunity_list" type="Map"/>
    <aura:handler name="change" value="{!v.data.Opportunity__c}" action="{!c.opportunityChange}"/>
  <aura:handler
    name="change"
    value="{!v.data.Opportunity__c}"
    action="{!c.opportunityChange}"
  />
    <aura:attribute name="edit_copy_select_report_id" type="String"/>
    <aura:attribute name="create_agency_report_id" type="String"/>
    <aura:attribute name="reports" type="List"/>
@@ -56,15 +80,31 @@
    <aura:handler name="change" value="{!v.data.Product_Category2__c}" action="{!c.productcategoryChange2}"/>
    <aura:handler name="change" value="{!v.data.Product_Category3__c}" action="{!c.productcategoryChange3}"/> -->
    <!-- <aura:handler name="change" value="{!v.oppdata.StageName__c}" action="{!c.stageNameChange}"/> -->
    <aura:attribute name="update_select_report_data_id" type="String" default=""/>
  <aura:attribute
    name="update_select_report_data_id"
    type="String"
    default=""
  />
    <!-- 批量添加周报 start-->
    <aura:attribute name="reports_date" type="List" />
    <!-- <aura:attribute name="reports_date1" type="Date" />
    <aura:attribute name="reports_date2" type="Date" /> -->
    <aura:attribute name="TableContent" type="String"  description=" Show the Result class"/>
    <aura:attribute name="TableContent2" type="String"  description=" Show the Result class"/>
    <aura:attribute name="TargetFileName" type="String"  description="Name of the file"/>
  <aura:attribute
    name="TableContent"
    type="String"
    description=" Show the Result class"
  />
  <aura:attribute
    name="TableContent2"
    type="String"
    description=" Show the Result class"
  />
  <aura:attribute
    name="TargetFileName"
    type="String"
    description="Name of the file"
  />
    <aura:attribute name="tableheaders" type="Object[]" />
    <aura:attribute name="fileContentData" type="String"/>
    <aura:attribute name="filename" type="String"/>
@@ -98,7 +138,10 @@
        <!-- add by Deloitte-Link 2023-6-19 -->
       <div class="weeklyReportSpinner">
          <div class="slds-spinner_container">
              <div class="slds-spinner--brand slds-spinner slds-spinner--medium" role="alert">
        <div
          class="slds-spinner--brand slds-spinner slds-spinner--medium"
          role="alert"
        >
                  <span id="aa" class="slds-assistive-text">Loading</span>
                  <div class="slds-spinner__dot-a"></div>
                  <div class="slds-spinner__dot-b"></div>
@@ -109,65 +152,111 @@
    
    <div aura:id="report" id="report">
        <div class="slds-grid slds-wrap slds-grid--pull-padded">
            <div class="tr mt5 slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-12 slds-large-size--1-of-12">
      <div
        class="tr mt5 slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-12 slds-large-size--1-of-12"
      >
                周
            </div>
            <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12">
                <ui:inputSelect aura:id="select_date" class="slds-select" change="{!c.select_date_change}"/>
      <div
        class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12"
      >
        <ui:inputSelect
          aura:id="select_date"
          class="slds-select"
          change="{!c.select_date_change}"
        />
            </div>
            
            <!-- 代理店担当者 -->
            <div class="tr mt5 slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-12 slds-large-size--1-of-12">
      <div
        class="tr mt5 slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-12 slds-large-size--1-of-12"
      >
                {!v.fieldsmap.Person_In_Charge2__c}
            </div>
            <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12">
                <ui:inputSelect aura:id="select_agency_person" class="slds-select agency_person_select" change="{!c.select_agency_change}"/>
      <div
        class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12"
      >
        <ui:inputSelect
          aura:id="select_agency_person"
          class="slds-select agency_person_select"
          change="{!c.select_agency_change}"
        />
            </div>
            <div class="tr slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-12 slds-large-size--1-of-12">
                <ui:button aura:id="new_button" label="新建" press="{!c.new_report}" disabled="true"/>
      <div
        class="tr slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-12 slds-large-size--1-of-12"
      >
        <ui:button
          aura:id="new_button"
          label="新建"
          press="{!c.new_report}"
          disabled="true"
        />
            </div>
            <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12">
                <ui:button aura:id="copy_button" label="复制" press="{!c.copy_button}" disabled="true"/>
      <div
        class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12"
      >
        <ui:button
          aura:id="copy_button"
          label="复制"
          press="{!c.copy_button}"
          disabled="true"
        />
                <!-- <ui:button aura:id="import" label="导入" press="{!c.import}" /> -->
                <ui:button aura:id="import" label="导入" press="{!c.import}" />
                
                <!-- <input type="file" class="file" aura:id="file" onchange="{!c.CreateRecord}"  style="position:absolute;filter:alpha(opacity=0);" size="1" hidden="true" />  -->
                <!-- <ui:button aura:id="import" label="导出" press="{!c.export}"/> -->
                <ui:button aura:id="export" label="导出" press="{!c.export_condition}"/>
        <ui:button
          aura:id="export"
          label="导出"
          press="{!c.export_condition}"
        />
            </div>
        </div>
    </div>
    
    <div aura:id="report_list" class="report_list_area">
        <div class="slds-table--edit_container slds-is-relative">
            <table class="slds-table slds-table--edit slds-table--bordered slds-table--fixed-layout slds-no-cell-focus" role="grid" style="width:66.75rem;">
      <table
        class="slds-table slds-table--edit slds-table--bordered slds-table--fixed-layout slds-no-cell-focus"
        role="grid"
        style="width: 66.75rem"
      >
                <thead>
                    <tr class="slds-line-height--reset">
                        <th class="table_header slds-text-title--caps" style="width: 250px;">
            <th class="table_header slds-text-title--caps" style="width: 250px">
              <span class="slds-truncate" title="Name">周报编号</span>
                        </th>
                        <th class="table_header slds-text-title--caps" style="width: 100px;">
                            <span class="slds-truncate" title="Name">{!v.fieldsmap.Person_In_Charge2__c}</span>
            <th class="table_header slds-text-title--caps" style="width: 100px">
              <span class="slds-truncate" title="Name"
                >{!v.fieldsmap.Person_In_Charge2__c}</span
              >
                        </th>
                        <th class="table_header slds-text-title--caps" style="width: 250px;">
            <th class="table_header slds-text-title--caps" style="width: 250px">
                            <span class="slds-truncate" title="Name">医院</span>
                        </th>
                        <th class="table_header slds-text-title--caps" style="width: 100px;">
                            <span class="slds-truncate" title="Name">{!v.fieldsmap.Department_Cateogy__c}</span>
            <th class="table_header slds-text-title--caps" style="width: 100px">
              <span class="slds-truncate" title="Name"
                >{!v.fieldsmap.Department_Cateogy__c}</span
              >
                        </th>
                        <th class="table_header slds-text-title--caps" style="width: 100px;">
            <th class="table_header slds-text-title--caps" style="width: 100px">
                            <!-- PIPL update Yin Mingjie 21/02/2022 start
                            <span class="slds-truncate" title="Name">{!v.fieldsmap.doctor2__r}</span>
                            PIPL update Yin Mingjie 21/02/2022 end-->
                            <span class="slds-truncate" title="Name" style="width: 100px;">{!v.fieldsmap.Agency_Contact__c}</span>
              <span class="slds-truncate" title="Name" style="width: 100px"
                >{!v.fieldsmap.Agency_Contact__c}</span
              >
                        </th>
                        <th class="table_header slds-text-title--caps" style="width: 100px;">
                            <span class="slds-truncate" title="Name">{!v.fieldsmap.visitor_title__c}</span>
            <th class="table_header slds-text-title--caps" style="width: 100px">
              <span class="slds-truncate" title="Name"
                >{!v.fieldsmap.visitor_title__c}</span
              >
                        </th>
                        <th class="table_header slds-text-title--caps">
                            <span class="slds-truncate" title="Name">{!v.fieldsmap.Purpose_Type__c}</span>
              <span class="slds-truncate" title="Name"
                >{!v.fieldsmap.Purpose_Type__c}</span
              >
                        </th>
                    </tr>
                </thead>
@@ -175,12 +264,27 @@
                    <aura:iteration items="{!v.reports}" var="item" indexVar="index">
                        <tr class="slds-hint-parent">
                            <td role="gridcell" class="slds-cell-edit">
                                <ui:inputRadio class="report_radio" name="report_radio" label="{!item.Name}" change="{!c.change_report_radio}"/>
                                <lightning:buttonIcon class="edit_button" iconName="utility:edit" size="small" alternativeText="edit" value="{!index}" onclick="{!c.edit_button}"/>
                <ui:inputRadio
                  class="report_radio"
                  name="report_radio"
                  label="{!item.Name}"
                  change="{!c.change_report_radio}"
                />
                <lightning:buttonIcon
                  class="edit_button"
                  iconName="utility:edit"
                  size="small"
                  alternativeText="edit"
                  value="{!index}"
                  onclick="{!c.edit_button}"
                />
                            </td>
                            <td role="gridcell" class="slds-cell-edit">
                                <span class="slds-grid slds-grid--align-spread">
                                    <span class="slds-truncate" title="{!item.Person_In_Charge2__r.Name}">
                  <span
                    class="slds-truncate"
                    title="{!item.Person_In_Charge2__r.Name}"
                  >
                                        {!item.Person_In_Charge2__r.Name}
                                        <!-- <span class="decrypt">{!item.Person_In_Charge2__r.awsdata.lastName}</span> -->
                                    </span>
@@ -193,7 +297,11 @@
                            </th>
                            <td role="gridcell" class="slds-cell-edit">
                                <span class="slds-grid slds-grid--align-spread">
                                    <span class="slds-truncate" title="{!item.Department_Cateogy__c}">{!item.Department_Cateogy__c}</span>
                  <span
                    class="slds-truncate"
                    title="{!item.Department_Cateogy__c}"
                    >{!item.Department_Cateogy__c}</span
                  >
                                </span>
                            </td>
                            <td role="gridcell" class="slds-cell-edit">
@@ -208,13 +316,17 @@
                                <span class="slds-grid slds-grid--align-spread">
                                    <span class="slds-truncate" title="{!item.visitor_title__c}">
                                        <span class="encrypt">{!item.visitor_title__c}</span>
                                        <span class="decrypt">{!item.doctor2__r.awsdata.doctorDivision1}</span>
                    <span class="decrypt"
                      >{!item.doctor2__r.awsdata.doctorDivision1}</span
                    >
                                    </span>
                                </span>
                            </td>
                            <td role="gridcell" class="slds-cell-edit">
                                <span class="slds-grid slds-grid--align-spread">
                                    <span class="slds-truncate" title="{!item.Purpose_Type__c}">{!item.Purpose_Type__c}</span>
                  <span class="slds-truncate" title="{!item.Purpose_Type__c}"
                    >{!item.Purpose_Type__c}</span
                  >
                                </span>
                            </td>
                        </tr>
@@ -224,47 +336,82 @@
        </div>
        <aura:renderIf isTrue="{!v.report_count > 0}">
            <aura:set attribute="else">
                <div class="no_data_area">
                    {!v.list_message}
                </div>
        <div class="no_data_area">{!v.list_message}</div>
            </aura:set>
        </aura:renderIf>
    </div>
<!--    <ui:button aura:id="test_button" label="test" class="fade animation_on" press="{!c.test}"/>-->
    <!-- 批量添加周报 start-->
    <div aura:id="modal_import" role="dialog" tabindex="-1" class="disp_none slds-modal slds-fade-in-open slds-modal--large" aria-labelledby="headerTarget">
  <div
    aura:id="modal_import"
    role="dialog"
    tabindex="-1"
    class="disp_none slds-modal slds-fade-in-open slds-modal--large"
    aria-labelledby="headerTarget"
  >
        <div class="slds-modal__container ">
            <div class="slds-modal__header ">
                <h4 id="headerTarget" class="slds-float--left"></h4>
                <h2 id="headerTarget" class="slds-text-heading--medium">周报批量导入</h2>
                <ui:button aura:id="close_button" label="关闭" class="close_button slds-button slds-button--neutral slds-order--1" press="{!c.close_import}"/>
        <h2 id="headerTarget" class="slds-text-heading--medium">
          周报批量导入
        </h2>
        <ui:button
          aura:id="close_button"
          label="关闭"
          class="close_button slds-button slds-button--neutral slds-order--1"
          press="{!c.close_import}"
        />
            </div>
            <div class="slds-modal__content slds-scrollable slds-grow slds-p-around--medium " >
      <div
        class="slds-modal__content slds-scrollable slds-grow slds-p-around--medium"
      >
                <aura:if isTrue="{!v.showMain}">
                    <div>
                        <!-- <input type="file" class="file" aura:id="file" onchange="{!c.CreateRecord}" value="导入" /> -->
                        <lightning:input type="file" class="file" uara:id="file" onchange="{!c.CreateRecord}" />
            <lightning:input
              type="file"
              class="file"
              uara:id="file"
              onchange="{!c.CreateRecord}"
            />
                        <!-- <ui:button label="Create Accounts" press="{!c.CreateRecord}"/> -->
                    </div>
                    <aura:set attribute="else">
                        <!-- <ui:outputRichText class="uiOutputRichText slds-m-around-large" value="{!v.TargetFileName}"/>  -->
                        <ui:outputRichText class="uiOutputRichText slds-m--around-large" value="{!v.TableContent}"/>
                        <div class="slds-p-around--large slds-align--absolute-center">
                            <lightning:button label="保存" variant="brand" onclick="{!c.processFileContent}"
            <ui:outputRichText
              class="uiOutputRichText slds-m--around-large"
              value="{!v.TableContent}"
                                              />
                            <lightning:button label="取消" variant="brand"
                                              onclick="{!c.cancel}" />
            <div class="slds-p-around--large slds-align--absolute-center">
              <lightning:button
                label="保存"
                variant="brand"
                onclick="{!c.processFileContent}"
              />
              <lightning:button
                label="取消"
                variant="brand"
                onclick="{!c.cancel}"
              />
                        </div>
                        <!-- start DTT-zhj 增加错误信息table 2023-05-16-->
                        <aura:if isTrue="{!v.showErrorInfo}">
                            <div class="slds-p-around--large slds-align--absolute-center">
                                <lightning:button label="导出错误信息" variant="brand" onclick="{!c.exportErrorInfo}" />
                <lightning:button
                  label="导出错误信息"
                  variant="brand"
                  onclick="{!c.exportErrorInfo}"
                />
                            </div>
                            <div class="slds-p-around--large slds-align--absolute-center">
                                <div style="height: 300px;overflow-x:scroll">
                                    <lightning:datatable keyField="id" data="{! v.errorData }"
                                        columns="{! v.errorColumns }" hideCheckboxColumn="true" />
                  <lightning:datatable
                    keyField="id"
                    data="{! v.errorData }"
                    columns="{! v.errorColumns }"
                    hideCheckboxColumn="true"
                  />
                                </div>
                            </div>
                        </aura:if>
@@ -274,39 +421,76 @@
            </div>
        </div>
    </div>
    <div aura:id="modal_importbg" class="disp_none slds-backdrop slds-backdrop--open"></div>
  <div
    aura:id="modal_importbg"
    class="disp_none slds-backdrop slds-backdrop--open"
  ></div>
    <!-- 批量添加周报 end-->
    <!-- 批量导出周报 start-->
    <div aura:id="modal_export" role="dialog" tabindex="-1" class="disp_none slds-modal slds-fade-in-open slds-modal--large" >
  <div
    aura:id="modal_export"
    role="dialog"
    tabindex="-1"
    class="disp_none slds-modal slds-fade-in-open slds-modal--large"
  >
        <div class="slds-modal__container">
            <div class="slds-modal__header">
                <h4 id="headerTarget" class="slds-float--left"></h4>
                <h2 id="headerTarget" class="slds-text-heading--medium">周报批量导出</h2>
                <ui:button aura:id="close_button" label="关闭" class="close_button slds-button slds-button--neutral slds-order--1" press="{!c.close_export}"/>
        <h2 id="headerTarget" class="slds-text-heading--medium">
          周报批量导出
        </h2>
        <ui:button
          aura:id="close_button"
          label="关闭"
          class="close_button slds-button slds-button--neutral slds-order--1"
          press="{!c.close_export}"
        />
            </div>
            <div class="slds-modal__content slds-scrollable slds-grow slds-p-around--medium">
      <div
        class="slds-modal__content slds-scrollable slds-grow slds-p-around--medium"
      >
                <aura:if isTrue="{!v.showMain}">
                    <div class="slds-grid slds-wrap slds-grid--pull-padded" >
                        <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-4">
                        </div>
                        <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-4">
            <div
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-4"
            ></div>
            <div
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-4"
            >
                            活动日开始日期
                            
                            <lightning:input type="Date" class="slds-input slds-input_bare " aura:id="input-report-date1" />
              <lightning:input
                type="Date"
                class="slds-input slds-input_bare"
                aura:id="input-report-date1"
              />
                        </div>
                        <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-4">
            <div
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-4"
            >
                            活动日结束日期
                            <lightning:input type="Date" class="slds-input slds-input_bare " aura:id="input-report-date2" />
              <lightning:input
                type="Date"
                class="slds-input slds-input_bare"
                aura:id="input-report-date2"
              />
                        </div>
                        <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-4">
                        </div>
            <div
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-4"
            ></div>
                        <div class="slds-p-around--large slds-align--absolute-center">
                            <lightning:button label="确认" variant="brand" onclick="{!c.select_repores_date}"
              <lightning:button
                label="确认"
                variant="brand"
                onclick="{!c.select_repores_date}"
                                                  />
                            <lightning:button label="取消" variant="brand"
                                                  onclick="{!c.close_export}" />
              <lightning:button
                label="取消"
                variant="brand"
                onclick="{!c.close_export}"
              />
                        </div>
                    </div>
                    <!-- <div>
@@ -319,47 +503,97 @@
                                              onclick="{!c.close_export}" /> 
                    </div> -->
                    <aura:set attribute="else">
                        <ui:outputRichText class="uiOutputRichText slds-m--around-large" value="{!v.TableContent2}"/>
                        <div class="slds-p-around--large slds-align--absolute-center">
                            <lightning:button label="确认" variant="brand" onclick="{!c.exportDate}"
            <ui:outputRichText
              class="uiOutputRichText slds-m--around-large"
              value="{!v.TableContent2}"
                                              />
                            <lightning:button label="取消" variant="brand"
                                              onclick="{!c.close_export}" />
            <div class="slds-p-around--large slds-align--absolute-center">
              <lightning:button
                label="确认"
                variant="brand"
                onclick="{!c.exportDate}"
              />
              <lightning:button
                label="取消"
                variant="brand"
                onclick="{!c.close_export}"
              />
                        </div>
                    </aura:set>
                </aura:if>
            </div>
        </div>
    </div>
    <div aura:id="modal_exportbg" class="disp_none slds-backdrop slds-backdrop--open"></div>
  <div
    aura:id="modal_exportbg"
    class="disp_none slds-backdrop slds-backdrop--open"
  ></div>
    <!-- 批量导出周报 end-->
    <div aura:id="modal_window" role="dialog" tabindex="-1" class="disp_none slds-modal slds-fade-in-open slds-modal--large" aria-labelledby="headerTarget">
  <div
    aura:id="modal_window"
    role="dialog"
    tabindex="-1"
    class="disp_none slds-modal slds-fade-in-open slds-modal--large"
    aria-labelledby="headerTarget"
  >
        <div class="slds-modal__container">
            <div class="slds-modal__header">
                <h4 id="headerTarget" class="slds-float--left">{!v.dialog_type}</h4>
                <h2 id="headerTarget" class="slds-text-heading--medium">周报({!v.selected_date}&nbsp;{!v.selected_agency_person})</h2>
                <ui:button aura:id="close_button" label="关闭" class="close_button slds-button slds-button--neutral slds-order--1" press="{!c.toggle_report}"/>
        <h4 id="headerTarget" class="slds-float--left"></h4>
        <h2 id="headerTarget" class="slds-text-heading--medium">
          周报({!v.selected_date}&nbsp;{!v.selected_agency_person})
        </h2>
        <ui:button
          aura:id="close_button"
          label="关闭"
          class="close_button slds-button slds-button--neutral slds-order--1"
          press="{!c.toggle_report}"
        />
            </div>
            <div class="slds-modal__content slds-grow slds-p-around--medium">
                <div class="slds-box slds-theme--shade">
                    <div class="slds-grid slds-wrap slds-grid--pull-padded" >
                        <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-6">
            <div
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-6"
            >
                            活动日
                            <!-- <ui:inputSelect aura:id="select_opportunity" class="slds-select"/> -->
                            <force:inputField value="{!v.data.Report_Date__c}" aura:id="input-report-date"/>
              <force:inputField
                value="{!v.data.Report_Date__c}"
                aura:id="input-report-date"
              />
                        </div>
                        <!-- 医院 -->
                        <div aura:id="hospital_list" class="slds-form-element slds-lookup slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-5" data-select="single">
                            <ui:inputText aura:id="hospital_input_text" label="医院" class="field" value="{!v.hospital}" updateOn="keyup"/>
            <div
              aura:id="hospital_list"
              class="slds-form-element slds-lookup slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-5"
              data-select="single"
            >
              <ui:inputText
                aura:id="hospital_input_text"
                label="医院"
                class="field"
                value="{!v.hospital}"
                updateOn="keyup"
              />
                            <div class="slds-lookup__menu" id="lookup-66">
                                <ul class="slds-lookup__list" role="listbox">
                                    <aura:iteration var="hospital" items="{!v.hospitalList}">
                                        <li role="presentation" onclick="{!c.selectHos}" data-accName="{!hospital.Hospital_Name_readonly__c}" data-accId="{!hospital.Hospital__c}">
                                            <span class="slds-lookup__item-action slds-media" id="lookup-option-498" role="option">
                    <li
                      role="presentation"
                      onclick="{!c.selectHos}"
                      data-accName="{!hospital.Hospital_Name_readonly__c}"
                      data-accId="{!hospital.Hospital__c}"
                    >
                      <span
                        class="slds-lookup__item-action slds-media"
                        id="lookup-option-498"
                        role="option"
                      >
                                                <div class="slds-media__body">
                                                    <div class="slds-lookup__result-text">{!hospital.Hospital_Name_readonly__c}</div>
                          <div class="slds-lookup__result-text">
                            {!hospital.Hospital_Name_readonly__c}
                          </div>
                                                </div>
                                            </span>
                                        </li>
@@ -369,38 +603,70 @@
                        </div>
                        
                        <!-- 科室分类 -->
                        <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-8">
            <div
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-8"
            >
                            {!v.fieldsmap.Department_Cateogy__c}
                            <ui:inputSelect aura:id="select_department" class="slds-select" change="{!c.select_department}"/>
              <ui:inputSelect
                aura:id="select_department"
                class="slds-select"
                change="{!c.select_department}"
              />
                        </div>
                        
                        <!-- 先生 -->
                        <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-8">
            <div
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-8"
            >
                            {!v.fieldsmap.doctor2__c}
                            <ui:inputSelect aura:id="select_doctor" class="slds-select" change="{!c.doctor_change}"/>
              <ui:inputSelect
                aura:id="select_doctor"
                class="slds-select"
                change="{!c.doctor_change}"
              />
                        </div>
                        
                        <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-12">
            <div
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-12"
            >
                            <br/>
                            <ui:button label="新建" class="slds-button" press="{!c.createCon}" disabled="true" aura:id="new_con"/>
              <ui:button
                label="新建"
                class="slds-button"
                press="{!c.createCon}"
                disabled="true"
                aura:id="new_con"
              />
                        </div>
                        
                        <!-- 职位 -->
                        <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-8">
            <div
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-8"
            >
                            {!v.fieldsmap.visitor_title__c}
                            <div>{!v.doctor_title}</div>
                        </div>       
                        <!-- 活动区分 -->
                        <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-6">
            <div
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-6"
            >
                            {!v.fieldsmap.Purpose_Type__c}
                            <ui:inputSelect aura:id="select_purpose_type" class="slds-select" change="{!c.select_purpose_type}"/>
              <ui:inputSelect
                aura:id="select_purpose_type"
                class="slds-select"
                change="{!c.select_purpose_type}"
              />
                        </div>
                        <!-- 询价 -->
                        <div aura:id="input-opportunity-opp" class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--4-of-12 slds-large-size--4-of-12">
            <div
              aura:id="input-opportunity-opp"
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--4-of-12 slds-large-size--4-of-12"
            >
                            {!v.fieldsmap.Opportunity__c}
                            <!-- <ui:inputSelect aura:id="select_opportunity" class="slds-select"/> -->
                            <!-- <force:inputField value="{!v.data.Opportunity__c}" aura:id="input-opportunity"/> -->
                            <c:strike_lookup label=""
              <c:strike_lookup
                label=""
                                    object="Agency_Opportunity__c"
                                    searchField="Name"
                                    placeholder="搜索经销商询价..."
@@ -415,55 +681,102 @@
                                    showRecentRecords ="true"
                                    value="{!v.data.Opportunity__c}"
                                    filter="{!v.opportunity_cfilter}"
                                    subTitleFormat="{0}+{1}+{2}"/>
                subTitleFormat="{0}+{1}+{2}"
              />
                        </div>
                        <div aura:id="input-opportunity-blank" class="lds-p-horizontal--small slds-size--1-of-1 slds-medium-size--8-of-12 slds-large-size--8-of-12">
                        </div>
                        <div aura:id="input-opportunity-stage" class="disp_none slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--2-of-12 slds-large-size--2-of-12">
            <div
              aura:id="input-opportunity-blank"
              class="lds-p-horizontal--small slds-size--1-of-1 slds-medium-size--8-of-12 slds-large-size--8-of-12"
            ></div>
            <div
              aura:id="input-opportunity-stage"
              class="disp_none slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--2-of-12 slds-large-size--2-of-12"
            >
                            {!v.fieldsmap.StageName__c}
                            <!-- <ui:inputSelect aura:id="select_opportunity" class="slds-select"/> -->
                            <ui:inputSelect aura:id="select_stageName" class="slds-select"/>
                            <!-- <force:inputField value="{!v.oppdata.StageName__c}" aura:id="input-oppstage" /> -->
                        </div>
                        <div aura:id="input-opportunity-amount1" class="disp_none slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--2-of-12 slds-large-size--2-of-12">
            <div
              aura:id="input-opportunity-amount1"
              class="disp_none slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--2-of-12 slds-large-size--2-of-12"
            >
                            {!v.fieldsmap.Amount__c}
                            <!-- <ui:inputSelect aura:id="select_opportunity" class="slds-select"/> -->
                            <force:inputField value="{!v.oppdata.Amount__c}" class=""/>
                        </div>
                        <div aura:id="input-opportunity-amount2" class="disp_none slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--2-of-12 slds-large-size--2-of-12">
            <div
              aura:id="input-opportunity-amount2"
              class="disp_none slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--2-of-12 slds-large-size--2-of-12"
            >
                            {!v.fieldsmap.OCMSale_Price__c}
                            <!-- <ui:inputSelect aura:id="select_opportunity" class="slds-select"/> -->
                            <force:inputField value="{!v.oppdata.OCMSale_Price__c}" class=""/>
              <force:inputField
                value="{!v.oppdata.OCMSale_Price__c}"
                class=""
              />
                        </div>
                        <div aura:id="input-opportunity-date" class="disp_none slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--2-of-12 slds-large-size--2-of-12">
            <div
              aura:id="input-opportunity-date"
              class="disp_none slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--2-of-12 slds-large-size--2-of-12"
            >
                            {!v.fieldsmap.Close_Forecasted_Date__c}
                            <!-- <ui:inputSelect aura:id="select_opportunity" class="slds-select"/> -->
                            <force:inputField value="{!v.oppdata.Close_Forecasted_Date__c}" class=""/>
              <force:inputField
                value="{!v.oppdata.Close_Forecasted_Date__c}"
                class=""
              />
                        </div>
                        <!-- 製品分類 -->
                        <div aura:id="product_category_select1" class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12">
            <div
              aura:id="product_category_select1"
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12"
            >
                            {!v.fieldsmap.Product_Category1__c}
                            <!-- <force:inputField value="{!v.data.Product_Category1__c}" aura:id="input-product-category1"/> -->
                            <ui:inputSelect aura:id="select_Product1" class="slds-select" change="{!c.productcategoryChange1}"/>
              <ui:inputSelect
                aura:id="select_Product1"
                class="slds-select"
                change="{!c.productcategoryChange1}"
              />
                        </div>
                        <div aura:id="product_category_select2" class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12">
            <div
              aura:id="product_category_select2"
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12"
            >
                            {!v.fieldsmap.Product_Category2__c}
                            <!-- <force:inputField value="{!v.data.Product_Category2__c}" aura:id="input-product-category2"/> -->
                            <ui:inputSelect aura:id="select_Product2" class="slds-select" change="{!c.productcategoryChange2}"/>
              <ui:inputSelect
                aura:id="select_Product2"
                class="slds-select"
                change="{!c.productcategoryChange2}"
              />
                        </div>
                        <div aura:id="product_category_select3" class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12">
            <div
              aura:id="product_category_select3"
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12"
            >
                            {!v.fieldsmap.Product_Category3__c}
                            <!-- <force:inputField value="{!v.data.Product_Category3__c}" aura:id="input-product-category3"/> -->
                            <ui:inputSelect aura:id="select_Product3" class="slds-select" change="{!c.productcategoryChange3}"/>
              <ui:inputSelect
                aura:id="select_Product3"
                class="slds-select"
                change="{!c.productcategoryChange3}"
              />
                        </div>
                        <!--SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start-->
                        <!-- 支援需求 change="{!c.SupportNeeds__c}"-->
                        <div class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-6">
            <div
              class="slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--1-of-5 slds-large-size--1-of-6"
            >
                            {!v.fieldsmap.SupportNeeds__c}
                            <ui:inputSelect aura:id="SupportNeeds__c" class="slds-select" />
                        </div>
                        <!--SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 end-->
                        <div aura:id="result" class="disp_none slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12">
            <div
              aura:id="result"
              class="disp_none slds-p-horizontal--small slds-size--1-of-1 slds-medium-size--3-of-12 slds-large-size--3-of-12"
            >
                            {!v.fieldsmap.Result__c}
                            <ui:inputSelect aura:id="select_result" class="slds-select"/>
                            <!-- <ui:inputText label="结果" class="bcolor" value="{!v.result}"/> -->
@@ -471,13 +784,21 @@
                    </div>
                </div>
                <div class="save_button_area">
                    <ui:button aura:id="save_button" label="保存并新建" class="save_button slds-button slds-button--brand slds-order--3" press="{!c.save_report}"/>
          <ui:button
            aura:id="save_button"
            label="保存并新建"
            class="save_button slds-button slds-button--brand slds-order--3"
            press="{!c.save_report}"
          />
                </div>
                
                <aura:renderIf isTrue="{!v.reports_now_count > 0}">
                    <div class="mt40 slds-box slds-theme--shade">
                        <div class="slds-table--edit_container slds-is-relative">
                            <table class="slds-table slds-table--edit slds-table--bordered slds-table--fixed-layout slds-no-cell-focus" role="grid">
              <table
                class="slds-table slds-table--edit slds-table--bordered slds-table--fixed-layout slds-no-cell-focus"
                role="grid"
              >
                                <thead>
                                    <tr class="slds-line-height--reset">
                                        <th class="table_header slds-text-title--caps">
@@ -487,56 +808,96 @@
                                            <span class="slds-truncate" title="Name">医院</span>
                                        </th>
                                        <th class="table_header slds-text-title--caps">
                                            <span class="slds-truncate" title="Name">{!v.fieldsmap.Department_Cateogy__c}</span>
                      <span class="slds-truncate" title="Name"
                        >{!v.fieldsmap.Department_Cateogy__c}</span
                      >
                                        </th>
                                        <th class="table_header slds-text-title--caps">
                                            <span class="slds-truncate" title="Name">{!v.fieldsmap.doctor2__c}</span>
                      <span class="slds-truncate" title="Name"
                        >{!v.fieldsmap.doctor2__c}</span
                      >
                                        </th>
                                        <th class="table_header slds-text-title--caps">
                                            <span class="slds-truncate" title="Name">{!v.fieldsmap.visitor_title__c}</span>
                      <span class="slds-truncate" title="Name"
                        >{!v.fieldsmap.visitor_title__c}</span
                      >
                                        </th>
                                        <th class="table_header slds-text-title--caps">
                                            <span class="slds-truncate" title="Name">{!v.fieldsmap.Purpose_Type__c}</span>
                      <span class="slds-truncate" title="Name"
                        >{!v.fieldsmap.Purpose_Type__c}</span
                      >
                                        </th>
                                    </tr>
                                </thead>
                                <tbody>
                                    <aura:iteration items="{!v.reports_now}" var="item" indexVar="index">
                  <aura:iteration
                    items="{!v.reports_now}"
                    var="item"
                    indexVar="index"
                  >
                                        <tr aura:id="modal_data_list_tr" class="slds-hint-parent">
                                            <td role="gridcell" class="slds-cell-edit">
                                                <span class="slds-grid slds-grid--align-spread">
                                                    <span class="slds-truncate" title="{!item.Department_Cateogy__c}">{!item.Name}</span>
                          <span
                            class="slds-truncate"
                            title="{!item.Department_Cateogy__c}"
                            >{!item.Name}</span
                          >
                                                </span>
                                            </td>
                                            <td role="gridcell" class="slds-cell-edit">
                                                <span class="slds-grid slds-grid--align-spread">
                                                    <span class="slds-truncate" title="{!item.Agency_Hospital__r.Name}">{!item.Agency_Hospital__r.Name}</span>
                          <span
                            class="slds-truncate"
                            title="{!item.Agency_Hospital__r.Name}"
                            >{!item.Agency_Hospital__r.Name}</span
                          >
                                                </span>
                                            </td>
                                            <td role="gridcell" class="slds-cell-edit">
                                                <span class="slds-grid slds-grid--align-spread">
                                                    <span class="slds-truncate" title="{!item.Department_Cateogy__c}">{!item.Department_Cateogy__c}</span>
                          <span
                            class="slds-truncate"
                            title="{!item.Department_Cateogy__c}"
                            >{!item.Department_Cateogy__c}</span
                          >
                                                </span>
                                            </td>
                                            <td role="gridcell" class="slds-cell-edit">
                                                <span class="slds-grid slds-grid--align-spread">
                                                    <span class="slds-truncate" title="{!item.doctor2__r.Name}">
                          <span
                            class="slds-truncate"
                            title="{!item.doctor2__r.Name}"
                          >
                                                        <span class="encrypt">{!item.doctor2__r.Name}</span>
                                                        <span class="decrypt">{!item.doctor2NameOrigin}</span>
                            <span class="decrypt"
                              >{!item.doctor2NameOrigin}</span
                            >
                                                    </span>
                                                </span>
                                            </td>
                                            <td role="gridcell" class="slds-cell-edit">
                                                <span class="slds-grid slds-grid--align-spread">
                                                    <span class="slds-truncate" title="{!item.visitor_title__c}">
                                                        <span class="encrypt">{!item.visitor_title__c}</span>
                                                        <span class="decrypt">{!item.visitorTitleOrigin}</span>
                          <span
                            class="slds-truncate"
                            title="{!item.visitor_title__c}"
                          >
                            <span class="encrypt"
                              >{!item.visitor_title__c}</span
                            >
                            <span class="decrypt"
                              >{!item.visitorTitleOrigin}</span
                            >
                                                    </span>
                                                </span>
                                            </td>
                                            <td role="gridcell" class="slds-cell-edit">
                                                <span class="slds-grid slds-grid--align-spread">
                                                    <span class="slds-truncate" title="{!item.Purpose_Type__c}">{!item.Purpose_Type__c}</span>
                          <span
                            class="slds-truncate"
                            title="{!item.Purpose_Type__c}"
                            >{!item.Purpose_Type__c}</span
                          >
                                                </span>
                                            </td>
                                        </tr>
@@ -549,37 +910,80 @@
            </div>
        </div>
    </div>
    <div aura:id="modal_bg" class="disp_none slds-backdrop slds-backdrop--open"></div>
  <div
    aura:id="modal_bg"
    class="disp_none slds-backdrop slds-backdrop--open"
  ></div>
    
    <div aura:id="modal_confirm" role="dialog" tabindex="-2" aria-labelledby="header43" class="disp_none slds-modal slds-fade-in-open">
  <div
    aura:id="modal_confirm"
    role="dialog"
    tabindex="-2"
    aria-labelledby="header43"
    class="disp_none slds-modal slds-fade-in-open"
  >
        <div class="slds-modal__container">
            <div class="slds-modal__header">
                <h2 id="header43" class="slds-text-heading--medium">{!v.modal_confirm_title}</h2>
        <h2 id="header43" class="slds-text-heading--medium">
          {!v.modal_confirm_title}
        </h2>
            </div>
            <div class="slds-modal__content slds-p-around--medium">
                <p>{!v.modal_confirm_text}</p>
            </div>
            <div class="slds-modal__footer">
                <ui:button label="是" class="slds-button slds-button--brand" press="{!c.yes_button}"/>
                <ui:button label="否" class="slds-button slds-button--neutral" press="{!c.no_button}" />
        <ui:button
          label="是"
          class="slds-button slds-button--brand"
          press="{!c.yes_button}"
        />
        <ui:button
          label="否"
          class="slds-button slds-button--neutral"
          press="{!c.no_button}"
        />
            </div>
        </div>
    </div>
    <div aura:id="modal_confirm_bg" class="disp_none slds-backdrop slds-backdrop--open"></div>
  <div
    aura:id="modal_confirm_bg"
    class="disp_none slds-backdrop slds-backdrop--open"
  ></div>
    <div aura:id="modal_newAC" role="dialog" tabindex="-3" aria-labelledby="headertest" class="disp_none slds-modal slds-fade-in-open">
  <div
    aura:id="modal_newAC"
    role="dialog"
    tabindex="-3"
    aria-labelledby="headertest"
    class="disp_none slds-modal slds-fade-in-open"
  >
        <div class="slds-modal__container">
            <div class="slds-modal__header">
                <h2 id="headertest" class="slds-text-heading--medium">新建.客户人员</h2>
            </div>
            <div class="slds-modal__content slds-p-around--medium">
                <lightning:recordEditForm aura:id="recordEditForm"  objectApiName="Agency_Contact__c" onsuccess="{!c.handleSuccess}" onload="{!c.showRequiredFields}" onsubmit="{!c.handleSubmit}">
        <lightning:recordEditForm
          aura:id="recordEditForm"
          objectApiName="Agency_Contact__c"
          onsuccess="{!c.handleSuccess}"
          onload="{!c.showRequiredFields}"
          onsubmit="{!c.handleSubmit}"
        >
                    <lightning:messages aura:id="OppMessage" />
                    <!-- onload="{!c.showRequiredFields}" -->
                    <aura:renderIf isTrue="{!v.truthy}">
                        <lightning:inputField fieldName="Name" aura:id="newOpportunityField" />
                        <lightning:inputField fieldName="Type__c" aura:id="newOpportunityField" />
                        <lightning:inputField fieldName="Doctor_Division1__c" aura:id="newOpportunityField" />
            <lightning:inputField
              fieldName="Name"
              aura:id="newOpportunityField"
            />
            <lightning:inputField
              fieldName="Type__c"
              aura:id="newOpportunityField"
            />
            <lightning:inputField
              fieldName="Doctor_Division1__c"
              aura:id="newOpportunityField"
            />
                        <!-- <lightning:inputField class="customRequired none" aura:id="Input_type__c" fieldName="Type__c"/>
                        <lightning:inputField class="customRequired none" aura:id="Input_Doctor_Division1__c" fieldName="Doctor_Division1__c"/> -->
                    </aura:renderIf>
@@ -589,15 +993,20 @@
                    <br/>
                    <br/>
                    <div class="save_button_area">
                        <lightning:button class="slds-m-top_small" type="button" label="取消" onclick="{!c.createCancel}"/>
                        <lightning:button class="slds-m-top_small" type="submit" label="保存" />
            <lightning:button
              class="slds-m-top_small"
              type="button"
              label="取消"
              onclick="{!c.createCancel}"
            />
            <lightning:button
              class="slds-m-top_small"
              type="submit"
              label="保存"
            />
                    </div>
                </lightning:recordEditForm>
            </div>
        </div>
    </div>
</aura:component>
force-app/main/default/aura/WeeklyReport/WeeklyReportController.js
@@ -1,6 +1,6 @@
({
    doInit : function(component, event, helper) {
        console.log('zhj 新方案weeklyReport');
    console.log("zhj 新方案weeklyReport");
        if (window.location.href.endsWith("weekly-report")) {
            helper.doinit(component, event, helper);
        } else {
@@ -10,22 +10,23 @@
    },
    createAopp : function(component, event, helper) {
        var addRecordEvent = $A.get('e.force:createRecord');
    var addRecordEvent = $A.get("e.force:createRecord");
        addRecordEvent.setParams({
            entityApiName: 'Agency_Opportunity__c',
            recordTypeId: '012100000006KW7'
      entityApiName: "Agency_Opportunity__c",
      recordTypeId: "012100000006KW7"
        });
        addRecordEvent.fire();
        component.set("v.showErrorInfo", false);
    },
    
    new_report : function(component, event, helper) {
        component.find('save_button').set('v.label', '保存并新建');
    component.find("save_button").set("v.label", "保存并新建");
    component.set("v.data.Report_Date__c", "");
        helper.new_report(component, event, helper);
    },
    
    copy_button : function(component, event, helper) {
        component.find('save_button').set('v.label', '保存并新建');
    component.find("save_button").set("v.label", "保存并新建");
        helper.copy_button(component, event, helper);
    },
    
@@ -34,7 +35,7 @@
    },
    
    edit_button : function(component, event, helper) {
        component.find('save_button').set('v.label', '保存');
    component.find("save_button").set("v.label", "保存");
        helper.edit_button(component, event, helper);
    },
    
@@ -63,7 +64,7 @@
        // helper.handleFormSubmit(component);
        var showValidationError = false;
        var fields = component.find("newOpportunityField");
        var vaildationFailReason = '';
    var vaildationFailReason = "";
        // var vaildationFailReason2 = '';
        // var currentDate = new Date().toJSON().slice(0,10);
        
@@ -72,25 +73,30 @@
        // PIPL update Yin Mingjie 21/02/2022 end
        fields.forEach(function (field) {
            if(field.get("v.fieldName") === 'Type__c' && $A.util.isEmpty(field.get("v.value"))){
      if (
        field.get("v.fieldName") === "Type__c" &&
        $A.util.isEmpty(field.get("v.value"))
      ) {
                showValidationError = true;
                vaildationFailReason = "分类不能为空!";
            }else if(field.get("v.fieldName") === 'Doctor_Division1__c' && $A.util.isEmpty(field.get("v.value"))){
      } else if (
        field.get("v.fieldName") === "Doctor_Division1__c" &&
        $A.util.isEmpty(field.get("v.value"))
      ) {
                showValidationError = true;
                if(vaildationFailReason != ''){
        if (vaildationFailReason != "") {
                    vaildationFailReason += "医生区分(职务)不能为空!";
                }else{
                    vaildationFailReason = "医生区分(职务)不能为空!";
                }
            }
            // PIPL update Yin Mingjie 21/02/2022 start
            if(field.get("v.fieldName") === 'Name'){
                agencyReport['name'] = field.get("v.value");
            }else if(field.get("v.fieldName") === 'Type__c'){
                agencyReport['type'] = field.get("v.value");
            }else if(field.get("v.fieldName") === 'Doctor_Division1__c'){
                agencyReport['doctorDivision1'] = field.get("v.value");
      if (field.get("v.fieldName") === "Name") {
        agencyReport["name"] = field.get("v.value");
      } else if (field.get("v.fieldName") === "Type__c") {
        agencyReport["type"] = field.get("v.value");
      } else if (field.get("v.fieldName") === "Doctor_Division1__c") {
        agencyReport["doctorDivision1"] = field.get("v.value");
            }
            // PIPL update Yin Mingjie 21/02/2022 end
        });
@@ -103,52 +109,65 @@
            component.find('recordEditForm').submit(eventFields);
            */
            var agencyHospitalid = component.get('v.hospitalLinkId');
      var agencyHospitalid = component.get("v.hospitalLinkId");
            //zhj MEBG新方案改造 2022-11-29 start
            debugger
            let hospitalName = '';
      debugger;
      let hospitalName = "";
            //调用后端searchAgencyDataId方法查询出医院下面所有客户人员dataid
            helper.CallBackAction(component,'searchAgencyDataId',{
      helper.CallBackAction(
        component,
        "searchAgencyDataId",
        {
                hospitalId : agencyHospitalid
            },function(data){
        },
        function (data) {
                if(data.getState() == "SUCCESS"){
                    var data = data.getReturnValue();
                    if(data.IsSuccess == true){
                        let agencyContactIds = ''
                        if(data.Message == '' && data.Data && data.Data.length > 0){
              let agencyContactIds = "";
              if (data.Message == "" && data.Data && data.Data.length > 0) {
                            hospitalName = data.Data[0].Agency_Hospital__r.Name;
                            for(var i=0;i<data.Data.length;i++){
                                if(data.Data[i].AWS_Data_Id__c)
                                    agencyContactIds += ','+data.Data[i].AWS_Data_Id__c;
                    agencyContactIds += "," + data.Data[i].AWS_Data_Id__c;
                            }
                            agencyContactIds = agencyContactIds.substring(1);
                            agencyReport['agencyContactIds'] = agencyContactIds;
                agencyReport["agencyContactIds"] = agencyContactIds;
                        }else{
                            agencyReport['agencyContactIds'] = agencyContactIds;
                agencyReport["agencyContactIds"] = agencyContactIds;
                        }
                        var arr = new Array();
                        arr.push(agencyReport);
                        var requestData = JSON.stringify(arr);
                        // helper.set_aws_url(component,data,agencyHospitalid);
                        var token = component.get('v.AWStoken');
                        var newUrl = component.get('v.AWSinsert') + 'V2';
              var token = component.get("v.AWStoken");
              var newUrl = component.get("v.AWSinsert") + "V2";
                        
                        component.set('v.login',true);
                        helper.insert_agencycontact(component,token,newUrl,requestData,agencyHospitalid,helper,hospitalName);
              component.set("v.login", true);
              helper.insert_agencycontact(
                component,
                token,
                newUrl,
                requestData,
                agencyHospitalid,
                helper,
                hospitalName
              );
                    }else{
                        helper.ShowToast({
                            "message" : data.message,
                            "type" : "error"
                message: data.message,
                type: "error"
                        });
                    }
                }else{
                    helper.ShowToast({
                        "message" : 'searchAgency失败',
                        "type" : "error"
              message: "searchAgency失败",
              type: "error"
                    });
                }
            })
        }
      );
            //zhj MEBG新方案改造 2022-11-29 end
            // var arr = new Array();
            // arr.push(agencyReport);
@@ -163,7 +182,7 @@
            // PIPL update Yin Mingjie 21/02/2022 end
        }else{
            component.find('OppMessage').setError(vaildationFailReason);
      component.find("OppMessage").setError(vaildationFailReason);
        }
        // var eventFields = event.getParam("fields");
        // eventFields["Agency_Hospital__c"] = component.get('v.hospitalLinkId');
@@ -176,13 +195,21 @@
    },
    
    yes_button : function(component, event, helper) {
        component.set('v.confirm_status', 1);
        helper.close_confirm(component, component.get('v.modal_confirm_title'), component.get('v.modal_confirm_text'));
    component.set("v.confirm_status", 1);
    helper.close_confirm(
      component,
      component.get("v.modal_confirm_title"),
      component.get("v.modal_confirm_text")
    );
    },
    no_button : function(component, event, helper) {
        component.set('v.confirm_status', 2);
        helper.close_confirm(component, component.get('v.modal_confirm_title'), component.get('v.modal_confirm_text'));
    component.set("v.confirm_status", 2);
    helper.close_confirm(
      component,
      component.get("v.modal_confirm_title"),
      component.get("v.modal_confirm_text")
    );
    },
    
    toggle_report : function(component, event, helper) {
@@ -249,7 +276,7 @@
    onDrop : function(component, event, helper) {
        event.stopPropagation();
        event.preventDefault();
        event.dataTransfer.dropEffect='copy';
    event.dataTransfer.dropEffect = "copy";
        var files=event.dataTransfer.files;
        helper.readFile(component,helper,files[0]);
    },
@@ -277,20 +304,22 @@
    },
    exportDate : function(component,event,helper){
        var stockData = component.get("v.reports_date");
        console.log('导出数据'+stockData);
    console.log("导出数据" + stockData);
        var csv = helper.convertArrayOfObjectsToCSV(component,stockData);
        if (csv == null){return;}
    if (csv == null) {
      return;
    }
        // ####--code for create a temp. <a> html tag [link tag] for download the CSV file--####     
        var universalBOM = "\uFEFF";
        var hiddenElement = document.createElement('a');
        hiddenElement.href = 'data:text/csv;charset=utf-8,' + encodeURI(universalBOM+csv);
        hiddenElement.target = '_self'; //
        hiddenElement.download = 'ExportData.csv';  // CSV file Name* you can change it.[only name not .csv]
    var hiddenElement = document.createElement("a");
    hiddenElement.href =
      "data:text/csv;charset=utf-8," + encodeURI(universalBOM + csv);
    hiddenElement.target = "_self"; //
    hiddenElement.download = "ExportData.csv"; // CSV file Name* you can change it.[only name not .csv]
        document.body.appendChild(hiddenElement); // Required for FireFox browser
        hiddenElement.click(); // using click() js function to download csv file
        // helper.showExport(component);
    },
    export_condition : function(component,event,helper){
@@ -305,9 +334,9 @@
        // this.export(component,event,helper);
    },
    export : function(component,event,helper){
        console.log('进入export');
    console.log("进入export");
        var stockData = component.get("v.reports_date");
        console.log('查出的数据'+stockData);
    console.log("查出的数据" + stockData);
        // helper.showExportDate(component,stockData);
        // helper.showExport(component);
    },
@@ -321,5 +350,5 @@
    },
    exportErrorInfo: function(component,event,helper){
        helper.exportErrorInfoHelper(component);
    },
})
  }
});
force-app/main/default/aura/WeeklyReport/WeeklyReportHelper.js
@@ -1,39 +1,71 @@
({
    doinit : function(component, event, helper) {
        this.report_date_list(component, event, helper, 5);
        component.set('v.login',true);
        var action = component.get('c.getalldata');
    component.set("v.login", true);
    var action = component.get("c.getalldata");
        action.setCallback(this,function(response){
            var state = response.getState();
            if(state == 'SUCCESS'){
      if (state == "SUCCESS") {
                var res = response.getReturnValue();
                component.set('v.alldata',res.reports);
                component.set('v.fieldsmap',res.fieldsMap);
                component.set('v.allselectlist',res.allselectlist);
                component.set('v.doclist',res.doclist);
        component.set("v.alldata", res.reports);
        component.set("v.fieldsmap", res.fieldsMap);
        component.set("v.allselectlist", res.allselectlist);
        component.set("v.doclist", res.doclist);
                // PIPL update Yin Mingjie 21/02/2022 start
                component.find('select_agency_person').set('v.options', this.conv_selected(res.allselectlist.AgencyPerson__c));
        component
          .find("select_agency_person")
          .set(
            "v.options",
            this.conv_selected(res.allselectlist.AgencyPerson__c)
          );
                // this.search_contact(component, event, helper,res.allselectlist.AgencyPerson__c);
                // PIPL update Yin Mingjie 21/02/2022 end
                component.find('select_department').set('v.options', this.conv_selected(res.allselectlist.Department_Cateogy__c));
                component.find('select_purpose_type').set('v.options', this.conv_selected(res.allselectlist.Purpose_Type__c));
                component.find('select_result').set('v.options', this.conv_selected(res.allselectlist.Result__c));
                component.find('select_stageName').set('v.options', this.conv_selected(res.allselectlist.StageName__c));
        component
          .find("select_department")
          .set(
            "v.options",
            this.conv_selected(res.allselectlist.Department_Cateogy__c)
          );
        component
          .find("select_purpose_type")
          .set(
            "v.options",
            this.conv_selected(res.allselectlist.Purpose_Type__c)
          );
        component
          .find("select_result")
          .set("v.options", this.conv_selected(res.allselectlist.Result__c));
        component
          .find("select_stageName")
          .set("v.options", this.conv_selected(res.allselectlist.StageName__c));
                 //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start
                 component.find('SupportNeeds__c').set('v.options', this.conv_selected(res.allselectlist.SupportNeeds__c));
        component
          .find("SupportNeeds__c")
          .set(
            "v.options",
            this.conv_selected(res.allselectlist.SupportNeeds__c)
          );
                 //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 end
                component.set('v.selected_agency_person', res.allselectlist.AgencyPerson__c[0].label);
                component.set('v.dialog_type', '新建');
                component.set('v.awsurl', res.awsurl);// 20220222 PI改造 by Bright
                component.set('v.contactawsurl', res.contactawsurl);// 20220222 PI改造 by Bright
        component.set(
          "v.selected_agency_person",
          res.allselectlist.AgencyPerson__c[0].label
        );
        component.set("v.dialog_type", "新建");
        component.set("v.awsurl", res.awsurl); // 20220222 PI改造 by Bright
        component.set("v.contactawsurl", res.contactawsurl); // 20220222 PI改造 by Bright
                
                this.get_reports(component, event, helper, component.find('select_date').get('v.value'), component.find('select_agency_person').get('v.value'));
        this.get_reports(
          component,
          event,
          helper,
          component.find("select_date").get("v.value"),
          component.find("select_agency_person").get("v.value")
        );
                
                component.set('v.login',false);
            }
            else{
                this.error('doinit failed.');
                component.set('v.login',false);
        component.set("v.login", false);
      } else {
        this.error("doinit failed.");
        component.set("v.login", false);
            }
        });
        $A.enqueueAction(action);
@@ -44,30 +76,35 @@
        let contactData = Object.create(null);
        var dataArr = new Array();
        for (let i = 0; i < resobj.length; i++) {
            if (resobj[i].awsid != null && resobj[i].awsid != ''){
      if (resobj[i].awsid != null && resobj[i].awsid != "") {
                contactData[resobj[i].awsid] = resobj[i];
                dataArr.push(resobj[i].awsid);
            }
        }
        let obj= Object.create(null);
        obj['dataIds'] = dataArr;
    obj["dataIds"] = dataArr;
        var payload = JSON.stringify(obj);
        this.search_contact_url(component, 'Contact', (result)=>{
    this.search_contact_url(component, "Contact", (result) => {
            var token = result.token;
            var searchUrl = result.searchUrl;
            this.search_core(token,searchUrl,payload,(result)=>{
                if(result.status == '0'){
      this.search_core(
        token,
        searchUrl,
        payload,
        (result) => {
          if (result.status == "0") {
                    if(result.object != null){
                        this.to_contact_list(result,contactData,component);
                    }else{
                        component.set('v.login',false);
              component.set("v.login", false);
                    }
                }else{
                    this.error('AWS search status1 : ' + result.status);
                    component.set('v.login',false);
            this.error("AWS search status1 : " + result.status);
            component.set("v.login", false);
                }
            },component);
        },
        component
      );
        });
    },
@@ -75,38 +112,37 @@
        var resls = result.object;
        var res = [];
        var space = {};
        space['label'] = '';
        space['selected'] = true;
        space['value'] = '';
    space["label"] = "";
    space["selected"] = true;
    space["value"] = "";
        res.push(space);
        for (var i = 0; i < resls.length; i++) {
            var t = {};
            t['label'] = resls[i].lastName;
            t['selected'] = false;
            t['Doctor_Division1__c'] = resls[i].doctorDivision1;
            t['value'] = retMap[resls[i].dataId].value;
      t["label"] = resls[i].lastName;
      t["selected"] = false;
      t["Doctor_Division1__c"] = resls[i].doctorDivision1;
      t["value"] = retMap[resls[i].dataId].value;
            res.push(t);
        }
        component.find('select_agency_person').set('v.options',res);
        component.set('v.allselectlistAgencyPerson',res);
        component.set('v.login',false);
    component.find("select_agency_person").set("v.options", res);
    component.set("v.allselectlistAgencyPerson", res);
    component.set("v.login", false);
    },
    search_contact_url : function(component, sobject, callback) {
        var action = component.get('c.getAwsurl');
    var action = component.get("c.getAwsurl");
        action.setParams({
            "sobj" : sobject,
      sobj: sobject
        });
        action.setCallback(this,function(response){
            var state = response.getState();
            if(state == 'SUCCESS'){
      if (state == "SUCCESS") {
                var result = response.getReturnValue();
                if(callback)callback(result);
            }
            else{
                this.error('AWS url/token error.');
                component.set('v.login',false);
      } else {
        this.error("AWS url/token error.");
        component.set("v.login", false);
            }
        });
        $A.enqueueAction(action);
@@ -115,42 +151,45 @@
    select_department : function(component, event, helper) {
        var dc = component.find("select_department").get("v.value");
        dc = dc ? '%'+dc+'%' : '';
    dc = dc ? "%" + dc + "%" : "";
        var purpose_type = component.find("select_purpose_type").get("v.value");
        if (purpose_type) {
            if (purpose_type.substr(-3) == 'OPD') {
                purpose_type = 'OPD';
            } else if (purpose_type.substr(-3) == 'SIS') {
                purpose_type = 'SIS';
      if (purpose_type.substr(-3) == "OPD") {
        purpose_type = "OPD";
      } else if (purpose_type.substr(-3) == "SIS") {
        purpose_type = "SIS";
            } else {
                purpose_type = '';
        purpose_type = "";
            }
        }
        if (dc != '' || purpose_type != '') {
            var action = component.get('c.getProductList');
    if (dc != "" || purpose_type != "") {
      var action = component.get("c.getProductList");
            action.setParams({
                "dc" : dc,
                "opdsis" : purpose_type,
        dc: dc,
        opdsis: purpose_type
            });
            action.setCallback(this,function(response){
                var state = response.getState();
                if(state == 'SUCCESS'){
        if (state == "SUCCESS") {
                    var res = response.getReturnValue();
                    component.find('select_Product1').set("v.options", JSON.parse(JSON.stringify(res)));
                    component.find('select_Product2').set("v.options", JSON.parse(JSON.stringify(res)));
                    component.find('select_Product3').set("v.options", JSON.parse(JSON.stringify(res)));
                }
                else{
                    this.error('getProductList failed.');
          component
            .find("select_Product1")
            .set("v.options", JSON.parse(JSON.stringify(res)));
          component
            .find("select_Product2")
            .set("v.options", JSON.parse(JSON.stringify(res)));
          component
            .find("select_Product3")
            .set("v.options", JSON.parse(JSON.stringify(res)));
        } else {
          this.error("getProductList failed.");
                }
            });
            $A.enqueueAction(action);
        } else {
            component.find('select_Product1').set('v.options', []);
            component.find('select_Product2').set('v.options', []);
            component.find('select_Product3').set('v.options', []);
      component.find("select_Product1").set("v.options", []);
      component.find("select_Product2").set("v.options", []);
      component.find("select_Product3").set("v.options", []);
        }
    },
@@ -161,18 +200,18 @@
        
        date_str = this.get_date_string(date_str);
        
        var action = component.get('c.getReports');
    var action = component.get("c.getReports");
        action.setParams({
            "date_str" : date_str,
            "person_str" : person_str,
      date_str: date_str,
      person_str: person_str
        });
        component.set('v.login',true);
    component.set("v.login", true);
        action.setCallback(this,function(response){
            var state = response.getState();
            if(state == 'SUCCESS'){
      if (state == "SUCCESS") {
                var res = response.getReturnValue();
                component.set('v.reports', res.reports);
        component.set("v.reports", res.reports);
                
                // 20220222 PI改造 by Bright--start
                let dataIds = [];
@@ -185,7 +224,10 @@
                        dataIds.push(rep.doctor2__r.AWS_Data_Id__c);
                    }
                    if (rep.Person_In_Charge2__r && rep.Person_In_Charge2__r.AWS_Data_Id__c) {
          if (
            rep.Person_In_Charge2__r &&
            rep.Person_In_Charge2__r.AWS_Data_Id__c
          ) {
                        dataIds1.push(rep.Person_In_Charge2__r.AWS_Data_Id__c);
                    }
                }
@@ -193,28 +235,40 @@
                Foo = function(){
                    if(b && b1){
                        for (const rep of res.reports) {
                            if (rep.doctor2__r && rep.doctor2__r.AWS_Data_Id__c && mm.hasOwnProperty(rep.doctor2__r.AWS_Data_Id__c)) {
              if (
                rep.doctor2__r &&
                rep.doctor2__r.AWS_Data_Id__c &&
                mm.hasOwnProperty(rep.doctor2__r.AWS_Data_Id__c)
              ) {
                                rep.doctor2__r.awsdata = mm[rep.doctor2__r.AWS_Data_Id__c];
                            }
                            if (rep.Person_In_Charge2__r && rep.Person_In_Charge2__r.AWS_Data_Id__c && mm.hasOwnProperty(rep.Person_In_Charge2__r.AWS_Data_Id__c)) {
                                rep.Person_In_Charge2__r.awsdata = mm[rep.Person_In_Charge2__r.AWS_Data_Id__c];
              if (
                rep.Person_In_Charge2__r &&
                rep.Person_In_Charge2__r.AWS_Data_Id__c &&
                mm.hasOwnProperty(rep.Person_In_Charge2__r.AWS_Data_Id__c)
              ) {
                rep.Person_In_Charge2__r.awsdata =
                  mm[rep.Person_In_Charge2__r.AWS_Data_Id__c];
                            }
                        }
                        $A.getCallback(()=>component.set('v.reports', res.reports))();
            $A.getCallback(() => component.set("v.reports", res.reports))();
                    }else{
                        console.log('b='+b + ',b1='+b1+',continue');
            console.log("b=" + b + ",b1=" + b1 + ",continue");
                        setTimeout(Foo,100);
                    }
                }
        };
                
                if(dataIds.length > 0){
                    let awsurl = component.get('v.awsurl');
                    helper.search_core(awsurl.token,awsurl.searchUrl,JSON.stringify({
                        "dataIds":dataIds
                    }),(result)=>{
                        if(result.status == '0'){
          let awsurl = component.get("v.awsurl");
          helper.search_core(
            awsurl.token,
            awsurl.searchUrl,
            JSON.stringify({
              dataIds: dataIds
            }),
            (result) => {
              if (result.status == "0") {
                            for (const m of result.object) {
                                mm[m.dataId] = m;
                            }
@@ -222,92 +276,108 @@
                            Foo();
                        }else{
                            //this.error('AWS search status2 : ' + result.status);
                            this.success('请重新刷新页面进行解密');
                this.success("请重新刷新页面进行解密");
                        }
                    },component);
            },
            component
          );
                }else{
                    b = true;
                }
                if(dataIds1.length > 0){
                    let contactawsurl = component.get('v.contactawsurl');
                    helper.search_core(contactawsurl.token,contactawsurl.searchUrl,JSON.stringify({
                        "dataIds":dataIds1
                    }),(result)=>{
                        if(result.status == '0'){
          let contactawsurl = component.get("v.contactawsurl");
          helper.search_core(
            contactawsurl.token,
            contactawsurl.searchUrl,
            JSON.stringify({
              dataIds: dataIds1
            }),
            (result) => {
              if (result.status == "0") {
                            for (const m of result.object) {
                                mm[m.dataId] = m;
                            }
                            b1 = true;
                            Foo();
                        }else{
                            this.error('AWS search status3 : ' + result.status);
                this.error("AWS search status3 : " + result.status);
                        }
                    },component);
            },
            component
          );
                }else{
                    b1 = true;
                }
                // 20220222 PI改造 by Bright--end
                component.set('v.report_count', res.reports.length);
        component.set("v.report_count", res.reports.length);
                // 更新保存後のselect_data用
                var report_id = component.get('v.update_select_report_data_id');
        var report_id = component.get("v.update_select_report_data_id");
                
                if (report_id != "") {
                    for (i = 0; i < res.reports.length; i++) {
                        if (res.reports[i]['Id'] == report_id) {
                            component.set('v.select_report_data', res.reports[i]);
            if (res.reports[i]["Id"] == report_id) {
              component.set("v.select_report_data", res.reports[i]);
                            break;
                        }
                    }
                    component.set('v.update_select_report_data_id', '');
          component.set("v.update_select_report_data_id", "");
                }
                
                if (res.reports.length > 0) {
                    component.set('v.list_message', '');
          component.set("v.list_message", "");
                } else {
                    component.set('v.list_message', 'no_data');
          component.set("v.list_message", "no_data");
                }
                component.set('v.login',false);
            }
            else{
                this.error('get_reports failed.');
                component.set('v.login',false);
        component.set("v.login", false);
      } else {
        this.error("get_reports failed.");
        component.set("v.login", false);
            }
        });
        $A.enqueueAction(action);
    },
    
    select_date_change : function(component, event, helper) {
        this.get_reports(component, event, helper, component.find('select_date').get('v.value'), component.find('select_agency_person').get('v.value'));
    this.get_reports(
      component,
      event,
      helper,
      component.find("select_date").get("v.value"),
      component.find("select_agency_person").get("v.value")
    );
        this.new_button_disabled(component, event, helper);
        
        component.set('v.select_report_data_radio', '');
        component.find('copy_button').set('v.disabled', true);
    component.set("v.select_report_data_radio", "");
    component.find("copy_button").set("v.disabled", true);
    },
    
    select_agency_change : function(component, event, helper) {
        var select_value = component.find('select_agency_person').get('v.value');
    var select_value = component.find("select_agency_person").get("v.value");
        var new_label = this.get_agency_person_name(component, select_value);
        component.set('v.selected_agency_person', new_label);
    component.set("v.selected_agency_person", new_label);
        
        this.get_reports(component, event, helper, component.find('select_date').get('v.value'), select_value);
    this.get_reports(
      component,
      event,
      helper,
      component.find("select_date").get("v.value"),
      select_value
    );
        this.new_button_disabled(component, event, helper);
        component.set('v.select_report_data_radio', '');
        component.find('copy_button').set('v.disabled', true);
    component.set("v.select_report_data_radio", "");
    component.find("copy_button").set("v.disabled", true);
    },
    
    get_agency_person_name : function(component, agency_person_value) {
        // PIPL update Yin Mingjie 21/02/2022 start
        var allselectlist = component.get('v.allselectlist.AgencyPerson__c');
    var allselectlist = component.get("v.allselectlist.AgencyPerson__c");
        // var allselectlist = component.get('v.allselectlistAgencyPerson');
        // PIPL update Yin Mingjie 21/02/2022 end
        var new_label = '';
    var new_label = "";
        for (var i = 0; i < allselectlist.length; i++) {
            if (agency_person_value == allselectlist[i].value) {
                new_label = allselectlist[i].label;
@@ -318,80 +388,104 @@
    },
    
    new_button_disabled : function(component, event, helper) {
        var select_date = component.find('select_date').get('v.value');
        var select_agency = component.find('select_agency_person').get('v.value');
    var select_date = component.find("select_date").get("v.value");
    var select_agency = component.find("select_agency_person").get("v.value");
        if (select_date && select_agency) {
            component.find('new_button').set('v.disabled', false);
      component.find("new_button").set("v.disabled", false);
        } else {
            component.find('new_button').set('v.disabled', true);
      component.find("new_button").set("v.disabled", true);
        }
    },
    
    toggle_report : function(component) {
        var modal_window = component.find('modal_window');
        var modal_bg = component.find('modal_bg');
        if ($A.util.hasClass(modal_window, 'disp_none')) {
    var modal_window = component.find("modal_window");
    var modal_bg = component.find("modal_bg");
    if ($A.util.hasClass(modal_window, "disp_none")) {
            // OPEN
            $A.util.removeClass(modal_window, 'disp_none');
            $A.util.removeClass(modal_bg, 'disp_none');
      $A.util.removeClass(modal_window, "disp_none");
      $A.util.removeClass(modal_bg, "disp_none");
            
            if (component.get('v.mode') == 'edit' || component.get('v.mode') == 'copy') {
                var select_data = '';
                if (component.get('v.mode') == 'edit') {
                    select_data = component.get('v.select_report_data');
                } else if (component.get('v.mode') == 'copy') {
                    select_data = component.get('v.select_report_data_radio');
      if (
        component.get("v.mode") == "edit" ||
        component.get("v.mode") == "copy"
      ) {
        var select_data = "";
        if (component.get("v.mode") == "edit") {
          select_data = component.get("v.select_report_data");
        } else if (component.get("v.mode") == "copy") {
          select_data = component.get("v.select_report_data_radio");
                }
                
                var reports = component.get('v.reports');
                var Agency_Hospital_text = '';
                var Agency_Hospital_parent_id = '';
                debugger
        var reports = component.get("v.reports");
        var Agency_Hospital_text = "";
        var Agency_Hospital_parent_id = "";
        debugger;
                // 医院名
                if (select_data['Agency_Hospital__c'] != '') {
        if (select_data["Agency_Hospital__c"] != "") {
                    for (var i = 0; i < reports.length; i++) {
                        if (reports[i]['Agency_Hospital__c'] == select_data['Agency_Hospital__c']) {
                            Agency_Hospital_text = reports[i]['Agency_Hospital__r']['Name'];
                            Agency_Hospital_parent_id = reports[i]['Agency_Hospital__r']['Hospital__c'];
            if (
              reports[i]["Agency_Hospital__c"] ==
              select_data["Agency_Hospital__c"]
            ) {
              Agency_Hospital_text = reports[i]["Agency_Hospital__r"]["Name"];
              Agency_Hospital_parent_id =
                reports[i]["Agency_Hospital__r"]["Hospital__c"];
                        }
                    }
                    component.set('v.hospital', Agency_Hospital_text);
                    component.set('v.hospitalId', Agency_Hospital_parent_id);
                    component.set('v.hospitalLinkId', select_data['Agency_Hospital__c']);
                    component.find('new_con').set('v.disabled', false);
          component.set("v.hospital", Agency_Hospital_text);
          component.set("v.hospitalId", Agency_Hospital_parent_id);
          component.set("v.hospitalLinkId", select_data["Agency_Hospital__c"]);
          component.find("new_con").set("v.disabled", false);
                }
                
                // 科室
                if (select_data['Department_Cateogy__c'] != '') {
                    this.set_selected(component, 'select_department', select_data['Department_Cateogy__c']);
        if (select_data["Department_Cateogy__c"] != "") {
          this.set_selected(
            component,
            "select_department",
            select_data["Department_Cateogy__c"]
          );
                }
                // 拜访人
                component.set('v.default_select_doctor_id', select_data['doctor2__c']);
        component.set("v.default_select_doctor_id", select_data["doctor2__c"]);
                this.set_doctor_list(component);
                
                // 活动区分
                if (select_data['Purpose_Type__c'] != '') {
                    this.set_selected(component, 'select_purpose_type', select_data['Purpose_Type__c']);
        if (select_data["Purpose_Type__c"] != "") {
          this.set_selected(
            component,
            "select_purpose_type",
            select_data["Purpose_Type__c"]
          );
                    this.select_purpose_type(component);
                }
                //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start
                // 支援需求
                if (select_data['SupportNeeds__c'] != '') {
                    this.set_selected(component, 'SupportNeeds__c', select_data['SupportNeeds__c']);
        if (select_data["SupportNeeds__c"] != "") {
          this.set_selected(
            component,
            "SupportNeeds__c",
            select_data["SupportNeeds__c"]
          );
                }  
                //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 end             
                // 結果
                if (select_data['Result__c'] != '' && typeof select_data['Result__c'] !== "undefined") {
                    component.find('select_result').set('v.value', select_data['Result__c']);
        if (
          select_data["Result__c"] != "" &&
          typeof select_data["Result__c"] !== "undefined"
        ) {
          component
            .find("select_result")
            .set("v.value", select_data["Result__c"]);
                }
                
                // 询价
                var report_id = component.get('v.edit_copy_select_report_id');
        var report_id = component.get("v.edit_copy_select_report_id");
                if (report_id != "") {
                    var select_opp = '';
                    var select_product_category1 = '';
                    var select_product_category2 = '';
                    var select_product_category3 = '';
          var select_opp = "";
          var select_product_category1 = "";
          var select_product_category2 = "";
          var select_product_category3 = "";
                    var reportDate;
                    var i = 0;
                    for (i = 0; i < reports.length; i++) {
@@ -406,85 +500,116 @@
                    }
                    
                    // 询价
                    if (select_opp != null && select_opp != '') {
                        var select_opp_name = component.get('v.reports')[i].OppName__c;
                        component.set('v.data.Opportunity__c', select_opp);
                        if ($A.get("$Browser.formFactor") == 'DESKTOP') {
                            var values = [{
                                type: 'Agency_Opportunity__c',
          if (select_opp != null && select_opp != "") {
            var select_opp_name = component.get("v.reports")[i].OppName__c;
            component.set("v.data.Opportunity__c", select_opp);
            if ($A.get("$Browser.formFactor") == "DESKTOP") {
              var values = [
                {
                  type: "Agency_Opportunity__c",
                                id: select_opp,
                                label: select_opp_name, 
                                icon : {
                                    url:'/img/icon/t4v35/custom/custom12_120.png',
                                    backgroundColor:'dc71d1',
                                    alt:'Agency_Opportunity__c'
                    url: "/img/icon/t4v35/custom/custom12_120.png",
                    backgroundColor: "dc71d1",
                    alt: "Agency_Opportunity__c"
                                }
                            }];
                            component.set('v.data.Opportunity__c', select_opp);
                }
              ];
              component.set("v.data.Opportunity__c", select_opp);
                            // component.find('input-opportunity').get("v.body")[0].set('v.values', values);
                        } else {
                            component.find('input-opportunity').get("v.body")[0].set('v.selectedLabel', select_opp_name);
              component
                .find("input-opportunity")
                .get("v.body")[0]
                .set("v.selectedLabel", select_opp_name);
                        }
                    }
                    
                    // 产品区分
                    if (select_product_category1 != null && select_product_category1 != '') {
                        component.find('select_Product1').set('v.value', select_product_category1);
          if (
            select_product_category1 != null &&
            select_product_category1 != ""
          ) {
            component
              .find("select_Product1")
              .set("v.value", select_product_category1);
                    }
                    if (select_product_category2 != null && select_product_category2 != '') {
                        component.find('select_Product2').set('v.value', select_product_category2);
          if (
            select_product_category2 != null &&
            select_product_category2 != ""
          ) {
            component
              .find("select_Product2")
              .set("v.value", select_product_category2);
                    }
                    if (select_product_category3 != null && select_product_category3 != '') {
                        component.find('select_Product3').set('v.value', select_product_category3);
                    }
                    console.log('reportDate = ' + reportDate);
                    if (reportDate != null) {
                        console.log('reportDate = ' + reportDate);
                        component.set('v.data.Report_Date__c', reportDate);
          if (
            select_product_category3 != null &&
            select_product_category3 != ""
          ) {
            component
              .find("select_Product3")
              .set("v.value", select_product_category3);
                    }
                    
                    component.set('v.edit_copy_select_report_id', "");
          if (reportDate != null) {
            console.log("reportDate = " + reportDate);
            component.set("v.data.Report_Date__c", reportDate);
          }
          component.set("v.edit_copy_select_report_id", "");
                }                
            }
        } else {
            // CLOSE
            console.log('reportDate = ' + reportDate);
            var select_report_data = component.get('v.select_report_data');
            var Report_Date__c = component.get('v.data.Report_Date__c');
            var Agency_Hospital__c = component.get('v.hospitalLinkId');
            var Department_Cateogy__c = component.find('select_department').get('v.value');
            var doctor2__c = component.find('select_doctor').get('v.value');
            var Purpose_Type__c = component.find('select_purpose_type').get('v.value');
            var SupportNeeds__c = component.find('SupportNeeds__c').get('v.value');
            var Opportunity__c = component.get('v.data.Opportunity__c');
            var Product_Category1__c = component.find('select_Product1').get('v.value');
            var Product_Category2__c = component.find('select_Product2').get('v.value');
            var Product_Category3__c = component.find('select_Product3').get('v.value');
            var Result__c = component.find('select_result').get('v.value');
      var select_report_data = component.get("v.select_report_data");
      var Report_Date__c = component.get("v.data.Report_Date__c");
      var Agency_Hospital__c = component.get("v.hospitalLinkId");
      var Department_Cateogy__c = component
        .find("select_department")
        .get("v.value");
      var doctor2__c = component.find("select_doctor").get("v.value");
      var Purpose_Type__c = component
        .find("select_purpose_type")
        .get("v.value");
      var SupportNeeds__c = component.find("SupportNeeds__c").get("v.value");
      var Opportunity__c = component.get("v.data.Opportunity__c");
      var Product_Category1__c = component
        .find("select_Product1")
        .get("v.value");
      var Product_Category2__c = component
        .find("select_Product2")
        .get("v.value");
      var Product_Category3__c = component
        .find("select_Product3")
        .get("v.value");
      var Result__c = component.find("select_result").get("v.value");
            
            if (select_report_data !== null) {
                if (typeof select_report_data['Opportunity__c'] === "undefined") {
                    select_report_data['Opportunity__c'] = "";
        if (typeof select_report_data["Opportunity__c"] === "undefined") {
          select_report_data["Opportunity__c"] = "";
                }
                if (typeof select_report_data['Product_Category1__c'] === "undefined") {
                    select_report_data['Product_Category1__c'] = "";
        if (typeof select_report_data["Product_Category1__c"] === "undefined") {
          select_report_data["Product_Category1__c"] = "";
                }
                if (typeof select_report_data['Product_Category2__c'] === "undefined") {
                    select_report_data['Product_Category2__c'] = "";
        if (typeof select_report_data["Product_Category2__c"] === "undefined") {
          select_report_data["Product_Category2__c"] = "";
                }
                if (typeof select_report_data['Product_Category3__c'] === "undefined") {
                    select_report_data['Product_Category3__c'] = "";
        if (typeof select_report_data["Product_Category3__c"] === "undefined") {
          select_report_data["Product_Category3__c"] = "";
                }
                if (typeof select_report_data['Result__c'] === "undefined") {
                    select_report_data['Result__c'] = "";
        if (typeof select_report_data["Result__c"] === "undefined") {
          select_report_data["Result__c"] = "";
                }
            }
            
            if (component.get('v.mode') == 'new') {
                var confirm_title = '警告!'
                var confirm_text = '放弃新建周报?';
      if (component.get("v.mode") == "new") {
        var confirm_title = "警告!";
        var confirm_text = "放弃新建周报?";
                
                if (!Report_Date__c &&
        if (
          !Report_Date__c &&
                    !Agency_Hospital__c &&
                    !Department_Cateogy__c &&
                    !doctor2__c &&
@@ -494,144 +619,166 @@
                    !Product_Category1__c &&
                    !Product_Category2__c &&
                    !Product_Category3__c &&
                    !Result__c)
                {
          !Result__c
        ) {
                    this.allclear(component);
                    $A.util.addClass(modal_window, 'disp_none');
                    $A.util.addClass(modal_bg, 'disp_none');
          $A.util.addClass(modal_window, "disp_none");
          $A.util.addClass(modal_bg, "disp_none");
                } else {
                    this.close_confirm(component, confirm_title, confirm_text);
                }        
            } else if (component.get('v.mode') == 'copy') {
                var confirm_title = '警告!'
                var confirm_text = '放弃新建周报?';
      } else if (component.get("v.mode") == "copy") {
        var confirm_title = "警告!";
        var confirm_text = "放弃新建周报?";
                
                if (select_report_data['Report_Date__c'] == Report_Date__c &&
                    select_report_data['Agency_Hospital__c'] == Agency_Hospital__c &&
                    select_report_data['Department_Cateogy__c'] == Department_Cateogy__c &&
                    select_report_data['doctor2__c'] == doctor2__c &&
                    select_report_data['Purpose_Type__c'] == Purpose_Type__c &&
                    select_report_data['SupportNeeds__c'] == SupportNeeds__c &&//WAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加
                    select_report_data['Opportunity__c'] == Opportunity__c &&
                    select_report_data['Product_Category1__c'] == Product_Category1__c &&
                    select_report_data['Product_Category2__c'] == Product_Category2__c &&
                    select_report_data['Product_Category3__c'] == Product_Category3__c &&
                    select_report_data['Result__c'] == Result__c)
                {
        if (
          select_report_data["Report_Date__c"] == Report_Date__c &&
          select_report_data["Agency_Hospital__c"] == Agency_Hospital__c &&
          select_report_data["Department_Cateogy__c"] ==
            Department_Cateogy__c &&
          select_report_data["doctor2__c"] == doctor2__c &&
          select_report_data["Purpose_Type__c"] == Purpose_Type__c &&
          select_report_data["SupportNeeds__c"] == SupportNeeds__c && //WAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加
          select_report_data["Opportunity__c"] == Opportunity__c &&
          select_report_data["Product_Category1__c"] == Product_Category1__c &&
          select_report_data["Product_Category2__c"] == Product_Category2__c &&
          select_report_data["Product_Category3__c"] == Product_Category3__c &&
          select_report_data["Result__c"] == Result__c
        ) {
                    this.allclear(component);
                    $A.util.addClass(modal_window, 'disp_none');
                    $A.util.addClass(modal_bg, 'disp_none');
          $A.util.addClass(modal_window, "disp_none");
          $A.util.addClass(modal_bg, "disp_none");
                } else {
                    this.close_confirm(component, confirm_title, confirm_text);
                }                
            } else if (component.get('v.mode') == 'edit') {
                var confirm_title = '警告!'
                var confirm_text = '放弃编辑周报?';
      } else if (component.get("v.mode") == "edit") {
        var confirm_title = "警告!";
        var confirm_text = "放弃编辑周报?";
                if (select_report_data['Report_Date__c'] == Report_Date__c &&
                    select_report_data['Agency_Hospital__c'] == Agency_Hospital__c &&
                    select_report_data['Department_Cateogy__c'] == Department_Cateogy__c &&
                    select_report_data['doctor2__c'] == doctor2__c &&
                    select_report_data['Purpose_Type__c'] == Purpose_Type__c &&
                    select_report_data['SupportNeeds__c'] == SupportNeeds__c &&//WAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加
                    select_report_data['Opportunity__c'] == Opportunity__c &&
                    select_report_data['Product_Category1__c'] == Product_Category1__c &&
                    select_report_data['Product_Category2__c'] == Product_Category2__c &&
                    select_report_data['Product_Category3__c'] == Product_Category3__c &&
                    select_report_data['Result__c'] == Result__c)
                {
        if (
          select_report_data["Report_Date__c"] == Report_Date__c &&
          select_report_data["Agency_Hospital__c"] == Agency_Hospital__c &&
          select_report_data["Department_Cateogy__c"] ==
            Department_Cateogy__c &&
          select_report_data["doctor2__c"] == doctor2__c &&
          select_report_data["Purpose_Type__c"] == Purpose_Type__c &&
          select_report_data["SupportNeeds__c"] == SupportNeeds__c && //WAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加
          select_report_data["Opportunity__c"] == Opportunity__c &&
          select_report_data["Product_Category1__c"] == Product_Category1__c &&
          select_report_data["Product_Category2__c"] == Product_Category2__c &&
          select_report_data["Product_Category3__c"] == Product_Category3__c &&
          select_report_data["Result__c"] == Result__c
        ) {
                    this.allclear(component);
                    $A.util.addClass(modal_window, 'disp_none');
                    $A.util.addClass(modal_bg, 'disp_none');
          $A.util.addClass(modal_window, "disp_none");
          $A.util.addClass(modal_bg, "disp_none");
                } else {
                    this.close_confirm(component, confirm_title, confirm_text);
                }
            }
        }
    },
    
    close_confirm : function(component, title, text) {
        var confirm_status = component.get('v.confirm_status');
        component.set('v.modal_confirm_title', title);
        component.set('v.modal_confirm_text', text);
        var modal_window = component.find('modal_window');
        var modal_bg = component.find('modal_bg');
        var modal_confirm = component.find('modal_confirm');
        var modal_confirm_bg = component.find('modal_confirm_bg');
    var confirm_status = component.get("v.confirm_status");
    component.set("v.modal_confirm_title", title);
    component.set("v.modal_confirm_text", text);
    var modal_window = component.find("modal_window");
    var modal_bg = component.find("modal_bg");
    var modal_confirm = component.find("modal_confirm");
    var modal_confirm_bg = component.find("modal_confirm_bg");
        if (confirm_status == 0) {
            $A.util.addClass(modal_window, 'disp_none');
            $A.util.addClass(modal_bg, 'disp_none');
            $A.util.removeClass(modal_confirm, 'disp_none');
            $A.util.removeClass(modal_confirm_bg, 'disp_none');
      $A.util.addClass(modal_window, "disp_none");
      $A.util.addClass(modal_bg, "disp_none");
      $A.util.removeClass(modal_confirm, "disp_none");
      $A.util.removeClass(modal_confirm_bg, "disp_none");
        } else if (confirm_status == 1) {
            // 是
            $A.util.addClass(modal_confirm, 'disp_none');
            $A.util.addClass(modal_confirm_bg, 'disp_none');
            component.set('v.mode', '');
      $A.util.addClass(modal_confirm, "disp_none");
      $A.util.addClass(modal_confirm_bg, "disp_none");
      component.set("v.mode", "");
            this.allclear(component);
            component.set('v.reports_now', "");
            component.set('v.reports_now_count', 0);
            component.set('v.confirm_status', 0);
      component.set("v.reports_now", "");
      component.set("v.reports_now_count", 0);
      component.set("v.confirm_status", 0);
        } else if (confirm_status == 2) {
            // 否
            $A.util.removeClass(modal_window, 'disp_none');
            $A.util.removeClass(modal_bg, 'disp_none');
            $A.util.addClass(modal_confirm, 'disp_none');
            $A.util.addClass(modal_confirm_bg, 'disp_none');
            component.set('v.confirm_status', 0);
      $A.util.removeClass(modal_window, "disp_none");
      $A.util.removeClass(modal_bg, "disp_none");
      $A.util.addClass(modal_confirm, "disp_none");
      $A.util.addClass(modal_confirm_bg, "disp_none");
      component.set("v.confirm_status", 0);
        }
    },
    new_report : function(component, event, helper) {
        component.set('v.mode', 'new');
        component.set('v.dialog_type', '新建');
        var select_date = component.find('select_date').get('v.value');
        var select_agency = component.find('select_agency_person').get('v.value');
        component.set('v.selected_date', select_date);
        var name = component.get('v.selected_agency_person');
        var ret = this.create_report_header(component, name, select_agency, select_date);
    component.set("v.mode", "new");
    component.set("v.dialog_type", "新建");
    var select_date = component.find("select_date").get("v.value");
    var select_agency = component.find("select_agency_person").get("v.value");
    component.set("v.selected_date", select_date);
    var name = component.get("v.selected_agency_person");
    var ret = this.create_report_header(
      component,
      name,
      select_agency,
      select_date
    );
        // PIPL update Yin Mingjie 21/02/2022 start
        this.set_aws_url(component,'Agency_Contact__c')
    this.set_aws_url(component, "Agency_Contact__c");
        // PIPL update Yin Mingjie 21/02/2022 end
    },
    
    copy_button : function(component, event, helper) {
        this.allclear(component);
        component.set('v.mode', 'copy');
        component.set('v.dialog_type', '新建');
        var select_report_data = component.get('v.select_report_data_radio');
        component.set('v.loadOpp', true);
    component.set("v.mode", "copy");
    component.set("v.dialog_type", "新建");
    var select_report_data = component.get("v.select_report_data_radio");
    component.set("v.loadOpp", true);
        // 週
        var now = new Date();
        var start_day = new Date(now.getFullYear(), now.getMonth(), (now.getDate() - now.getDay() + 1));
        var select_date = start_day.getFullYear() + '/' + (start_day.getMonth() + 1) + '/' + start_day.getDate();
        this.set_selected(component, 'select_date', select_date);
        component.set('v.selected_date', select_date);
    var start_day = new Date(
      now.getFullYear(),
      now.getMonth(),
      now.getDate() - now.getDay() + 1
    );
    var select_date =
      start_day.getFullYear() +
      "/" +
      (start_day.getMonth() + 1) +
      "/" +
      start_day.getDate();
    this.set_selected(component, "select_date", select_date);
    component.set("v.selected_date", select_date);
        
        // 担当
        var select_agency = select_report_data['Person_In_Charge2__c'];
    var select_agency = select_report_data["Person_In_Charge2__c"];
        var new_label = this.get_agency_person_name(component, select_agency);
        component.set('v.selected_agency_person', new_label);
        this.set_selected(component, 'select_agency_person', select_agency);
    component.set("v.selected_agency_person", new_label);
    this.set_selected(component, "select_agency_person", select_agency);
        
        this.new_button_disabled(component, event, helper);
        var name = component.get('v.selected_agency_person');
    var name = component.get("v.selected_agency_person");
        
        component.set('v.edit_copy_select_report_id', select_report_data['Id']);
        component.set('v.select_report_data', select_report_data);
    component.set("v.edit_copy_select_report_id", select_report_data["Id"]);
    component.set("v.select_report_data", select_report_data);
        var ret = this.create_report_header(component, name, select_agency, select_date);
    var ret = this.create_report_header(
      component,
      name,
      select_agency,
      select_date
    );
    },
    
    change_report_radio : function(component, event, helper) {
        var reports = component.get('v.reports');
    var reports = component.get("v.reports");
        for (var i = 0; i < reports.length; i++) {
            if (reports[i].Name == event.getSource().get('v.label')) {
                component.set('v.select_report_data_radio', reports[i]);
                component.find('copy_button').set('v.disabled', false);
      if (reports[i].Name == event.getSource().get("v.label")) {
        component.set("v.select_report_data_radio", reports[i]);
        component.find("copy_button").set("v.disabled", false);
                break;
            }
        }
@@ -639,36 +786,44 @@
    
    edit_button : function(component, event, helper) {
        this.allclear(component);
        component.set('v.loadOpp', true);
        var index = event.getSource().get('v.value');
        component.set('v.select_report_data', component.get('v.reports')[index]);
        component.set('v.mode', 'edit');
        component.set('v.dialog_type', '编辑');
    component.set("v.loadOpp", true);
    var index = event.getSource().get("v.value");
    component.set("v.select_report_data", component.get("v.reports")[index]);
    component.set("v.mode", "edit");
    component.set("v.dialog_type", "编辑");
        var select_date = component.get('v.reports')[index].Submit_date__c;
        var select_agency = component.get('v.reports')[index].Person_In_Charge2__c;
        var text_tmp = select_date.split('-');
        var select_date_text = text_tmp[0] + '/' + Number(text_tmp[1]) + '/' + Number(text_tmp[2]);
        component.set('v.selected_date', select_date_text);
        var name = component.get('v.reports')[index].Person_In_Charge2__r.Name;
    var select_date = component.get("v.reports")[index].Submit_date__c;
    var select_agency = component.get("v.reports")[index].Person_In_Charge2__c;
    var text_tmp = select_date.split("-");
    var select_date_text =
      text_tmp[0] + "/" + Number(text_tmp[1]) + "/" + Number(text_tmp[2]);
    component.set("v.selected_date", select_date_text);
    var name = component.get("v.reports")[index].Person_In_Charge2__r.Name;
        
        this.set_selected(component, 'select_agency_person', select_agency);
    this.set_selected(component, "select_agency_person", select_agency);
        this.new_button_disabled(component, event, helper);
        
        var new_label = this.get_agency_person_name(component, select_agency);
        component.set('v.selected_agency_person', new_label);
    component.set("v.selected_agency_person", new_label);
        component.set('v.edit_copy_select_report_id', component.get('v.reports')[index].Id);
    component.set(
      "v.edit_copy_select_report_id",
      component.get("v.reports")[index].Id
    );
        
        var ret = this.create_report_header(component, name, select_agency, select_date);
    var ret = this.create_report_header(
      component,
      name,
      select_agency,
      select_date
    );
    },
    
    save_report : function(component, event, helper) {
        // 20220222 PI改造  by Bright--start
        let doctor2Name = '';
        let visitortitle = '';
        for(let op of component.find('select_doctor').get('v.options')){
    let doctor2Name = "";
    let visitortitle = "";
    for (let op of component.find("select_doctor").get("v.options")) {
            if (op.selected) {
                doctor2Name = op.label;
                visitortitle = op.Doctor_Division1__c;
@@ -676,165 +831,227 @@
        }
        // 20220222 PI改造  by Bright--end
    component.find("save_button").set("v.disabled", true);
        component.find('save_button').set('v.disabled', true);
        var Report_Date__c = component.get('v.data.Report_Date__c');
    var Report_Date__c = component.get("v.data.Report_Date__c");
            // alert('Report_Date__c'+Report_Date__c);
        var Person_In_Charge2__c = "";
        var Submit_date__c = "";
        if (component.get('v.mode') == 'edit') {
    if (component.get("v.mode") == "edit") {
            // 周 Submit_date__c
            Submit_date__c = component.get('v.select_report_data').Submit_date__c;
      Submit_date__c = component.get("v.select_report_data").Submit_date__c;
            // alert('Submit_date__c'+Submit_date__c);
            // 担当 Person_In_Charge2__c
            Person_In_Charge2__c = component.get('v.select_report_data').Person_In_Charge2__c;
      Person_In_Charge2__c = component.get(
        "v.select_report_data"
      ).Person_In_Charge2__c;
        } else {
            // 周 Submit_date__c
            Submit_date__c = this.get_date_string(component.find('select_date').get('v.value'));
      Submit_date__c = this.get_date_string(
        component.find("select_date").get("v.value")
      );
            // alert('Submit_date__c'+Submit_date__c);
            // 担当 Person_In_Charge2__c
            Person_In_Charge2__c = component.find('select_agency_person').get('v.value');
      Person_In_Charge2__c = component
        .find("select_agency_person")
        .get("v.value");
        }
        // Agency_Report_Header__c
        var Agency_Report_Header__c = component.get('v.agency_report_header_id');
    var Agency_Report_Header__c = component.get("v.agency_report_header_id");
        
        // 医院 Agency_Hospital__c (Agency_Hospital_Link__c)
        var Agency_Hospital__c = component.get('v.hospitalLinkId');
    var Agency_Hospital__c = component.get("v.hospitalLinkId");
        
        // 科室 Department_Cateogy__c
        var Department_Cateogy__c = component.find('select_department').get('v.value');
    var Department_Cateogy__c = component
      .find("select_department")
      .get("v.value");
        
        // 拜访人 doctor2__c
        var doctor2__c = component.find('select_doctor').get('v.value');
    var doctor2__c = component.find("select_doctor").get("v.value");
        
        // 活动区分 Purpose_Type__c
        var Purpose_Type__c = component.find('select_purpose_type').get('v.value');
    var Purpose_Type__c = component.find("select_purpose_type").get("v.value");
          //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start
        // 支援需求 SupportNeeds__c
        var SupportNeeds__c = component.find('SupportNeeds__c').get('v.value');
    var SupportNeeds__c = component.find("SupportNeeds__c").get("v.value");
        //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 end
        // 询价 Opportunity__c
        var Opportunity__c = component.get('v.data.Opportunity__c');
    var Opportunity__c = component.get("v.data.Opportunity__c");
        var StageName__c = component.find('select_stageName').get('v.value');
        var Amount__c = component.get('v.oppdata.Amount__c') != null ? component.get('v.oppdata.Amount__c').toString() : '';
        var OCMSale_Price__c = component.get('v.oppdata.OCMSale_Price__c') != null ? component.get('v.oppdata.OCMSale_Price__c').toString() : '';
        var Close_Forecasted_Date__c = component.get('v.oppdata.Close_Forecasted_Date__c');
    var StageName__c = component.find("select_stageName").get("v.value");
    var Amount__c =
      component.get("v.oppdata.Amount__c") != null
        ? component.get("v.oppdata.Amount__c").toString()
        : "";
    var OCMSale_Price__c =
      component.get("v.oppdata.OCMSale_Price__c") != null
        ? component.get("v.oppdata.OCMSale_Price__c").toString()
        : "";
    var Close_Forecasted_Date__c = component.get(
      "v.oppdata.Close_Forecasted_Date__c"
    );
        var StageName__c_o = component.get('v.StageName__c_o');
        var Amount__c_o = component.get('v.Amount__c_o');
        var OCMSale_Price__c_o = component.get('v.OCMSale_Price__c_o');
        var Close_Forecasted_Date__c_o = component.get('v.Close_Forecasted_Date__c_o');
        if (StageName__c_o == undefined) StageName__c_o = '';
        if (Amount__c_o == undefined) Amount__c_o = '';
        if (OCMSale_Price__c_o == undefined) OCMSale_Price__c_o = '';
        if (Close_Forecasted_Date__c_o == undefined) Close_Forecasted_Date__c_o = '';
        if (StageName__c == StageName__c_o && OCMSale_Price__c_o == OCMSale_Price__c && Amount__c == Amount__c_o && Close_Forecasted_Date__c == Close_Forecasted_Date__c_o) {
            StageName__c = '';
            Amount__c = '';
            OCMSale_Price__c = '';
            Close_Forecasted_Date__c = '';
    var StageName__c_o = component.get("v.StageName__c_o");
    var Amount__c_o = component.get("v.Amount__c_o");
    var OCMSale_Price__c_o = component.get("v.OCMSale_Price__c_o");
    var Close_Forecasted_Date__c_o = component.get(
      "v.Close_Forecasted_Date__c_o"
    );
    if (StageName__c_o == undefined) StageName__c_o = "";
    if (Amount__c_o == undefined) Amount__c_o = "";
    if (OCMSale_Price__c_o == undefined) OCMSale_Price__c_o = "";
    if (Close_Forecasted_Date__c_o == undefined)
      Close_Forecasted_Date__c_o = "";
    if (
      StageName__c == StageName__c_o &&
      OCMSale_Price__c_o == OCMSale_Price__c &&
      Amount__c == Amount__c_o &&
      Close_Forecasted_Date__c == Close_Forecasted_Date__c_o
    ) {
      StageName__c = "";
      Amount__c = "";
      OCMSale_Price__c = "";
      Close_Forecasted_Date__c = "";
        }
        // 产品区分 Product_Category__c (ProductTypes__c)
        var Product_Category1__c = component.find('select_Product1').get('v.value');
        var Product_Category2__c = component.find('select_Product2').get('v.value');
        var Product_Category3__c = component.find('select_Product3').get('v.value');
    var Product_Category1__c = component.find("select_Product1").get("v.value");
    var Product_Category2__c = component.find("select_Product2").get("v.value");
    var Product_Category3__c = component.find("select_Product3").get("v.value");
        
        // 結果 Result__c
        var Result__c = component.find('select_result').get('v.value');
    var Result__c = component.find("select_result").get("v.value");
        
        // バリデーション
        var error = [];
        if (!Report_Date__c) { error.push("活动日 不存在"); }
        if (!Submit_date__c) { error.push("周 不存在"); }
    if (!Report_Date__c) {
      error.push("活动日 不存在");
    }
    if (!Submit_date__c) {
      error.push("周 不存在");
    }
        var rDate = new Date(Report_Date__c);
        var sDate = new Date(Submit_date__c);
        sDate.setDate(sDate.getDate() - 1);
        if (rDate < sDate) {error.push('活动日必须是本周!'); }
    if (rDate < sDate) {
      error.push("活动日必须是本周!");
    }
        sDate.setDate(sDate.getDate() + 7);
        if (rDate >= sDate) {error.push('活动日必须是本周!'); }
    if (rDate >= sDate) {
      error.push("活动日必须是本周!");
    }
        
        if (!Person_In_Charge2__c) { error.push("担当 不存在"); }
        if (!Agency_Report_Header__c) { this.error("Report Header Id 不存在"); }
        if (!Agency_Hospital__c) { error.push("医院 不存在"); }
        if (!Department_Cateogy__c) { error.push("科室 不存在"); }
        if (!doctor2__c) { error.push("拜访人 不存在"); }
        if (!Purpose_Type__c) { error.push("活动区分 不存在"); }
    if (!Person_In_Charge2__c) {
      error.push("担当 不存在");
    }
    if (!Agency_Report_Header__c) {
      this.error("Report Header Id 不存在");
    }
    if (!Agency_Hospital__c) {
      error.push("医院 不存在");
    }
    if (!Department_Cateogy__c) {
      error.push("科室 不存在");
    }
    if (!doctor2__c) {
      error.push("拜访人 不存在");
    }
    if (!Purpose_Type__c) {
      error.push("活动区分 不存在");
    }
        // if (!SupportNeeds__c) { error.push("支援需求 不存在"); }
        if (!Opportunity__c) { Opportunity__c = ""; }
        if (!Product_Category1__c) { error.push("产品区分1 不存在"); }
        if (Purpose_Type__c && (Purpose_Type__c.substr(-3) == 'SIS' || Purpose_Type__c.substr(-3) == 'OPD')) {
            if (!Result__c) { error.push("结果 不存在"); }
    if (!Opportunity__c) {
      Opportunity__c = "";
    }
    if (!Product_Category1__c) {
      error.push("产品区分1 不存在");
    }
    if (
      Purpose_Type__c &&
      (Purpose_Type__c.substr(-3) == "SIS" ||
        Purpose_Type__c.substr(-3) == "OPD")
    ) {
      if (!Result__c) {
        error.push("结果 不存在");
      }
        }
        for (var i = 0; i < error.length; i++) {
            this.warning(error[i]);
        }
        if (error.length > 0) {
            component.find('save_button').set('v.disabled', false);
      component.find("save_button").set("v.disabled", false);
            return false;
        }
        // 保存処理
        component.set('v.login',true);
        if (component.get('v.mode') == 'edit') {
            var Agency_Report__c = component.get('v.select_report_data').Id;
            var action = component.get('c.editAgencyReport');
            debugger
    component.set("v.login", true);
    if (component.get("v.mode") == "edit") {
      var Agency_Report__c = component.get("v.select_report_data").Id;
      var action = component.get("c.editAgencyReport");
      debugger;
            // alert("Purpose_Type:"+Purpose_Type__c+","+"SupportNeedsc:"+SupportNeeds__c);
            action.setParams({
                "Agency_Report_Id" : Agency_Report__c,
                "Department_Cateogy" : Department_Cateogy__c,
                "Purpose_Type" : Purpose_Type__c,
        Agency_Report_Id: Agency_Report__c,
        Department_Cateogy: Department_Cateogy__c,
        Purpose_Type: Purpose_Type__c,
                 //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start
                 "SupportNeedsc" : SupportNeeds__c,
        SupportNeedsc: SupportNeeds__c,
                 //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 end
                "Agency_Report_Header" : Agency_Report_Header__c,
                "Agency_Hospital" : Agency_Hospital__c,
                "Person_In_Charge2" : Person_In_Charge2__c,
                "doctor" : doctor2__c,
                "Submit_date" : Submit_date__c,
                "Product_Category1" : Product_Category1__c,
                "Product_Category2" : Product_Category2__c,
                "Product_Category3" : Product_Category3__c,
                "Result" : Result__c,
                "Opportunity" : Opportunity__c,
                "StageName" : StageName__c,
                "oppAmount" : Amount__c,
                "oppOCMPrice" : OCMSale_Price__c,
                "Close_Forecasted_Date" : Close_Forecasted_Date__c,
                "Report_Date" : Report_Date__c,
        Agency_Report_Header: Agency_Report_Header__c,
        Agency_Hospital: Agency_Hospital__c,
        Person_In_Charge2: Person_In_Charge2__c,
        doctor: doctor2__c,
        Submit_date: Submit_date__c,
        Product_Category1: Product_Category1__c,
        Product_Category2: Product_Category2__c,
        Product_Category3: Product_Category3__c,
        Result: Result__c,
        Opportunity: Opportunity__c,
        StageName: StageName__c,
        oppAmount: Amount__c,
        oppOCMPrice: OCMSale_Price__c,
        Close_Forecasted_Date: Close_Forecasted_Date__c,
        Report_Date: Report_Date__c
            });
            
            action.setCallback(this,function(response){
                var state = response.getState();
                if(state == 'SUCCESS'){
                    this.success('编辑保存成功');
        if (state == "SUCCESS") {
          this.success("编辑保存成功");
                    var report_id = response.getReturnValue();
                    component.set('v.create_agency_report_id', report_id);
          component.set("v.create_agency_report_id", report_id);
                    
                    var select_agency_list = component.get('v.allselectlist').AgencyPerson__c;
          var select_agency_list =
            component.get("v.allselectlist").AgencyPerson__c;
                    for (var i = 0; i < select_agency_list.length; i++) {
                        if (select_agency_list[i].value == component.get('v.select_report_data').Person_In_Charge2__c) {
            if (
              select_agency_list[i].value ==
              component.get("v.select_report_data").Person_In_Charge2__c
            ) {
                            select_agency_list[i].selected = true;
                        } else {
                            select_agency_list[i].selected = false;
                        }
                    }
                    component.find('select_agency_person').set('v.options', select_agency_list);
          component
            .find("select_agency_person")
            .set("v.options", select_agency_list);
                    
                    component.set('v.update_select_report_data_id', report_id);
                    this.get_reports(component, event, helper, component.get('v.select_report_data').Submit_date__c, component.get('v.select_report_data').Person_In_Charge2__c);
          component.set("v.update_select_report_data_id", report_id);
          this.get_reports(
            component,
            event,
            helper,
            component.get("v.select_report_data").Submit_date__c,
            component.get("v.select_report_data").Person_In_Charge2__c
          );
                    component.find('save_button').set('v.disabled', false);
                    component.set('v.login',false);
                }
                else{
          component.find("save_button").set("v.disabled", false);
          component.set("v.login", false);
        } else {
                    // var error = response.getError();
                    // alert(JSON.stringify(error));
                    // alert(JSON.stringify(error[0].fieldErrors));
@@ -844,60 +1061,66 @@
                    // else () {
                    //     error[0].fieldErrors[0]
                    // }
                    this.error('save_report failed.');
                    component.find('save_button').set('v.disabled', false);
                    component.set('v.login',false);
          this.error("save_report failed.");
          component.find("save_button").set("v.disabled", false);
          component.set("v.login", false);
                }
            });
            $A.enqueueAction(action);
        } else {
            /* Save (New & Copy) */
            
            var action = component.get('c.saveAgencyReport');
      var action = component.get("c.saveAgencyReport");
            debugger;
            // alert(SupportNeeds__c);
            action.setParams({
                "Department_Cateogy" : Department_Cateogy__c,
                "Purpose_Type" : Purpose_Type__c,
        Department_Cateogy: Department_Cateogy__c,
        Purpose_Type: Purpose_Type__c,
                //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start
                "SupportNeedsc" : SupportNeeds__c,
        SupportNeedsc: SupportNeeds__c,
                //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 end
                "Agency_Report_Header" : Agency_Report_Header__c,
                "Agency_Hospital" : Agency_Hospital__c,
                "Person_In_Charge2" : Person_In_Charge2__c,
                "doctor" : doctor2__c,
                "Submit_date" : Submit_date__c,
                "Product_Category1" : Product_Category1__c,
                "Product_Category2" : Product_Category2__c,
                "Product_Category3" : Product_Category3__c,
                "Result" : Result__c,
                "Opportunity" : Opportunity__c,
                "StageName" : StageName__c,
                "oppAmount" : Amount__c,
                "oppOCMPrice" : OCMSale_Price__c,
                "Close_Forecasted_Date" : Close_Forecasted_Date__c,
                "Report_Date" : Report_Date__c,
        Agency_Report_Header: Agency_Report_Header__c,
        Agency_Hospital: Agency_Hospital__c,
        Person_In_Charge2: Person_In_Charge2__c,
        doctor: doctor2__c,
        Submit_date: Submit_date__c,
        Product_Category1: Product_Category1__c,
        Product_Category2: Product_Category2__c,
        Product_Category3: Product_Category3__c,
        Result: Result__c,
        Opportunity: Opportunity__c,
        StageName: StageName__c,
        oppAmount: Amount__c,
        oppOCMPrice: OCMSale_Price__c,
        Close_Forecasted_Date: Close_Forecasted_Date__c,
        Report_Date: Report_Date__c
            });
            action.setCallback(this,function(response){
                var state = response.getState();
                if(state == 'SUCCESS'){
                    this.success('保存成功');
        if (state == "SUCCESS") {
          this.success("保存成功");
                    var report_id = response.getReturnValue();
                    component.set('v.create_agency_report_id', report_id);
          component.set("v.create_agency_report_id", report_id);
                    
                    this.get_reports(component, event, helper, component.find('select_date').get('v.value'), component.find('select_agency_person').get('v.value'));
          this.get_reports(
            component,
            event,
            helper,
            component.find("select_date").get("v.value"),
            component.find("select_agency_person").get("v.value")
          );
                    // モーダルウィンドウ内の一覧用
                    var action2 = component.get('c.getReportsById');
          var action2 = component.get("c.getReportsById");
                    action2.setParams({
                        "report_id" : report_id,
            report_id: report_id
                    });
                    action2.setCallback(this,function(response){
                        var state = response.getState();
                        if(state == 'SUCCESS'){
            if (state == "SUCCESS") {
                            var res = response.getReturnValue();
                            var reports_now = component.get('v.reports_now');
              var reports_now = component.get("v.reports_now");
                            var reports_now_count = 0;
                            if (reports_now.length > 0 && reports_now != "") {
                                reports_now_count = reports_now.length;
@@ -917,29 +1140,27 @@
                                    return 0;
                                });
                                
                                component.set('v.reports_now', reports_now);
                                component.set('v.reports_now_count', reports_now.length);
                                var data_list = component.find('modal_data_list_tr');
                component.set("v.reports_now", reports_now);
                component.set("v.reports_now_count", reports_now.length);
                var data_list = component.find("modal_data_list_tr");
                            }
                        }
                        else{
                            this.error('get_reports_now failed.');
                            component.find('save_button').set('v.disabled', false);
                            component.set('v.login',false);
            } else {
              this.error("get_reports_now failed.");
              component.find("save_button").set("v.disabled", false);
              component.set("v.login", false);
                        }
                    });
                    $A.enqueueAction(action2);
                    
                    this.allclear(component);
                    component.find('save_button').set('v.disabled', false);
                    component.set('v.login',false);
                }
                else{
          component.find("save_button").set("v.disabled", false);
          component.set("v.login", false);
        } else {
                    var error = response.getError();
                    // alert(JSON.stringify(error));
                    this.error('saveAgencyReport failed.');
                    component.find('save_button').set('v.disabled', false);
                    component.set('v.login',false);
          this.error("saveAgencyReport failed.");
          component.find("save_button").set("v.disabled", false);
          component.set("v.login", false);
                }
            });
            $A.enqueueAction(action);
@@ -947,39 +1168,56 @@
    },
    
    allclear : function(component) {
        var clear = [{label:'', value:'', selected:true}];
        component.set('v.hospital', '');
        component.set('v.hospitalId', '');
        component.set('v.hospitalLinkId', '');
        component.find('new_con').set('v.disabled', true);
        component.find('select_doctor').set('v.options', clear);
        component.set('v.doctor_title', '');
        component.find('select_department').set('v.options', this.conv_selected(component.get('v.allselectlist.Department_Cateogy__c')));
        component.find('select_purpose_type').set('v.options', this.conv_selected(component.get('v.allselectlist.Purpose_Type__c')));
    var clear = [{ label: "", value: "", selected: true }];
    component.set("v.hospital", "");
    component.set("v.hospitalId", "");
    component.set("v.hospitalLinkId", "");
    component.find("new_con").set("v.disabled", true);
    component.find("select_doctor").set("v.options", clear);
    component.set("v.doctor_title", "");
    component
      .find("select_department")
      .set(
        "v.options",
        this.conv_selected(
          component.get("v.allselectlist.Department_Cateogy__c")
        )
      );
    component
      .find("select_purpose_type")
      .set(
        "v.options",
        this.conv_selected(component.get("v.allselectlist.Purpose_Type__c"))
      );
        //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start
        component.find('SupportNeeds__c').set('v.options', this.conv_selected(component.get('v.allselectlist.SupportNeeds__c')));
    component
      .find("SupportNeeds__c")
      .set(
        "v.options",
        this.conv_selected(component.get("v.allselectlist.SupportNeeds__c"))
      );
        //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 end
        // ToDo需要测试手机上能运行不
        component.set('v.data.Opportunity__c', '');
        component.find('select_Product1').set('v.value','');
        component.find('select_Product2').set('v.value','');
        component.find('select_Product3').set('v.value','');
        console.log('reportDate = 空');
        component.set('v.data.Report_Date__c', '');
        component.set('v.oppdata.Close_Forecasted_Date__c', '');
        component.set('v.oppdata.Amount__c', '');
        component.set('v.oppdata.OCMSale_Price__c', '');
        component.set('v.oppdata.StageName__c', '');
    component.set("v.data.Opportunity__c", "");
    component.find("select_Product1").set("v.value", "");
    component.find("select_Product2").set("v.value", "");
    component.find("select_Product3").set("v.value", "");
    console.log("reportDate = 空");
    component.set("v.data.Report_Date__c", "");
    component.set("v.oppdata.Close_Forecasted_Date__c", "");
    component.set("v.oppdata.Amount__c", "");
    component.set("v.oppdata.OCMSale_Price__c", "");
    component.set("v.oppdata.StageName__c", "");
        // component.set('v.oppdata', '');
        component.set('v.Close_Forecasted_Date__c_o', '');
        component.set('v.Amount__c_o', '');
        component.set('v.OCMSale_Price__c_o', '');
        component.set('v.StageName__c_o', '');
        $A.util.addClass(component.find('input-opportunity-stage'), 'disp_none');
        $A.util.addClass(component.find('input-opportunity-amount1'), 'disp_none');
        $A.util.addClass(component.find('input-opportunity-amount2'), 'disp_none');
        $A.util.addClass(component.find('input-opportunity-date'), 'disp_none');
        $A.util.removeClass(component.find('input-opportunity-blank'), 'disp_none');
    component.set("v.Close_Forecasted_Date__c_o", "");
    component.set("v.Amount__c_o", "");
    component.set("v.OCMSale_Price__c_o", "");
    component.set("v.StageName__c_o", "");
    $A.util.addClass(component.find("input-opportunity-stage"), "disp_none");
    $A.util.addClass(component.find("input-opportunity-amount1"), "disp_none");
    $A.util.addClass(component.find("input-opportunity-amount2"), "disp_none");
    $A.util.addClass(component.find("input-opportunity-date"), "disp_none");
    $A.util.removeClass(component.find("input-opportunity-blank"), "disp_none");
        // if ($A.get("$Browser.formFactor") == 'DESKTOP') {
            // var values = [];
            // component.find('input-opportunity').get("v.body")[0].set('v.values', values);
@@ -993,7 +1231,7 @@
        //     component.find('input-product-category2').get("v.body")[0].set('v.values', values);
        // if (component.find('input-product-category3'))
        //     component.find('input-product-category3').get("v.body")[0].set('v.values', values);
        component.find('select_result').set('v.value', '');
    component.find("select_result").set("v.value", "");
        this.select_purpose_type(component);
    },
    
@@ -1001,78 +1239,135 @@
        var ret_obj = [];
        var now = new Date();
        for (var i = 0; i < count; i++) {
      var start_day = new Date(
        now.getFullYear(),
        now.getMonth(),
        now.getDate() - now.getDay() + 1 - i * 7
      );
      var end_day = new Date(
        now.getFullYear(),
        now.getMonth(),
        now.getDate() + (7 - now.getDay()) - i * 7
      );
            var start_day = new Date(now.getFullYear(), now.getMonth(), (now.getDate() - now.getDay() + 1 - (i * 7)));
            var end_day = new Date(now.getFullYear(), now.getMonth(), now.getDate() + (7 - now.getDay()) - (i * 7));
            var start_day_show = new Date(now.getFullYear(), now.getMonth(), (now.getDate() - now.getDay() - (i * 7)));
            var end_day_show = new Date(now.getFullYear(), now.getMonth(), now.getDate() + (6 - now.getDay()) - (i * 7));
            var date_text = start_day.getFullYear() + '/' + (start_day.getMonth() + 1) + '/' + start_day.getDate() + '~' + end_day.getFullYear() + '/' + (end_day.getMonth() + 1) + '/' + end_day.getDate();
      var start_day_show = new Date(
        now.getFullYear(),
        now.getMonth(),
        now.getDate() - now.getDay() - i * 7
      );
      var end_day_show = new Date(
        now.getFullYear(),
        now.getMonth(),
        now.getDate() + (6 - now.getDay()) - i * 7
      );
      var date_text =
        start_day.getFullYear() +
        "/" +
        (start_day.getMonth() + 1) +
        "/" +
        start_day.getDate() +
        "~" +
        end_day.getFullYear() +
        "/" +
        (end_day.getMonth() + 1) +
        "/" +
        end_day.getDate();
            if (i == 0) {
                ret_obj.push({
                    selected : true,
                    value : start_day.getFullYear() + '/' + (start_day.getMonth() + 1) + '/' + start_day.getDate(),
                    label : start_day_show.getFullYear() + '/' + (start_day_show.getMonth() + 1) + '/' + start_day_show.getDate() + '~' + end_day_show.getFullYear() + '/' + (end_day_show.getMonth() + 1) + '/' + end_day_show.getDate(),
          value:
            start_day.getFullYear() +
            "/" +
            (start_day.getMonth() + 1) +
            "/" +
            start_day.getDate(),
          label:
            start_day_show.getFullYear() +
            "/" +
            (start_day_show.getMonth() + 1) +
            "/" +
            start_day_show.getDate() +
            "~" +
            end_day_show.getFullYear() +
            "/" +
            (end_day_show.getMonth() + 1) +
            "/" +
            end_day_show.getDate()
                });
            } else {
                ret_obj.push({
                    selected : false,
                    value : start_day.getFullYear() + '/' + (start_day.getMonth() + 1) + '/' + start_day.getDate(),
                    label : start_day_show.getFullYear() + '/' + (start_day_show.getMonth() + 1) + '/' + start_day_show.getDate() + '~' + end_day_show.getFullYear() + '/' + (end_day_show.getMonth() + 1) + '/' + end_day_show.getDate(),
          value:
            start_day.getFullYear() +
            "/" +
            (start_day.getMonth() + 1) +
            "/" +
            start_day.getDate(),
          label:
            start_day_show.getFullYear() +
            "/" +
            (start_day_show.getMonth() + 1) +
            "/" +
            start_day_show.getDate() +
            "~" +
            end_day_show.getFullYear() +
            "/" +
            (end_day_show.getMonth() + 1) +
            "/" +
            end_day_show.getDate()
                });
            }
        }
        component.find('select_date').set('v.options', ret_obj);
        component.set('v.report_date_list', ret_obj);
    component.find("select_date").set("v.options", ret_obj);
    component.set("v.report_date_list", ret_obj);
    },
    
    create_report_header : function(component, name, s_agency, s_date) {
        s_date = this.get_date_string(s_date);
        if (s_date == false) {
            this.error('get_date_string failed.');
      this.error("get_date_string failed.");
            return false;
        }
        var head_key = this.create_header_input_key(s_agency, s_date);
        component.set('v.agency_report_header', head_key);
    component.set("v.agency_report_header", head_key);
        if (head_key == false) {
            this.error('create_header_input_key failed.');
      this.error("create_header_input_key failed.");
            return false;
        }
        
        var key2 = s_date.replace(/-/g, '');
        var action = component.get('c.createReportHeader');
    var key2 = s_date.replace(/-/g, "");
    var action = component.get("c.createReportHeader");
        action.setParams({
            "name" : name,
            "s_date" : s_date,
            "s_agency" : s_agency,
            "head_key" : head_key,
      name: name,
      s_date: s_date,
      s_agency: s_agency,
      head_key: head_key
        });
        
        component.set('v.login',true);
    component.set("v.login", true);
        action.setCallback(this,function(response){
            var state = response.getState();
            if(state == 'SUCCESS'){
      if (state == "SUCCESS") {
                var res = response.getReturnValue();
                component.set('v.agency_report_header_id', res);
                component.set('v.login',false);
        component.set("v.agency_report_header_id", res);
        component.set("v.login", false);
                this.toggle_report(component);
            }
            else{
                this.error('createReportHeader callback failed.');
                component.set('v.login',false);
      } else {
        this.error("createReportHeader callback failed.");
        component.set("v.login", false);
            }
        });
        $A.enqueueAction(action);
    },
    create_header_input_key : function(agency_id, s_date) {
        if (typeof(s_date) != 'string') {
    if (typeof s_date != "string") {
            s_date = this.get_date_string(s_date);
            if (s_date == false) {
                this.error('get_date_string in create_header_input_key.')
        this.error("get_date_string in create_header_input_key.");
                return false;
            }
        }
@@ -1080,7 +1375,7 @@
            return false;
        }
        s_date = s_date.replace(/-/g, '');
    s_date = s_date.replace(/-/g, "");
        var headkey = agency_id + ":" + s_date;
        return headkey;
@@ -1096,36 +1391,36 @@
    // create yyyy-mm-dd string
    get_date_string : function(val) {
        if (typeof(val) == 'string') {
    if (typeof val == "string") {
            if (val.match(/^\d{4}\/\d{1,2}\/\d{1,2}$/)) {
                val = val.replace(/[\/]/g, '-');
                var tmp = val.split('-');
        val = val.replace(/[\/]/g, "-");
        var tmp = val.split("-");
                if (tmp[1].length == 1) {
                    tmp[1] = '0' + tmp[1];
          tmp[1] = "0" + tmp[1];
                }
                if (tmp[2].length == 1) {
                    tmp[2] = '0' + tmp[2];
          tmp[2] = "0" + tmp[2];
                }
                val = tmp[0] + '-' + tmp[1] + '-' + tmp[2];
        val = tmp[0] + "-" + tmp[1] + "-" + tmp[2];
            } else if (val.match(/^\d{4}-\d{1,2}-\d{1,2}$/)) {
                //ok
            } else {
                return false;
            }
        } else if (this.object_type(val) == 'Date') {
    } else if (this.object_type(val) == "Date") {
            var mm = val.getMonth() + 1;
            if (String(mm).length == 1) {
                mm = '0' + mm;
        mm = "0" + mm;
            }
            
            var dd = '';
      var dd = "";
            if (String(val.getDate()).length == 1) {
                dd = '0' + val.getDate();
        dd = "0" + val.getDate();
            } else {
                dd = val.getDate();
            }
            
            val = val.getFullYear() + '-' + mm + '-' + dd;
      val = val.getFullYear() + "-" + mm + "-" + dd;
        } else {
            return false;
        }
@@ -1137,43 +1432,43 @@
        var hospital_name = event.getParam("value");
        var action = component.get("c.getHospitalList");
        debugger;
        action.setParams({"hospital_name": hospital_name});
    action.setParams({ hospital_name: hospital_name });
        action.setCallback(this, function(response) {
            var state = response.getState();
            if(state === "SUCCESS") {
                var hospital_list = component.find('hospital_list');
        var hospital_list = component.find("hospital_list");
                var hosList = response.getReturnValue();
                if (hosList.length > 0) {
                    $A.util.addClass(hospital_list, 'slds-is-open');
          $A.util.addClass(hospital_list, "slds-is-open");
                } else {
                    $A.util.removeClass(hospital_list, 'slds-is-open');
          $A.util.removeClass(hospital_list, "slds-is-open");
                }
                component.set("v.hospitalList", response.getReturnValue());
            } else {
                $A.util.removeClass(hospital_list, 'slds-is-open');
        $A.util.removeClass(hospital_list, "slds-is-open");
            }
        });
        $A.enqueueAction(action);
    },
    hideSearch : function(component, event, helper) {
        var hospital_list = component.find('hospital_list');
        $A.util.removeClass(hospital_list, 'slds-is-open');
    var hospital_list = component.find("hospital_list");
    $A.util.removeClass(hospital_list, "slds-is-open");
    },
    selectHos : function(component, event, helper) {
        debugger
        var hospital_list = component.find('hospital_list');
        $A.util.removeClass(hospital_list, 'slds-is-open');
    debugger;
    var hospital_list = component.find("hospital_list");
    $A.util.removeClass(hospital_list, "slds-is-open");
        var accname = event.currentTarget.dataset.accname;
        var accid = event.currentTarget.dataset.accid;
        var hospital_data = component.get('v.hospitalList');
    var hospital_data = component.get("v.hospitalList");
        for (var i = 0; i < hospital_data.length; i++) {
            if (hospital_data[i].Hospital__c == accid) {
                component.set('v.hospitalLinkId', hospital_data[i].Id);
                component.set('v.data.Agency_Hospital__c', hospital_data[i].Id);
                component.find('new_con').set('v.disabled', false);
        component.set("v.hospitalLinkId", hospital_data[i].Id);
        component.set("v.data.Agency_Hospital__c", hospital_data[i].Id);
        component.find("new_con").set("v.disabled", false);
            }
        }
        component.set("v.hospital", accname);
@@ -1183,58 +1478,69 @@
    },
    
    select_purpose_type : function(component) {
        var purpose_type = component.find('select_purpose_type').get('v.value');
        if (purpose_type != null && purpose_type != undefined && purpose_type.substr(-3) == 'OPD' || purpose_type.substr(-3) == 'SIS') {
            var result = component.find('result');
            $A.util.removeClass(result, 'disp_none');
    var purpose_type = component.find("select_purpose_type").get("v.value");
    if (
      (purpose_type != null &&
        purpose_type != undefined &&
        purpose_type.substr(-3) == "OPD") ||
      purpose_type.substr(-3) == "SIS"
    ) {
      var result = component.find("result");
      $A.util.removeClass(result, "disp_none");
        } else {
            component.find('select_result').set('v.value', '');
            var result = component.find('result');
            $A.util.addClass(result, 'disp_none');
      component.find("select_result").set("v.value", "");
      var result = component.find("result");
      $A.util.addClass(result, "disp_none");
        }
        this.select_department(component, null, null);
    },
    
    doctor_change : function(component, event, helper) {
        var doctor_value = component.find('select_doctor').get('v.value');
        var doctor_list = component.get('v.doctor_list');
    var doctor_value = component.find("select_doctor").get("v.value");
    var doctor_list = component.get("v.doctor_list");
        var flg = false;
        for (var i = 0; i < doctor_list.length; i++) {
            if (doctor_list[i].value == doctor_value) {
                component.set('v.doctor_title', doctor_list[i].Doctor_Division1__c);
        component.set("v.doctor_title", doctor_list[i].Doctor_Division1__c);
                flg = true;
                break;
            }
        }
        if (flg == false) {
            component.set('v.doctor_title', '');
      component.set("v.doctor_title", "");
        }
    },
    // PIPL update Yin Mingjie 21/02/2022 start
    set_aws_url : function(component,sobject) {
        var action = component.get('c.getAwsurl');
    var action = component.get("c.getAwsurl");
        action.setParams({
            "sobj" : sobject,
      sobj: sobject
        });
        action.setCallback(this,function(response){
            var state = response.getState();
            if(state == 'SUCCESS'){
      if (state == "SUCCESS") {
                var awsmap = this.conv_selected(response.getReturnValue());
                component.set('v.AWStoken',awsmap.token);
                component.set('v.AWSinsert',awsmap.newUrl);
                component.set('v.AWSsearch',awsmap.searchUrl);
                component.set('v.AWStransactionURL',awsmap.transactionURL);
            }
            else{
                this.error('AWS url/token error.');
                component.set('v.login',false);
        component.set("v.AWStoken", awsmap.token);
        component.set("v.AWSinsert", awsmap.newUrl);
        component.set("v.AWSsearch", awsmap.searchUrl);
        component.set("v.AWStransactionURL", awsmap.transactionURL);
      } else {
        this.error("AWS url/token error.");
        component.set("v.login", false);
            }
        });
        $A.enqueueAction(action);
    },
    insert_agencycontact : function(component,token,newUrl,payload,agencyHospitalid,helper,hospitalName) {
  insert_agencycontact: function (
    component,
    token,
    newUrl,
    payload,
    agencyHospitalid,
    helper,
    hospitalName
  ) {
        // AWSService.insert(newUrl,payload,function(result){
        //     if(result.status == '0'){
        //         $A.getCallback(function(){
@@ -1249,75 +1555,80 @@
        // },token);
        
        fetch(newUrl, {
            method: 'POST',
      method: "POST",
            body: payload,
            headers: {
                'Content-Type': 'application/json',
                'pi-token': token
        "Content-Type": "application/json",
        "pi-token": token
            }
        }).then((data) => {
    })
      .then((data) => {
            return data.json();
        }).then((result) => {
            if(result.status == '0'){
      })
      .then((result) => {
        if (result.status == "0") {
                $A.getCallback(function(){
                    helper.to_agencycontact(component,result,agencyHospitalid);
                })();
            }else{
                console.log('AWS status error:' + result)
                component.set('v.login',false);
                if(result.status == '129'){
                    component.find('OppMessage').setError('该客户人员名字已存在,在'+hospitalName+'医院,请修改');
          console.log("AWS status error:" + result);
          component.set("v.login", false);
          if (result.status == "129") {
            component
              .find("OppMessage")
              .setError(
                "该客户人员名字已存在,在" + hospitalName + "医院,请修改"
              );
                }else{
                    component.find('OppMessage').setError('AWS insert error.');
            component.find("OppMessage").setError("AWS insert error.");
                }
            }
        }).catch(error => {
            console.log('AWS insert error:' + error)
            component.set('v.login',false);
            component.find('OppMessage').setError('AWS insert error.');
      })
      .catch((error) => {
        console.log("AWS insert error:" + error);
        component.set("v.login", false);
        component.find("OppMessage").setError("AWS insert error.");
        });
    },
    to_agencycontact : function(component,result,agencyHospitalid) {
        var action = component.get('c.saveAgencyContact');
    var action = component.get("c.saveAgencyContact");
        action.setParams({
            "name" : result.object[0].name,
      name: result.object[0].name,
            //"nameEncrypt" : result.object[0].nameEncrypt,
            "type" : result.object[0].type,
      type: result.object[0].type,
            //"typeEncrypt" : result.object[0].typeEncrypt,
            "doctorDivision1" : result.object[0].doctorDivision1,
      doctorDivision1: result.object[0].doctorDivision1,
            //"doctorDivision1Encrypt" : result.object[0].doctorDivision1Encrypt,
            "agencyHospitalid" : agencyHospitalid,
            "awsid" : result.object[0].dataId,
      agencyHospitalid: agencyHospitalid,
      awsid: result.object[0].dataId
        });
        action.setCallback(this,function(response){
            var state = response.getState();
            if(state == 'SUCCESS'){
      if (state == "SUCCESS") {
                var acMap = this.conv_selected(response.getReturnValue());
                console.log(acMap);
                if(acMap.AgencyContactId != ''){
        if (acMap.AgencyContactId != "") {
                    //确认事务 
                    var token = component.get('v.AWStoken');
                    var confirmUrl = component.get('v.AWStransactionURL');
          var token = component.get("v.AWStoken");
          var confirmUrl = component.get("v.AWStransactionURL");
                    let data = Object.create(null);
                    data['isSuccess'] = 1;
                    data['sfRecordId'] = '';
                    data['txId'] = result.txId;
          data["isSuccess"] = 1;
          data["sfRecordId"] = "";
          data["txId"] = result.txId;
                    this.to_confirm(component,token,confirmUrl,JSON.stringify(data));
                }else if(acMap.errormsg != ''){
        } else if (acMap.errormsg != "") {
                    this.error(acMap.errormsg);
                    component.set('v.login',false);
          component.set("v.login", false);
                }else {
                    this.error('agency contact insert id error.');
                    component.set('v.login',false);
          this.error("agency contact insert id error.");
          component.set("v.login", false);
                }
            }
            else{
                this.error('agency contact insert error.');
                component.set('v.login',false);
      } else {
        this.error("agency contact insert error.");
        component.set("v.login", false);
            }
        });
        $A.enqueueAction(action);
@@ -1325,43 +1636,50 @@
    to_confirm : function(component,token,confirmUrl,payload) {
        fetch(confirmUrl, {
            method: 'POST',
      method: "POST",
            body: payload,
            headers: {
                'Content-Type': 'application/json',
                'pi-token': token
        "Content-Type": "application/json",
        "pi-token": token
            }
        }).then((data) => {
    })
      .then((data) => {
            return data.json();
        }).then((result) => {
            if(result.status == '0' && result.hasOwnProperty('success') && result.success){
                component.set('v.truthy', false);
                var modal_newAC = component.find('modal_newAC')
                $A.util.addClass(modal_newAC, 'disp_none');
                this.success('.客户人员已创建。');
      })
      .then((result) => {
        if (
          result.status == "0" &&
          result.hasOwnProperty("success") &&
          result.success
        ) {
          component.set("v.truthy", false);
          var modal_newAC = component.find("modal_newAC");
          $A.util.addClass(modal_newAC, "disp_none");
          this.success(".客户人员已创建。");
                this.set_doctor_list(component);
            }else {
                this.error('AWS confirm error.');
                component.set('v.login',false);
          this.error("AWS confirm error.");
          component.set("v.login", false);
            }
        }).catch(error => {
            this.error('AWS confirm error.');
            component.set('v.login',false);
      })
      .catch((error) => {
        this.error("AWS confirm error.");
        component.set("v.login", false);
        });
    },
    // PIPL update Yin Mingjie 21/02/2022 end
    set_doctor_list : function(component) {
        var hospital_id = component.get('v.hospitalLinkId');
    var hospital_id = component.get("v.hospitalLinkId");
        if (hospital_id) {
            component.set('v.login',true);
            var action = component.get('c.getDoctorList');
      component.set("v.login", true);
      var action = component.get("c.getDoctorList");
            action.setParams({
                "hospital_id" : hospital_id,
        hospital_id: hospital_id
            });
            action.setCallback(this,function(response){
                var state = response.getState();
                if(state == 'SUCCESS'){
        if (state == "SUCCESS") {
                    var retMap = this.conv_selected(response.getReturnValue());
                    // PIPL update Yin Mingjie 21/02/2022 start
                    this.AWS_search(retMap,component);
@@ -1392,10 +1710,9 @@
                    component.set('v.login',false);
                    */
                   // PIPL update Yin Mingjie 21/02/2022 end
                }
                else{
                    this.error('set_doctor_list failed.');
                    component.set('v.login',false);
        } else {
          this.error("set_doctor_list failed.");
          component.set("v.login", false);
                }
            });
            $A.enqueueAction(action);
@@ -1409,29 +1726,43 @@
        var dataArr = new Array();
        for (const key in retMap) {
            if (key == 'sre') {continue;}
      if (key == "sre") {
        continue;
      }
            dataArr.push(key);
        }
        if(dataArr.length == 0){
            component.set('v.login',false);
            this.warning('没有找到符合条件的客户人员');
      component.set("v.login", false);
      this.warning("没有找到符合条件的客户人员");
            return;
        }
        let obj= Object.create(null);
        obj['dataIds'] = dataArr;
    obj["dataIds"] = dataArr;
        var data = JSON.stringify(obj);
        this.search_agency_contact(token,searchUrl,data,retMap,component);
    },
    search_agency_contact : function(token,searchUrl,payload,retMap,component) {
        this.search_core(token,searchUrl,payload,(result)=>{
            if(result.status == '0'){
  search_agency_contact: function (
    token,
    searchUrl,
    payload,
    retMap,
    component
  ) {
    this.search_core(
      token,
      searchUrl,
      payload,
      (result) => {
        if (result.status == "0") {
                this.to_doctor_list(result,retMap,component);
            }else{
                this.error('AWS search status4 : ' + result.status);
                component.set('v.login',false);
          this.error("AWS search status4 : " + result.status);
          component.set("v.login", false);
            }
        },component);
      },
      component
    );
        // fetch(searchUrl, {
        //     method: 'POST',
        //     body: payload,
@@ -1449,25 +1780,28 @@
        // });
    },
    search_core : function(token,searchUrl,payload,callback,component) {
        console.log('token = ' + token);
        console.log('searchUrl = ' + searchUrl);
        console.log('payload = ' + payload);
    console.log("token = " + token);
    console.log("searchUrl = " + searchUrl);
    console.log("payload = " + payload);
        fetch(searchUrl, {
            method: 'POST',
      method: "POST",
            body: payload,
            headers: {
                'Content-Type': 'application/json',
                'pi-token': token
        "Content-Type": "application/json",
        "pi-token": token
            }
        }).then((data) => {
    })
      .then((data) => {
            return data.json();
        }).then((result) => {
            component.set('v.login',false);
      })
      .then((result) => {
        component.set("v.login", false);
            if(callback)callback(result);
        }).catch(error => {
            console.log('error = ' + JSON.stringify(error));
            this.error('AWS search error.');
            component.set('v.login',false);
      })
      .catch((error) => {
        console.log("error = " + JSON.stringify(error));
        this.error("AWS search error.");
        component.set("v.login", false);
        });
    },
@@ -1475,23 +1809,23 @@
        var resls = result.object;
        var res = [];
        var space = {};
        space['label'] = '';
        space['selected'] = true;
        space['value'] = '';
    space["label"] = "";
    space["selected"] = true;
    space["value"] = "";
        res.push(space);
        for (var i = 0; i < resls.length; i++) {
            var t = {};
            t['label'] = resls[i].name;
            t['selected'] = false;
            t['Doctor_Division1__c'] = resls[i].doctorDivision1;
            t['value'] = retMap[resls[i].dataId].value;
      t["label"] = resls[i].name;
      t["selected"] = false;
      t["Doctor_Division1__c"] = resls[i].doctorDivision1;
      t["value"] = retMap[resls[i].dataId].value;
            res.push(t);
        }
        var default_doctor = component.get('v.default_select_doctor_id');
        if (default_doctor != '' && res.length > 0) {
            var doctor_title = '';
    var default_doctor = component.get("v.default_select_doctor_id");
    if (default_doctor != "" && res.length > 0) {
      var doctor_title = "";
            for (var i = 0; i < res.length; i++) {
                if (res[i].value == default_doctor) {
                    res[i].selected = true;
@@ -1501,18 +1835,18 @@
                }
            }
            component.find('select_doctor').set('v.options', res);
            component.set('v.doctor_title', doctor_title);
      component.find("select_doctor").set("v.options", res);
      component.set("v.doctor_title", doctor_title);
        } else {
            component.find('select_doctor').set('v.options', res);
      component.find("select_doctor").set("v.options", res);
            if (res.length > 0) {
                component.set('v.doctor_title', res[0].Doctor_Division1__c);
        component.set("v.doctor_title", res[0].Doctor_Division1__c);
            }
        }
        
        component.set('v.default_select_doctor_id', '');
        component.set('v.doctor_list', res);
        component.set('v.login',false);
    component.set("v.default_select_doctor_id", "");
    component.set("v.doctor_list", res);
    component.set("v.login", false);
    },
    // PIPL update Yin Mingjie 21/02/2022 end
@@ -1529,32 +1863,62 @@
    // },
    
    opportunityChange : function(component, event, helper) {
        debugger
        var opp_id = component.get('v.data.Opportunity__c');
        if (opp_id == '') {
            $A.util.addClass(component.find('input-opportunity-stage'), 'disp_none');
            $A.util.addClass(component.find('input-opportunity-amount1'), 'disp_none');
            $A.util.addClass(component.find('input-opportunity-amount2'), 'disp_none');
            $A.util.addClass(component.find('input-opportunity-date'), 'disp_none');
            $A.util.removeClass(component.find('input-opportunity-blank'), 'disp_none');
        } else if (opp_id == 'MALFORMED_ID') {
            component.set('v.data.Opportunity__c', '');
            $A.util.addClass(component.find('input-opportunity-stage'), 'disp_none');
            $A.util.addClass(component.find('input-opportunity-amount1'), 'disp_none');
            $A.util.addClass(component.find('input-opportunity-amount2'), 'disp_none');
            $A.util.addClass(component.find('input-opportunity-date'), 'disp_none');
            $A.util.removeClass(component.find('input-opportunity-blank'), 'disp_none');
    debugger;
    var opp_id = component.get("v.data.Opportunity__c");
    if (opp_id == "") {
      $A.util.addClass(component.find("input-opportunity-stage"), "disp_none");
      $A.util.addClass(
        component.find("input-opportunity-amount1"),
        "disp_none"
      );
      $A.util.addClass(
        component.find("input-opportunity-amount2"),
        "disp_none"
      );
      $A.util.addClass(component.find("input-opportunity-date"), "disp_none");
      $A.util.removeClass(
        component.find("input-opportunity-blank"),
        "disp_none"
      );
    } else if (opp_id == "MALFORMED_ID") {
      component.set("v.data.Opportunity__c", "");
      $A.util.addClass(component.find("input-opportunity-stage"), "disp_none");
      $A.util.addClass(
        component.find("input-opportunity-amount1"),
        "disp_none"
      );
      $A.util.addClass(
        component.find("input-opportunity-amount2"),
        "disp_none"
      );
      $A.util.addClass(component.find("input-opportunity-date"), "disp_none");
      $A.util.removeClass(
        component.find("input-opportunity-blank"),
        "disp_none"
      );
        } else if (opp_id != "") {
            var hospital_link_id = component.get('v.hospitalLinkId');
            if (hospital_link_id == '') {
                this.warning('医院不存在');
      var hospital_link_id = component.get("v.hospitalLinkId");
      if (hospital_link_id == "") {
        this.warning("医院不存在");
                // ToDo需要测试手机上能运行不
                component.set('v.data.Opportunity__c', '');
                $A.util.addClass(component.find('input-opportunity-stage'), 'disp_none');
                $A.util.addClass(component.find('input-opportunity-amount1'), 'disp_none');
                $A.util.addClass(component.find('input-opportunity-amount2'), 'disp_none');
                $A.util.addClass(component.find('input-opportunity-date'), 'disp_none');
                $A.util.removeClass(component.find('input-opportunity-blank'), 'disp_none');
        component.set("v.data.Opportunity__c", "");
        $A.util.addClass(
          component.find("input-opportunity-stage"),
          "disp_none"
        );
        $A.util.addClass(
          component.find("input-opportunity-amount1"),
          "disp_none"
        );
        $A.util.addClass(
          component.find("input-opportunity-amount2"),
          "disp_none"
        );
        $A.util.addClass(component.find("input-opportunity-date"), "disp_none");
        $A.util.removeClass(
          component.find("input-opportunity-blank"),
          "disp_none"
        );
                // if ($A.get("$Browser.formFactor") == 'DESKTOP') {
                //     var values = [];
                //     // component.find('input-opportunity').get("v.body")[0].set('v.values', values);
@@ -1563,35 +1927,50 @@
                // }
                return false;
            }
            var action = component.get('c.selectOpportunityByIdAndHospitalLinkId');
      var action = component.get("c.selectOpportunityByIdAndHospitalLinkId");
            action.setParams({
                "opportunity_id" : opp_id,
                "agency_hospital_link_id" : component.get('v.hospitalLinkId'),
        opportunity_id: opp_id,
        agency_hospital_link_id: component.get("v.hospitalLinkId")
            });
            component.set('v.login',true);
      component.set("v.login", true);
            action.setCallback(this,function(response){
                var state = response.getState();
                if(state == 'SUCCESS'){
        if (state == "SUCCESS") {
                    var res = response.getReturnValue();
                    if (res.length <= 0) {
                        if (component.get('v.data.Opportunity__c')) {
                            this.warning('医院未匹配到');
            if (component.get("v.data.Opportunity__c")) {
              this.warning("医院未匹配到");
                        }
                        // ToDo需要测试手机上能运行不
                        component.set('v.data.Opportunity__c', '');
                        $A.util.addClass(component.find('input-opportunity-stage'), 'disp_none');
                        $A.util.addClass(component.find('input-opportunity-amount1'), 'disp_none');
                        $A.util.addClass(component.find('input-opportunity-amount2'), 'disp_none');
                        $A.util.addClass(component.find('input-opportunity-date'), 'disp_none');
                        $A.util.removeClass(component.find('input-opportunity-blank'), 'disp_none');
            component.set("v.data.Opportunity__c", "");
            $A.util.addClass(
              component.find("input-opportunity-stage"),
              "disp_none"
            );
            $A.util.addClass(
              component.find("input-opportunity-amount1"),
              "disp_none"
            );
            $A.util.addClass(
              component.find("input-opportunity-amount2"),
              "disp_none"
            );
            $A.util.addClass(
              component.find("input-opportunity-date"),
              "disp_none"
            );
            $A.util.removeClass(
              component.find("input-opportunity-blank"),
              "disp_none"
            );
                        // if ($A.get("$Browser.formFactor") == 'DESKTOP') {
                        //     var values = [];
                        //     component.find('input-opportunity').get("v.body")[0].set('v.values', values);
                        // } else {
                        //     component.find('input-opportunity').get("v.body")[0].set('v.selectedLabel', '');            
                        // }
                        component.set('v.login',false);
            component.set("v.login", false);
                        return false;
                    }
                    //SWAG-CKH5M8  【委托】周报关联询价,可选择询价范围调整 fy start
@@ -1615,26 +1994,47 @@
                    // }
                    //SWAG-CKH5M8  【委托】周报关联询价,可选择询价范围调整 fy end
                     else {
                        component.set('v.loadOpp', false);
                        component.set('v.oppdata',res[0]);
                        this.set_selected(component, 'select_stageName', res[0].StageName__c);
                        component.set('v.Close_Forecasted_Date__c_o', res[0].Close_Forecasted_Date__c);
                        component.set('v.Amount__c_o', res[0].Amount__c);
                        component.set('v.OCMSale_Price__c_o', res[0].OCMSale_Price__c);
                        component.set('v.StageName__c_o', res[0].StageName__c);
            component.set("v.loadOpp", false);
            component.set("v.oppdata", res[0]);
            this.set_selected(
              component,
              "select_stageName",
              res[0].StageName__c
            );
            component.set(
              "v.Close_Forecasted_Date__c_o",
              res[0].Close_Forecasted_Date__c
            );
            component.set("v.Amount__c_o", res[0].Amount__c);
            component.set("v.OCMSale_Price__c_o", res[0].OCMSale_Price__c);
            component.set("v.StageName__c_o", res[0].StageName__c);
                        $A.util.removeClass(component.find('input-opportunity-stage'), 'disp_none');
                        $A.util.removeClass(component.find('input-opportunity-amount1'), 'disp_none');
                        $A.util.removeClass(component.find('input-opportunity-amount2'), 'disp_none');
                        $A.util.removeClass(component.find('input-opportunity-date'), 'disp_none');
                        $A.util.addClass(component.find('input-opportunity-blank'), 'disp_none');
            $A.util.removeClass(
              component.find("input-opportunity-stage"),
              "disp_none"
            );
            $A.util.removeClass(
              component.find("input-opportunity-amount1"),
              "disp_none"
            );
            $A.util.removeClass(
              component.find("input-opportunity-amount2"),
              "disp_none"
            );
            $A.util.removeClass(
              component.find("input-opportunity-date"),
              "disp_none"
            );
            $A.util.addClass(
              component.find("input-opportunity-blank"),
              "disp_none"
            );
                    }
                    
                    component.set('v.login',false);
                }
                else{
                    this.error('selectOpportunityByIdAndHospitalLinkId failed.');
                    component.set('v.login',false);
          component.set("v.login", false);
        } else {
          this.error("selectOpportunityByIdAndHospitalLinkId failed.");
          component.set("v.login", false);
                }
            });
            $A.enqueueAction(action);
@@ -1642,46 +2042,64 @@
    },
    
    productcategoryChange1 : function(component, event, helper) {
        var product_category_id = component.find('select_Product1').get('v.value');
        var pcId1 = component.find('select_Product2').get('v.value');
        var pcId2 = component.find('select_Product3').get('v.value');
        var p1bool = pcId1 != '' && pcId1 != null && pcId1 != undefined;
        var p2bool = pcId2 != '' && pcId2 != null && pcId2 != undefined;
        var p0bool = product_category_id != '' && product_category_id != null && product_category_id != undefined;
        if ((p1bool && p0bool && product_category_id == pcId1) || (p2bool && p0bool && product_category_id == pcId2)) {
            this.warning('不能选择同样的产品区分');
            component.find('select_Product1').set('v.value','');
    var product_category_id = component.find("select_Product1").get("v.value");
    var pcId1 = component.find("select_Product2").get("v.value");
    var pcId2 = component.find("select_Product3").get("v.value");
    var p1bool = pcId1 != "" && pcId1 != null && pcId1 != undefined;
    var p2bool = pcId2 != "" && pcId2 != null && pcId2 != undefined;
    var p0bool =
      product_category_id != "" &&
      product_category_id != null &&
      product_category_id != undefined;
    if (
      (p1bool && p0bool && product_category_id == pcId1) ||
      (p2bool && p0bool && product_category_id == pcId2)
    ) {
      this.warning("不能选择同样的产品区分");
      component.find("select_Product1").set("v.value", "");
        }
    },
    productcategoryChange2 : function(component, event, helper) {
        var product_category_id = component.find('select_Product2').get('v.value');
        var pcId1 = component.find('select_Product1').get('v.value');
        var pcId2 = component.find('select_Product3').get('v.value');
        var p1bool = pcId1 != '' && pcId1 != null && pcId1 != undefined;
        var p2bool = pcId2 != '' && pcId2 != null && pcId2 != undefined;
        var p0bool = product_category_id != '' && product_category_id != null && product_category_id != undefined;
        if ((p1bool && p0bool && product_category_id == pcId1) || (p2bool && p0bool && product_category_id == pcId2)) {
            this.warning('不能选择同样的产品区分');
            component.find('select_Product2').set('v.value','');
    var product_category_id = component.find("select_Product2").get("v.value");
    var pcId1 = component.find("select_Product1").get("v.value");
    var pcId2 = component.find("select_Product3").get("v.value");
    var p1bool = pcId1 != "" && pcId1 != null && pcId1 != undefined;
    var p2bool = pcId2 != "" && pcId2 != null && pcId2 != undefined;
    var p0bool =
      product_category_id != "" &&
      product_category_id != null &&
      product_category_id != undefined;
    if (
      (p1bool && p0bool && product_category_id == pcId1) ||
      (p2bool && p0bool && product_category_id == pcId2)
    ) {
      this.warning("不能选择同样的产品区分");
      component.find("select_Product2").set("v.value", "");
        }
    },
    productcategoryChange3 : function(component, event, helper) {
        var product_category_id = component.find('select_Product3').get('v.value');
        var pcId1 = component.find('select_Product1').get('v.value');
        var pcId2 = component.find('select_Product2').get('v.value');
        var p1bool = pcId1 != '' && pcId1 != null && pcId1 != undefined;
        var p2bool = pcId2 != '' && pcId2 != null && pcId2 != undefined;
        var p0bool = product_category_id != '' && product_category_id != null && product_category_id != undefined;
        if ((p1bool && p0bool && product_category_id == pcId1) || (p2bool && p0bool && product_category_id == pcId2)) {
            this.warning('不能选择同样的产品区分');
            component.find('select_Product3').set('v.value','');
    var product_category_id = component.find("select_Product3").get("v.value");
    var pcId1 = component.find("select_Product1").get("v.value");
    var pcId2 = component.find("select_Product2").get("v.value");
    var p1bool = pcId1 != "" && pcId1 != null && pcId1 != undefined;
    var p2bool = pcId2 != "" && pcId2 != null && pcId2 != undefined;
    var p0bool =
      product_category_id != "" &&
      product_category_id != null &&
      product_category_id != undefined;
    if (
      (p1bool && p0bool && product_category_id == pcId1) ||
      (p2bool && p0bool && product_category_id == pcId2)
    ) {
      this.warning("不能选择同样的产品区分");
      component.find("select_Product3").set("v.value", "");
        }
    },
    
    conv_selected : function(obj) {
        for (var i = 0; i < obj.length; i++) {
            if (obj[i].selected) {
                if (obj[i].selected == 'true') {
        if (obj[i].selected == "true") {
                    obj[i].selected = true;
                } else {
                    obj[i].selected = false;
@@ -1693,7 +2111,7 @@
    },
    
    set_selected : function (component, aura_id_name, value) {
        var select_tmp = component.find(aura_id_name).get('v.options');
    var select_tmp = component.find(aura_id_name).get("v.options");
        if (select_tmp) {
            for (var i = 0; i < select_tmp.length; i++) {
                if (select_tmp[i].value == value) {
@@ -1702,7 +2120,7 @@
                    select_tmp[i].selected = false;
                }
            }
            component.find(aura_id_name).set('v.options', select_tmp);
      component.find(aura_id_name).set("v.options", select_tmp);
            return true;
        } else {
            return false;
@@ -1712,10 +2130,10 @@
    success : function(message) {
        var toastEvent = $A.get("e.force:showToast");
        toastEvent.setParams({
            "title" : "成功!",
            "message" : message,
            "type" : "success",
            "duration" : "5000"
      title: "成功!",
      message: message,
      type: "success",
      duration: "5000"
        });
        toastEvent.fire();
    },
@@ -1723,10 +2141,10 @@
    warning : function(message) {
        var toastEvent = $A.get("e.force:showToast");
        toastEvent.setParams({
            "title": "警告!",
            "message": message,
            "type":"warning",
            "duration" : "10000"
      title: "警告!",
      message: message,
      type: "warning",
      duration: "10000"
        });
        toastEvent.fire();
    },
@@ -1736,18 +2154,18 @@
        var toastEvent = $A.get("e.force:showToast");
        toastEvent.setParams({
            "title": "错误!",
            "message": message,
            "type":"error",
            "duration" : "sticky"
      title: "错误!",
      message: message,
      type: "error",
      duration: "sticky"
        });
        toastEvent.fire();
    },
    
    createCon : function(component, event, helper) {
        var modal_newAC = component.find('modal_newAC')
        $A.util.removeClass(modal_newAC, 'disp_none');
        component.set('v.truthy', true);
    var modal_newAC = component.find("modal_newAC");
    $A.util.removeClass(modal_newAC, "disp_none");
    component.set("v.truthy", true);
        // var modal_newAC = component.find('modal_newAC')
        // $A.util.removeClass(modal_newAC, 'disp_none');
    },
@@ -1776,77 +2194,87 @@
    // vivek end 添加验证
    hideCmp : function(component, event, helper) {
        var div1 = component.find('report')
        var div2 = component.find('report_list')
        $A.util.addClass(div1, 'disp_none');
        $A.util.addClass(div2, 'disp_none');
    var div1 = component.find("report");
    var div2 = component.find("report_list");
    $A.util.addClass(div1, "disp_none");
    $A.util.addClass(div2, "disp_none");
    },
            
    handleSuccess : function(component, event, helper) {
        var insertId = event.getParams().response.Id;
        var displayValue = event.getParams().response.fields.Name.value;
        event.setParams({});
        component.set('v.truthy', false);
        var modal_newAC = component.find('modal_newAC')
        $A.util.addClass(modal_newAC, 'disp_none');
        this.success('.客户人员已创建。');
    component.set("v.truthy", false);
    var modal_newAC = component.find("modal_newAC");
    $A.util.addClass(modal_newAC, "disp_none");
    this.success(".客户人员已创建。");
        this.set_doctor_list(component);
    },
    
    createCancel : function(component, event, helper) {
        component.set('v.truthy', false);
        var modal_newAC = component.find('modal_newAC')
        $A.util.addClass(modal_newAC, 'disp_none');
    component.set("v.truthy", false);
    var modal_newAC = component.find("modal_newAC");
    $A.util.addClass(modal_newAC, "disp_none");
    },
    setOpportunity_cfilter : function(component) {
        debugger
        var hosId = component.get('v.hospitalId');
        var Department_Cateogy__c = component.find('select_department').get('v.value');
        var opportunity_cfilter = '';
        if (hosId != '' && hosId != null) {
            opportunity_cfilter = ' Agency_Hospital__r.Hospital__c=' + '\'' + hosId + '\'';
    debugger;
    var hosId = component.get("v.hospitalId");
    var Department_Cateogy__c = component
      .find("select_department")
      .get("v.value");
    var opportunity_cfilter = "";
    if (hosId != "" && hosId != null) {
      opportunity_cfilter =
        " Agency_Hospital__r.Hospital__c=" + "'" + hosId + "'";
        }
        if (Department_Cateogy__c != '' && Department_Cateogy__c != null) {
            if (opportunity_cfilter != '' && opportunity_cfilter != null) {
                opportunity_cfilter += ' AND ';
    if (Department_Cateogy__c != "" && Department_Cateogy__c != null) {
      if (opportunity_cfilter != "" && opportunity_cfilter != null) {
        opportunity_cfilter += " AND ";
            }
            opportunity_cfilter += 'Department_Cateogy__c=' + '\'' + Department_Cateogy__c + '\'';
      opportunity_cfilter +=
        "Department_Cateogy__c=" + "'" + Department_Cateogy__c + "'";
        }
        component.set('v.opportunity_cfilter', opportunity_cfilter);
        component.set('v.data.Opportunity__c', null);
    component.set("v.opportunity_cfilter", opportunity_cfilter);
    component.set("v.data.Opportunity__c", null);
    },
    readFile: function(component, helper, file) {
        if (!file) return;
        // console.log('file'+file.name);
        if(!file.name.match(/\.(csv||CSV)$/)){
            return alert('only support csv files');
      return alert("only support csv files");
        }else{
            reader = new FileReader();
            reader.onerror =function errorHandler(evt) {
                switch(evt.target.error.code) {
                    case evt.target.error.NOT_FOUND_ERR:
                        alert('File Not Found!');
            alert("File Not Found!");
                        break;
                    case evt.target.error.NOT_READABLE_ERR:
                        alert('File is not readable');
            alert("File is not readable");
                        break;
                    case evt.target.error.ABORT_ERR:
                        break; // noop
                    default:
                        alert('An error occurred reading this file.');
                };
            alert("An error occurred reading this file.");
            }
      };
            //reader.onprogress = updateProgress;
            reader.onabort = function(e) {
                alert('File read cancelled');
        alert("File read cancelled");
            };
            reader.onloadstart = function(e) { 
                var output = '<ui type=\"disc\"><li><strong>'+file.name +'</strong> ('+file.type+')- '+file.size+'bytes, last modified: '+file.lastModifiedDate.toLocaleDateString()+'</li></ui>';
        var output =
          '<ui type="disc"><li><strong>' +
          file.name +
          "</strong> (" +
          file.type +
          ")- " +
          file.size +
          "bytes, last modified: " +
          file.lastModifiedDate.toLocaleDateString() +
          "</li></ui>";
                component.set("v.filename",file.name);
                component.set("v.TargetFileName",output);
            };
            reader.onload = function(e) {
                var data=e.target.result;
@@ -1855,35 +2283,32 @@
                // console.log("file data"+encodeURI(JSON.stringify(data),"utf-8"));
                var allTextLines = data.split(/\r\n|\n/);
                var dataRows=allTextLines.length-1;
                var headers = allTextLines[0].split(',');
        var headers = allTextLines[0].split(",");
                
                // console.log("Rows length::"+dataRows);
               
                    var numOfRows=component.get("v.NumOfRecords");
                    if(dataRows > numOfRows+1 || dataRows == 1 || dataRows== 0){
                     alert("File Rows between 1 to "+numOfRows+" .");
                    component.set("v.showMain",true);
                }
                else{
        } else {
                    var lines = [];
                    var filecontentdata;
                    var content = "<table class=\"table slds-table slds-table--bordered slds-table--cell-buffer\">";
                    content += "<thead><tr class=\"slds-text-title--caps\">";
                    content += '<th scope=\"col"\>'+'行号'+'</th>';
          var content =
            '<table class="table slds-table slds-table--bordered slds-table--cell-buffer">';
          content += '<thead><tr class="slds-text-title--caps">';
          content += '<th scope="col">' + "行号" + "</th>";
                    for(i=0;i<headers.length; i++){
                        content += '<th scope=\"col"\>'+headers[i]+'</th>';
            content += '<th scope="col">' + headers[i] + "</th>";
                    }
                    content += "</tr></thead>";
                    for (var i=1; i<allTextLines.length; i++) {
                        filecontentdata = allTextLines[i].split(',');
                        if(filecontentdata[0]!=''){
            filecontentdata = allTextLines[i].split(",");
            if (filecontentdata[0] != "") {
                            content +="<tr>";
                            content +="<td>"+i+"</td>";
                            for(var j=0;j<filecontentdata.length;j++){
                                content +='<td>'+filecontentdata[j]+'</td>';
                content += "<td>" + filecontentdata[j] + "</td>";
                            }
                            content +="</tr>";
                        }
@@ -1893,40 +2318,37 @@
                    component.set("v.TableContent",content);
                    component.set("v.showMain",false);                   
                }
            }
            reader.readAsText(file,'gb2312');
      };
      reader.readAsText(file, "gb2312");
        }
        var reader = new FileReader();
        reader.onloadend = function() {
        };
    reader.onloadend = function () {};
        reader.readAsDataURL(file);
    },
    
    saveRecords : function(component,event,helper){
        debugger
        component.set('v.login',true);
    debugger;
    component.set("v.login", true);
        //fy 导入 20220424 start
        var action1 = component.get("c.processDataAWSId");
        action1.setParams({ 
            fileData : component.get("v.fileContentData"),
      fileData: component.get("v.fileContentData")
        }); 
        debugger
    debugger;
        action1.setCallback(this, function(response) {
            console.log('response = '  + JSON.stringify(response));
      console.log("response = " + JSON.stringify(response));
            var state = response.getState();
            if (state === "SUCCESS") {
                var ress = response.getReturnValue();
                console.log('ress = '  + JSON.stringify(ress));
        console.log("ress = " + JSON.stringify(ress));
                if(ress){
                    var valur =ress.split('error1');
          var valur = ress.split("error1");
                    if(valur.length<=1){
                        var res = JSON.parse(response.getReturnValue());
                        console.log('res = '  + JSON.stringify(res));
            console.log("res = " + JSON.stringify(res));
                        var dataArr = new Array();
                        var dataMap = new Map();
                        res.forEach(item => {
            res.forEach((item) => {
                            if(item.AWS_Data_Id__c){
                                dataArr.push(item.AWS_Data_Id__c);
                                //dataMap.set(item.AWS_Data_Id__c,item.Name_Encrypted__c);
@@ -1934,15 +2356,22 @@
                            }
                        });
                        let obj= Object.create(null);
                        obj['dataIds'] = dataArr;
            obj["dataIds"] = dataArr;
                        var payload = JSON.stringify(obj);
                        console.log('payload zhj = ' + JSON.stringify(payload));
            console.log("payload zhj = " + JSON.stringify(payload));
                        
                        this.search_contact_url(component, 'Agency_Contact__c', (result)=>{
            this.search_contact_url(
              component,
              "Agency_Contact__c",
              (result) => {
                            var token = result.token;
                            var searchUrl = result.searchUrl;
                            this.search_core(token,searchUrl,payload,(result)=>{
                                if(result.status == '0'){
                this.search_core(
                  token,
                  searchUrl,
                  payload,
                  (result) => {
                    if (result.status == "0") {
                                    if(result.object != null&&result.object.length != 0){
                                        // var resultjson = JSON.stringify(result.object);
                                        // if(resultjson){
@@ -1951,25 +2380,32 @@
                                        //     component.set('v.login',true);
                                        //     this.ImportMethod(component,resultjson);
                                        // }
                                        component.set('v.login',true);
                                        this.saveRecordsEditFile(component,dataMap,result.object,helper);
                        component.set("v.login", true);
                        this.saveRecordsEditFile(
                          component,
                          dataMap,
                          result.object,
                          helper
                        );
                                    }else{
                                        this.error('AWS 查询数据为空 ' );
                                        component.set('v.login',false);
                        this.error("AWS 查询数据为空 ");
                        component.set("v.login", false);
                                    }
                                }else{
                                    this.error('AWS search status6 : ' + result.status);
                                    component.set('v.login',false);
                      this.error("AWS search status6 : " + result.status);
                      component.set("v.login", false);
                                }
                            },component);
                  },
                  component
                );
                        //     var resultjson =null;
                        // this.ImportMethod(component,resultjson);
                        });
              }
            );
                        // var resultjson =null;
                        // this.ImportMethod(component,resultjson);
                    }else{
                        this.error(valur[1]+'\n'+"请修改后重新上传");
            this.error(valur[1] + "\n" + "请修改后重新上传");
                    }
                }
            }
@@ -2031,64 +2467,84 @@
        //     }
        // });
        // $A.enqueueAction(action);
    },isNumber: function(str) {
  },
  isNumber: function (str) {
        return /^\d+$/.test(str);
    },ImportMethod : function(component,fileStr){
        debugger
  },
  ImportMethod: function (component, fileStr) {
    debugger;
        var actionss = component.get("c.processData");
         var selectDate = component.find('select_date').get('v.value');
        var fieldsList=['Name','Phone','AccountNumber']; //Please write your code dynamic
    var selectDate = component.find("select_date").get("v.value");
    var fieldsList = ["Name", "Phone", "AccountNumber"]; //Please write your code dynamic
        var sss=component.get("v.fileContentData");
        actionss.setParams({ 
            // fileData : component.get("v.fileContentData"),
            fileData : fileStr,
            // selectDateselectDate :component.find('select_date').get('v.value'),
            sobjectName:'Account', //Any object
      sobjectName: "Account", //Any object
            fields:fieldsList
            // Agency_ContactListjson:resultjson
        }); 
        actionss.setCallback(this, function(response) {
                console.log('002');
      console.log("002");
                var state = response.getState();
                if (state === "SUCCESS") {
                    var res = response.getReturnValue();
                    var res1 = '';
        var res1 = "";
                    console.log("[[[[[["+res);
                    if(res != 'success'){
                        var ress = res.split('=');
        if (res != "success") {
          var ress = res.split("=");
                        console.log(ress);
                        let errorDatas = [];
                        let errorDataRow = [];
                        debugger
          debugger;
                        for (var i=0; i<ress.length; i++) {
                            res1 += ress[i].substr(7)+'\n';
                            if (ress[i] != '') {
                                let errorData = {}
            res1 += ress[i].substr(7) + "\n";
            if (ress[i] != "") {
              let errorData = {};
                                if(!this.isNumber(ress[i].substr(7).substring(1, 2))){
                                    continue
                continue;
                                }
                                let index = errorDataRow.indexOf(ress[i].substr(7).substring(1, 2));
              let index = errorDataRow.indexOf(
                ress[i].substr(7).substring(1, 2)
              );
                                if (index == -1) {
                                    errorData.errorRow = ress[i].substr(7).substring(1, 2);
                                    errorDataRow.push(errorData.errorRow);
                                    errorData.errorInfo = ress[i].substr(7).substring(5).replace('=','');
                errorData.errorInfo = ress[i]
                  .substr(7)
                  .substring(5)
                  .replace("=", "");
                                    errorDatas.push(errorData);
                                } else {
                                    errorDatas[index].errorInfo += '; ' + ress[i].substr(7).substring(5);
                errorDatas[index].errorInfo +=
                  "; " + ress[i].substr(7).substring(5);
                                }
                            }
                        }
                        var fileContentData = component.get("v.fileContentData").split('\n');
          var fileContentData = component.get("v.fileContentData").split("\n");
                        let errorColumns = [
                            { label: '错误行', fieldName: 'errorRow', type: 'text', hideDefaultActions: true, initialWidth: 100 },
                            { label: '错误信息', fieldName: 'errorInfo', type: 'text', hideDefaultActions: true, initialWidth: 300, wrapText: true }
            {
              label: "错误行",
              fieldName: "errorRow",
              type: "text",
              hideDefaultActions: true,
              initialWidth: 100
            },
            {
              label: "错误信息",
              fieldName: "errorInfo",
              type: "text",
              hideDefaultActions: true,
              initialWidth: 300,
              wrapText: true
            }
                        ];
                        for (var i = 0; i < fileContentData[0].split(',').length; i++) {
          for (var i = 0; i < fileContentData[0].split(",").length; i++) {
                            errorColumns.push({
                                label: fileContentData[0].split(',')[i],
                                fieldName: 'field' + i,
                                type: 'text',
              label: fileContentData[0].split(",")[i],
              fieldName: "field" + i,
              type: "text",
                                hideDefaultActions: true, 
                                wrapText: true,
                                initialWidth: 120
@@ -2097,116 +2553,132 @@
                        for (var i = 0; i < errorDatas.length; i++) {
                            let data = fileContentData[errorDatas[i].errorRow];
                            console.log('data = ' + JSON.stringify(data));
            console.log("data = " + JSON.stringify(data));
                            if(data){
                                for (var j = 0; j < data.split(',').length; j++) {
                                    let label = 'field' + j;
                                    errorDatas[i][label] = data.split(',')[j];
              for (var j = 0; j < data.split(",").length; j++) {
                let label = "field" + j;
                errorDatas[i][label] = data.split(",")[j];
                                }
                            }
                        }
                        component.set('v.errorColumns', errorColumns);
                        component.set('v.errorData', errorDatas);
          component.set("v.errorColumns", errorColumns);
          component.set("v.errorData", errorDatas);
                        component.set("v.showErrorInfo", true);
                        console.log("=="+res1);
                        this.error(res1+"请修改后重新上传");
                        component.set('v.login',false);
          component.set("v.login", false);
                    }else{
                        component.set("v.showMain",true);
                        this.success("导入成功");
                        // alert('saved successfully');
                        component.set('v.login',false);
          component.set("v.login", false);
                    }
                }
                else if (state === "INCOMPLETE") {
      } else if (state === "INCOMPLETE") {
                    // do something
                    component.set('v.login',false);
                }
                else if (state === "ERROR") {
        component.set("v.login", false);
      } else if (state === "ERROR") {
                    var errors = response.getError();
                    if (errors) {
                        if (errors[0] && errors[0].message) {
                            console.log("Error message: " +
                                    errors[0].message);
                            component.set('v.login',false);
            console.log("Error message: " + errors[0].message);
            component.set("v.login", false);
                        }
                    } else {
                        console.log("Unknown error");
                        component.set('v.login',false);
          component.set("v.login", false);
                    }
                }
        });    
        $A.enqueueAction(actionss);
    },saveRecordsEditFile : function(component,dataMap,searchData,helper){
  },
  saveRecordsEditFile: function (component, dataMap, searchData, helper) {
        var searchDataMap = new Map();
         for (var i = 0; i < searchData.length; i++) {
         var sd = searchData[i];
         if(sd.name)
         searchDataMap.set(sd.name.replace(' ',''),sd.dataId);
      if (sd.name) searchDataMap.set(sd.name.replace(" ", ""), sd.dataId);
         }
         console.log('searchDataMap='+searchDataMap);
         var error = '';
    console.log("searchDataMap=" + searchDataMap);
    var error = "";
         var fileData = component.get("v.fileContentData");
         var files = fileData.split('\n');
    var files = fileData.split("\n");
         var fileStr = files[0];
         fileStr += '\n';
    fileStr += "\n";
       for (var i = 1; i < files.length-1; i++) {
         var filelist = files[i].split(',');
      var filelist = files[i].split(",");
         var fileName = filelist[4];
         if (searchDataMap.get(fileName.replace(' ',''))) {
                 var nameDataId = searchDataMap.get(fileName.replace(' ',''));
      if (searchDataMap.get(fileName.replace(" ", ""))) {
        var nameDataId = searchDataMap.get(fileName.replace(" ", ""));
                if (dataMap.get(nameDataId)) {
                     filelist[4] = dataMap.get(nameDataId);     //zhj 新方案改造 filelist[4]不再存的nameEncrpt 2022-12-21
                }else {
                     error += 'error1 第'+i+'行数据拜访人SF不存在';
                     error += '=';
          error += "error1 第" + i + "行数据拜访人SF不存在";
          error += "=";
                }
            }else {
                 error += 'error1 第'+i+'行数据拜访人AWS不存在';
                 error += '=';
        error += "error1 第" + i + "行数据拜访人AWS不存在";
        error += "=";
            }
            fileStr += filelist.toString();
             fileStr += '\n';
      fileStr += "\n";
        }
        if (error != '') {
            console.log('zhj error = ' + error);
            let errorArray = error.split('error1');
    if (error != "") {
      console.log("zhj error = " + error);
      let errorArray = error.split("error1");
            let errorDatas = [];
            let errorDataRow = [];
            debugger
            console.log('errorArray = ' + JSON.stringify(errorArray))
      debugger;
      console.log("errorArray = " + JSON.stringify(errorArray));
            for (var i in errorArray) {
                if (errorArray[i] != '') {
                    let errorData = {}
        if (errorArray[i] != "") {
          let errorData = {};
                    if(!this.isNumber(errorArray[i].trim().substring(1, 2))){
                        continue
            continue;
                    }
                    let index = errorDataRow.indexOf(errorArray[i].trim().substring(1, 2));
          let index = errorDataRow.indexOf(
            errorArray[i].trim().substring(1, 2)
          );
                    if (index == -1) {
                        errorData.errorRow = errorArray[i].trim().substring(1, 2);
                        errorDataRow.push(errorData.errorRow);
                        errorData.errorInfo = errorArray[i].trim().substring(5,errorArray[i].trim().length).replace('=','');
            errorData.errorInfo = errorArray[i]
              .trim()
              .substring(5, errorArray[i].trim().length)
              .replace("=", "");
                        errorDatas.push(errorData);
                    } else {
                        errorDatas[index].errorInfo += '; ' + errorArray[i].trim().substring(5,errorArray[i].trim().length);
            errorDatas[index].errorInfo +=
              "; " +
              errorArray[i].trim().substring(5, errorArray[i].trim().length);
                    }
                }
            }
            var fileContentData = component.get("v.fileContentData").split('\n');
      var fileContentData = component.get("v.fileContentData").split("\n");
            let errorColumns = [
                { label: '错误行', fieldName: 'errorRow', type: 'text', hideDefaultActions: true, initialWidth: 100 },
                { label: '错误信息', fieldName: 'errorInfo', type: 'text', hideDefaultActions: true, initialWidth: 300, wrapText: true }
        {
          label: "错误行",
          fieldName: "errorRow",
          type: "text",
          hideDefaultActions: true,
          initialWidth: 100
        },
        {
          label: "错误信息",
          fieldName: "errorInfo",
          type: "text",
          hideDefaultActions: true,
          initialWidth: 300,
          wrapText: true
        }
            ];
            for (var i = 0; i < fileContentData[0].split(',').length; i++) {
      for (var i = 0; i < fileContentData[0].split(",").length; i++) {
                errorColumns.push({
                    label: fileContentData[0].split(',')[i],
                    fieldName: 'field' + i,
                    type: 'text',
          label: fileContentData[0].split(",")[i],
          fieldName: "field" + i,
          type: "text",
                    hideDefaultActions: true, 
                    wrapText: true,
                    initialWidth: 120
@@ -2215,46 +2687,71 @@
            for (var i = 0; i < errorDatas.length; i++) {
                let data = fileContentData[errorDatas[i].errorRow];
                console.log('data = ' + JSON.stringify(data));
                for (var j = 0; j < data.split(',').length; j++) {
                    let label = 'field' + j;
                    errorDatas[i][label] = data.split(',')[j];
        console.log("data = " + JSON.stringify(data));
        for (var j = 0; j < data.split(",").length; j++) {
          let label = "field" + j;
          errorDatas[i][label] = data.split(",")[j];
                }
            }
            console.log('errorDatas =' + JSON.stringify(errorDatas))
            component.set('v.errorColumns', errorColumns);
            component.set('v.errorData', errorDatas);
      console.log("errorDatas =" + JSON.stringify(errorDatas));
      component.set("v.errorColumns", errorColumns);
      component.set("v.errorData", errorDatas);
            component.set("v.showErrorInfo", true);
            console.log('error = ' + error);
            component.set('v.errorMessage', error);
      console.log("error = " + error);
      component.set("v.errorMessage", error);
            this.error(error);
            console.log('error='+error);
            component.set('v.login',false);
      console.log("error=" + error);
      component.set("v.login", false);
            return;
         }
         console.log('fileStr='+fileStr);
    console.log("fileStr=" + fileStr);
         $A.getCallback(function(){
             debugger
      debugger;
             helper.ImportMethod(component,fileStr);
         })();
     },
    convertArrayOfObjectsToCSV : function(component,objectRecords){
        var csvStringResult, counter, keys, columnDivider, lineDivider,thkeys;
        if (objectRecords == null || !objectRecords.length) {
            return null;
         }
        columnDivider = ',';
        lineDivider =  '\n';
    columnDivider = ",";
    lineDivider = "\n";
        //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start ,'SupportNeeds__c'  ,'支援需求'
        keys = ['Submit_date__c','Person_In_Charge2__c','Report_Date__c','Agency_Hospital__c','Department_Cateogy__c','doctor2__c','visitor_title__c','Product_Category1__c','Product_Category2__c','Product_Category3__c','Purpose_Type__c','Result__c','SupportNeeds__c'];
        thkeys = ['周','担当','活动日','医院','科室','拜访人','职位','产品区分1','产品区分2','产品区分3','活动区分','结果','支援需求']
        csvStringResult = '';
    keys = [
      "Submit_date__c",
      "Person_In_Charge2__c",
      "Report_Date__c",
      "Agency_Hospital__c",
      "Department_Cateogy__c",
      "doctor2__c",
      "visitor_title__c",
      "Product_Category1__c",
      "Product_Category2__c",
      "Product_Category3__c",
      "Purpose_Type__c",
      "Result__c",
      "SupportNeeds__c"
    ];
    thkeys = [
      "周",
      "担当",
      "活动日",
      "医院",
      "科室",
      "拜访人",
      "职位",
      "产品区分1",
      "产品区分2",
      "产品区分3",
      "活动区分",
      "结果",
      "支援需求"
    ];
    csvStringResult = "";
        csvStringResult += thkeys.join(columnDivider);
        csvStringResult += lineDivider;
        console.log("进入导出helper");
@@ -2266,30 +2763,33 @@
                    csvStringResult += columnDivider; 
                }
                if(typeof objectRecords[i][skey] === "undefined"){
                    csvStringResult += '"'+''+'"';
          csvStringResult += '"' + "" + '"';
                    continue;
                }   
                if(skey == 'Person_In_Charge2__c'){
                    csvStringResult += '"'+ objectRecords[i].Person_In_Charge2__r.Name+'"';
                }else if(skey == 'Agency_Hospital__c'){
                    csvStringResult += '"'+ objectRecords[i].Agency_Hospital__r.Name+'"';
                }else if(skey == 'doctor2__c'){
        if (skey == "Person_In_Charge2__c") {
          csvStringResult +=
            '"' + objectRecords[i].Person_In_Charge2__r.Name + '"';
        } else if (skey == "Agency_Hospital__c") {
          csvStringResult +=
            '"' + objectRecords[i].Agency_Hospital__r.Name + '"';
        } else if (skey == "doctor2__c") {
                    csvStringResult += '"'+ objectRecords[i].doctor2__r.Name+'"';
                }else if(skey == 'Product_Category1__c'){
                    csvStringResult += '"'+ objectRecords[i].Product_Category1__r.Name+'"';
                }else if(skey == 'Product_Category2__c'){
                    csvStringResult += '"'+ objectRecords[i].Product_Category2__r.Name+'"';
                }else if(skey == 'Product_Category3__c'){
                    csvStringResult += '"'+ objectRecords[i].Product_Category3__r.Name+'"';
                }
                else if(skey == 'SupportNeeds__c'){//SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start
        } else if (skey == "Product_Category1__c") {
          csvStringResult +=
            '"' + objectRecords[i].Product_Category1__r.Name + '"';
        } else if (skey == "Product_Category2__c") {
          csvStringResult +=
            '"' + objectRecords[i].Product_Category2__r.Name + '"';
        } else if (skey == "Product_Category3__c") {
          csvStringResult +=
            '"' + objectRecords[i].Product_Category3__r.Name + '"';
        } else if (skey == "SupportNeeds__c") {
          //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start
                    csvStringResult += '"'+ objectRecords[i].SupportNeeds__c+'"';
                }
                else{
        } else {
                    csvStringResult += '"'+ objectRecords[i][skey]+'"';
                }
                counter++;
            } // inner for loop close    
            console.log("导出循环结束");
            csvStringResult += lineDivider;
@@ -2299,89 +2799,130 @@
        return csvStringResult;        
    },
    showExportDate : function(component,objectRecords){
        console.log('进入showexceportdate'+objectRecords);//SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start  ,'SupportNeeds__c' ,'支援需求'
        var keys = ['Submit_date__c','Person_In_Charge2__c','Report_Date__c','Agency_Hospital__c','Department_Cateogy__c','doctor2__c','visitor_title__c','Product_Category1__c','Product_Category2__c','Product_Category3__c','Purpose_Type__c','Result__c','SupportNeeds__c'];
        var headers = ['周','担当','活动日','医院','科室','拜访人','职位','产品区分1','产品区分2','产品区分3','活动区分','结果','支援需求']
        var content = "<table class=\"table slds-table slds-table--bordered slds-table--cell-buffer\">";
        content += "<thead><tr class=\"slds-text-title--caps\">";
    console.log("进入showexceportdate" + objectRecords); //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start  ,'SupportNeeds__c' ,'支援需求'
    var keys = [
      "Submit_date__c",
      "Person_In_Charge2__c",
      "Report_Date__c",
      "Agency_Hospital__c",
      "Department_Cateogy__c",
      "doctor2__c",
      "visitor_title__c",
      "Product_Category1__c",
      "Product_Category2__c",
      "Product_Category3__c",
      "Purpose_Type__c",
      "Result__c",
      "SupportNeeds__c"
    ];
    var headers = [
      "周",
      "担当",
      "活动日",
      "医院",
      "科室",
      "拜访人",
      "职位",
      "产品区分1",
      "产品区分2",
      "产品区分3",
      "活动区分",
      "结果",
      "支援需求"
    ];
    var content =
      '<table class="table slds-table slds-table--bordered slds-table--cell-buffer">';
    content += '<thead><tr class="slds-text-title--caps">';
        for(i=0;i<headers.length; i++){
            content += '<th scope=\"col"\>'+headers[i]+'</th>';
      content += '<th scope="col">' + headers[i] + "</th>";
        }
        content += "</tr></thead>";
        for(var i=0; i < objectRecords.length; i++){
            console.log('for'+content);
            content += '<tr>';
      console.log("for" + content);
      content += "<tr>";
            // content += '<td>'+(i+1)+'</td>';
            for(var sTempkey in keys) {
                console.log('for1'+sTempkey);
        console.log("for1" + sTempkey);
                var skey = keys[sTempkey];
                if(typeof objectRecords[i][skey] === "undefined"){
                    content += '<td>'+''+'</td>';
          content += "<td>" + "" + "</td>";
                    continue;
                }
                console.log('for2'+objectRecords[i].Person_In_Charge2__r.Name);
                if(skey == 'Person_In_Charge2__c'){
                    content += '<td>'+ objectRecords[i].Person_In_Charge2__r.Name+'</td>';
                }else if(skey == 'Agency_Hospital__c'){
                    content += '<td>'+ objectRecords[i].Agency_Hospital__r.Name+'</td>';
                }else if(skey == 'doctor2__c'){
                    content += '<td>'+ objectRecords[i].doctor2__r.Name+'</td>';
                }else if(skey == 'Product_Category1__c'){
                    content += '<td>'+ objectRecords[i].Product_Category1__r.Name+'</td>';
                }else if(skey == 'Product_Category2__c'){
                    content += '<td>'+ objectRecords[i].Product_Category2__r.Name+'</td>';
                }else if(skey == 'Product_Category3__c'){
                    content += '<td>'+ objectRecords[i].Product_Category3__r.Name+'</td>';
                }
                else if(skey == 'SupportNeeds__c'){//SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start
                    content += '<td>'+ objectRecords[i].SupportNeeds__c+'</td>';
                }
                else{
                    content += '<td>'+ objectRecords[i][skey]+'</td>';
        console.log("for2" + objectRecords[i].Person_In_Charge2__r.Name);
        if (skey == "Person_In_Charge2__c") {
          content +=
            "<td>" + objectRecords[i].Person_In_Charge2__r.Name + "</td>";
        } else if (skey == "Agency_Hospital__c") {
          content +=
            "<td>" + objectRecords[i].Agency_Hospital__r.Name + "</td>";
        } else if (skey == "doctor2__c") {
          content += "<td>" + objectRecords[i].doctor2__r.Name + "</td>";
        } else if (skey == "Product_Category1__c") {
          content +=
            "<td>" + objectRecords[i].Product_Category1__r.Name + "</td>";
        } else if (skey == "Product_Category2__c") {
          content +=
            "<td>" + objectRecords[i].Product_Category2__r.Name + "</td>";
        } else if (skey == "Product_Category3__c") {
          content +=
            "<td>" + objectRecords[i].Product_Category3__r.Name + "</td>";
        } else if (skey == "SupportNeeds__c") {
          //SWAG-CBX68C fy 【委托】DAMS系统周报模块内容需求增加 start
          content += "<td>" + objectRecords[i].SupportNeeds__c + "</td>";
        } else {
          content += "<td>" + objectRecords[i][skey] + "</td>";
                }
            } // inner for loop close     
            content += '</tr>'
      content += "</tr>";
        }// outer main for loop close 
        content += '</table>';
    content += "</table>";
        console.log("helper循环结束"+content);
        component.set("v.TableContent2",content);
        component.set("v.showMain",false);
    },
    select_repores_date : function(component,event,helper){
        component.set('v.login',true);
        var reportsdate1 = component.find('input-report-date1').get('v.value');
        var reportsdate2 = component.find('input-report-date2').get('v.value');
        console.log('输入的开始日期'+reportsdate1+'输入的结束日期'+reportsdate2);
    component.set("v.login", true);
    var reportsdate1 = component.find("input-report-date1").get("v.value");
    var reportsdate2 = component.find("input-report-date2").get("v.value");
    console.log(
      "输入的开始日期" + reportsdate1 + "输入的结束日期" + reportsdate2
    );
        var action = component.get("c.getReportsByDate");
        console.log('输入的开始日期1');
    console.log("输入的开始日期1");
        action.setParams({ 
            date1 : reportsdate1,
            date2: reportsdate2
        });
        console.log('输入的开始日期2');
    console.log("输入的开始日期2");
        action.setCallback(this, function(response) {
            var state = response.getState();
            if (state === "SUCCESS") {
                var res = response.getReturnValue();
                console.log('输入的开始日期3'+res);
                component.set('v.login',false);
        console.log("输入的开始日期3" + res);
        component.set("v.login", false);
                // PI 改造 By Bright 20220328
                if(true){
                    let awsids = [];
                    for (let ri in res) {
                        if(res[ri] && res[ri].doctor2__r && res[ri].doctor2__r.AWS_Data_Id__c){
            if (
              res[ri] &&
              res[ri].doctor2__r &&
              res[ri].doctor2__r.AWS_Data_Id__c
            ) {
                            awsids.push(res[ri].doctor2__r.AWS_Data_Id__c);
                        }
                    }                    
                    if(awsids.length > 0){
                        let awsurl = component.get('v.awsurl');
            let awsurl = component.get("v.awsurl");
                        
                        AWSService.search(awsurl.searchUrl,{
            AWSService.search(
              awsurl.searchUrl,
              {
                            dataIds:awsids
                        }, function(data){
              },
              function (data) {
                            if(data && data.object && data.object.length){
                                let m = {};
                                for(let di in data.object){
@@ -2391,67 +2932,74 @@
                                }
                                
                                for(let ri in res){
                                    if(res[ri] && res[ri].doctor2__r && res[ri].doctor2__r.AWS_Data_Id__c && m.hasOwnProperty(res[ri].doctor2__r.AWS_Data_Id__c)){
                                        res[ri].doctor2__r.Name = m[res[ri].doctor2__r.AWS_Data_Id__c].name;
                                        res[ri].visitor_title__c = m[res[ri].doctor2__r.AWS_Data_Id__c].doctorDivision1;
                    if (
                      res[ri] &&
                      res[ri].doctor2__r &&
                      res[ri].doctor2__r.AWS_Data_Id__c &&
                      m.hasOwnProperty(res[ri].doctor2__r.AWS_Data_Id__c)
                    ) {
                      res[ri].doctor2__r.Name =
                        m[res[ri].doctor2__r.AWS_Data_Id__c].name;
                      res[ri].visitor_title__c =
                        m[res[ri].doctor2__r.AWS_Data_Id__c].doctorDivision1;
                                    }
                                }
                            }
                            helper.showExportDate(component, res);
                            
                            component.set('v.login', false);
                        }, awsurl.token);
                component.set("v.login", false);
              },
              awsurl.token
            );
                    }else{
                        helper.showExportDate(component, res);
                    }
                }
                
                component.set('v.reports_date', res);
        component.set("v.reports_date", res);
            }else{
                alert('导出失败,请检查活动日');
                component.set('v.login',false);
        alert("导出失败,请检查活动日");
        component.set("v.login", false);
            }
        });
        $A.enqueueAction(action);
    },
    showImport : function(component){
        // console.log('进入');
        // component.find('file').click();
        var modalimport = component.find('modal_import');
        var modalimportbg = component.find('modal_importbg');
        $A.util.removeClass(modalimport, 'disp_none');
        $A.util.removeClass(modalimportbg,'disp_none');
    var modalimport = component.find("modal_import");
    var modalimportbg = component.find("modal_importbg");
    $A.util.removeClass(modalimport, "disp_none");
    $A.util.removeClass(modalimportbg, "disp_none");
    },
    showExport : function(component) {
        var modalimport = component.find('modal_export');
        var modalimportbg = component.find('modal_exportbg');
        $A.util.removeClass(modalimport, 'disp_none');
        $A.util.removeClass(modalimportbg,'disp_none');
    var modalimport = component.find("modal_export");
    var modalimportbg = component.find("modal_exportbg");
    $A.util.removeClass(modalimport, "disp_none");
    $A.util.removeClass(modalimportbg, "disp_none");
    },
    close_import : function(component){
        var modalimport = component.find('modal_import');
        var modalimportbg = component.find('modal_importbg');
        $A.util.addClass(modalimport, 'disp_none');
        $A.util.addClass(modalimportbg,'disp_none');
    var modalimport = component.find("modal_import");
    var modalimportbg = component.find("modal_importbg");
    $A.util.addClass(modalimport, "disp_none");
    $A.util.addClass(modalimportbg, "disp_none");
    },
    close_export : function(component){
        var modalimport = component.find('modal_export');
        var modalimportbg = component.find('modal_exportbg');
        $A.util.addClass(modalimport, 'disp_none');
        $A.util.addClass(modalimportbg,'disp_none');
    var modalimport = component.find("modal_export");
    var modalimportbg = component.find("modal_exportbg");
    $A.util.addClass(modalimport, "disp_none");
    $A.util.addClass(modalimportbg, "disp_none");
    },
    //zhj MEBG新方案改造 2022-11-29 start
    CallBackAction  : function(component,action_name,para,callback) {
        var action = component.get("c." + action_name.trimStart().replace("c.",""));
    var action = component.get(
      "c." + action_name.trimStart().replace("c.", "")
    );
        if(para){
            action.setParams(para);
        }
@@ -2467,8 +3015,8 @@
    //zhj 导出错误信息 2023-05-16 start
    exportErrorInfoHelper: function (component) {
        var errorData = component.get('v.errorData');
        var errorColumns = component.get('v.errorColumns');
    var errorData = component.get("v.errorData");
    var errorColumns = component.get("v.errorColumns");
        var datas = [];
        let errorColumnsArray = [];
@@ -2480,54 +3028,58 @@
        for (var i in errorData) {
            let data = [];
            data.push(errorData[i].errorRow)
            data.push(errorData[i].errorInfo)
      data.push(errorData[i].errorRow);
      data.push(errorData[i].errorInfo);
            for(var j = 0 ; j < Object.keys(errorData[i]).length - 2 ; j++){
                data.push(errorData[i]['field' + j])
        data.push(errorData[i]["field" + j]);
            }
            datas.push(data);
        }
        console.log('datas = ' + JSON.stringify(datas));
    console.log("datas = " + JSON.stringify(datas));
        var csv = this.convertToCSV(component, datas);
        console.log('csv = ' + JSON.stringify(csv))
    console.log("csv = " + JSON.stringify(csv));
        this.downloadCSV(component, csv);
    },
    convertToCSV: function (component, data) {
        console.log('enter convertToCSV')
        console.log('data = ' + data);
        var csv = '';
    console.log("enter convertToCSV");
    console.log("data = " + data);
    var csv = "";
        for (var i = 0; i < data.length; i++) {
            var row = data[i];
            console.log('row = ' + JSON.stringify(row));
      console.log("row = " + JSON.stringify(row));
            for (var j = 0; j < row.length; j++) {
                var val = '';
                val = row[j] === null ? '' : row[j].toString();
                console.log('val = ' + val);
                if (val.indexOf(',') !== -1 || val.indexOf('"') !== -1 || val.indexOf('\n') !== -1) {
        var val = "";
        val = row[j] === null ? "" : row[j].toString();
        console.log("val = " + val);
        if (
          val.indexOf(",") !== -1 ||
          val.indexOf('"') !== -1 ||
          val.indexOf("\n") !== -1
        ) {
                    //val = '"' + val.replace(/"/g,'""') + '"';
                }
                if (j > 0) {
                    csv += ',';
          csv += ",";
                }
                csv += val;
            }
            csv += '\n';
      csv += "\n";
        }
        return csv;
    },
    downloadCSV: function (component, csv) {
        var link = document.createElement('a');
    var link = document.createElement("a");
        // 设置字符集和文件头
        var bom = "\uFEFF";
        link.href = 'data:text/csv;charset=utf-8,' + encodeURIComponent(bom + csv);
        link.download = 'data.csv';
    link.href = "data:text/csv;charset=utf-8," + encodeURIComponent(bom + csv);
    link.download = "data.csv";
        document.body.appendChild(link);
        link.click();
        document.body.removeChild(link);
    },
  }
    //zhj 导出错误信息 2023-05-16 end
    // searchAgencyContact : function(res) {
@@ -2564,4 +3116,4 @@
    //     var data = this.search(searchUrl,data,token);
    //     return data;searchUrl,requestSearchPayload,token
    // },
})
});
force-app/main/default/classes/WeeklyReportCmp.cls
@@ -1,12 +1,19 @@
public with sharing class WeeklyReportCmp {
    @AuraEnabled public List<Agency_Report__c> reports{get;set;}
    @AuraEnabled public Map<String,List<Map<String,String>>> allselectlist{get;set;}
    @AuraEnabled public Map<String,String> fieldsMap{get;set;}
    @AuraEnabled public Map<String,List<Map<String,String>>> docmap{get;set;}
    @AuraEnabled public List<Map<String,String>> doctorList{get;set;}
  @AuraEnabled
  public List<Agency_Report__c> reports { get; set; }
  @AuraEnabled
  public Map<String, List<Map<String, String>>> allselectlist { get; set; }
  @AuraEnabled
  public Map<String, String> fieldsMap { get; set; }
  @AuraEnabled
  public Map<String, List<Map<String, String>>> docmap { get; set; }
  @AuraEnabled
  public List<Map<String, String>> doctorList { get; set; }
    // PIPL update Yin Mingjie 21/02/2022 start
    @AuraEnabled public Map<String,String> awsurl{get;set;}
    @AuraEnabled public Map<String,String> contactawsurl{get;set;}
  @AuraEnabled
  public Map<String, String> awsurl { get; set; }
  @AuraEnabled
  public Map<String, String> contactawsurl { get; set; }
    // PIPL update Yin Mingjie 21/02/2022 end
    public WeeklyReportCmp() {
    }
@@ -47,8 +54,13 @@
    //zhj 新方案改造 2022-12-21 start
    @RemoteAction
    @AuraEnabled
    public static Map<String, String> saveAgencyContact(String name, String type, String doctorDivision1,
        String agencyHospitalid, String awsid) {
  public static Map<String, String> saveAgencyContact(
    String name,
    String type,
    String doctorDivision1,
    String agencyHospitalid,
    String awsid
  ) {
        Agency_Contact__c agency_contact = new Agency_Contact__c();
        agency_contact.Name = name;
@@ -66,12 +78,26 @@
    // PIPL update Yin Mingjie 21/02/2022 end
    @RemoteAction
    @AuraEnabled
    public static List<Map<String,String>> getProductList(String dc, String opdsis){
  public static List<Map<String, String>> getProductList(
    String dc,
    String opdsis
  ) {
        List<ProductTypes__c> 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];
      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];
      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<Map<String,String>> pts = new List<Map<String,String>>();
        Map<String,String> blank = new Map<String,String>();
@@ -87,8 +113,7 @@
        return pts;
    }
    
    public void setalldata()
    {
  public void setalldata() {
        /*** create allselectlist ***/
        this.allselectlist = new Map<String,List<Map<String,String>>>();
@@ -138,19 +163,37 @@
        */
        
        // 科室分类 Department_Cateogy__c 
        this.allselectlist.put('Department_Cateogy__c', WeeklyReportCmp.getPicklistValues('Agency_Report__c','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'));
    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'));
    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'));
    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'));
    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'));
@@ -179,8 +222,10 @@
        this.contactawsurl = getAwsurl('Contact');// 20220222 PI改造 by Bright
    }
    
    public static List<Map<String,String>> getPicklistValues(String objstr, String fld){
  public static List<Map<String, String>> getPicklistValues(
    String objstr,
    String fld
  ) {
        List<Map<String,String>> options = new List<Map<String,String>>();
        Map<String,String> space = new Map<String,String>();
        space.put('label', '');
@@ -191,11 +236,13 @@
        Schema.sObjectType objType = Schema.getGlobalDescribe().get(objstr);
        Schema.DescribeSObjectResult objDescribe = objType.getDescribe();
        map<String, Schema.SObjectField> fieldMap = objDescribe.fields.getMap();
        list<Schema.PicklistEntry> values = fieldMap.get(fld).getDescribe().getPickListValues();
    list<Schema.PicklistEntry> values = fieldMap.get(fld)
      .getDescribe()
      .getPickListValues();
        system.debug(objstr + '=' + values);
        for (Schema.PicklistEntry a : values)
        {
            if (!a.isActive()) continue;
    for (Schema.PicklistEntry a : values) {
      if (!a.isActive())
        continue;
            Map<String,String> ses = new Map<String,String>();
            ses.put('label', a.getLabel());
            ses.put('value', a.getValue());
@@ -205,16 +252,17 @@
        return options;
    }
    
    public  Map<String,String> getfiledsmap()
    {
  public Map<String, String> getfiledsmap() {
        Map<String,Schema.SObjectType> schemaMap = Schema.getGlobalDescribe();
        Map<String,List<String>>   typemap = new Map<String,List<String>>  ();
        
        Map<String,Schema.SObjectField> fieldMap = schemaMap.get('Agency_Opportunity__c').getDescribe().fields.getMap();
    Map<String, Schema.SObjectField> fieldMap = schemaMap.get(
        'Agency_Opportunity__c'
      )
      .getDescribe()
      .fields.getMap();
        Map<String,String> mappingmap = new Map<String,String>();
        for(Schema.SObjectField sfield : fieldMap.Values())
        {
    for (Schema.SObjectField sfield : fieldMap.Values()) {
            Schema.describefieldresult dfield = sfield.getDescribe();
            String lab = '';
            lab = dfield.getLabel();
@@ -222,8 +270,7 @@
            mappingmap.put(dfield.name,lab);
        }
        fieldMap = schemaMap.get('Agency_Report__c').getDescribe().fields.getMap();
        for(Schema.SObjectField sfield : fieldMap.Values())
        {
    for (Schema.SObjectField sfield : fieldMap.Values()) {
            Schema.describefieldresult dfield = sfield.getDescribe();
            String lab = '';
            lab = dfield.getLabel();
@@ -244,19 +291,39 @@
    @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];
    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);
  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);
        system.debug('report Id:'+);
    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){
  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 + ')';
@@ -266,10 +333,16 @@
        // READ OlympusCalendar__c
        system.debug(week);
        OlympusCalendar__c olympus_calendar = [select Id,Date__c from OlympusCalendar__c where Date__c=: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; }
    if (olympus_calendar_id != '') {
      agency_report_header.OlympusDate__c = olympus_calendar_id;
    }
        system.debug(agency_report_header);
        return agency_report_header;
@@ -277,10 +350,18 @@
    
    @RemoteAction
    @AuraEnabled
    public static List<Agency_Hospital_Link__c> getHospitalList(String hospital_name) {
  public static List<Agency_Hospital_Link__c> getHospitalList(
    String hospital_name
  ) {
        hospital_name = '%' + hospital_name.trim() + '%'; 
        system.debug('hospital_name+++'+hospital_name);
        List<Agency_Hospital_Link__c> 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];
    List<Agency_Hospital_Link__c> 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;
    }
@@ -288,7 +369,9 @@
    @RemoteAction
    @AuraEnabled
    // PIPL update Yin Mingjie 21/02/2022 start
    public static Map<String,Map<String,String>> getDoctorList(String hospital_id){
  public static Map<String, Map<String, String>> getDoctorList(
    String hospital_id
  ) {
    /*
    public static List<Map<String,String>> getDoctorList(String hospital_id){
        List<Map<String,String>> ret = new List<Map<String,String>>();
@@ -301,7 +384,11 @@
    // 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];
    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
        /*
@@ -319,12 +406,21 @@
            ret.add(tmp);
        }
        */
        List<Agency_Contact__c> 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];
    List<Agency_Contact__c> 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<String,Map<String,String>> ret_test = new Map<String,Map<String,String>>();
        for (Agency_Contact__c row : doctor_list)
        {
    for (Agency_Contact__c row : doctor_list) {
            if(row.AWS_Data_Id__c == '' || row.AWS_Data_Id__c == null){
                continue;
            }
@@ -336,7 +432,9 @@
            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');
    PIHelper.PIIntegration piIntegration = PIHelper.getPIIntegrationInfo(
      'Agency_Contact__c'
    );
        Map<String, String> sre = new Map<String, String>();
        sre.put('token', piIntegration.token);
        sre.put('searchUrl', piIntegration.searchUrl);
@@ -395,24 +493,70 @@
    @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);
  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)
    {
  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;
@@ -437,23 +581,54 @@
        //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; }
    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; }
    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 (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 (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 != '' ||
        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;
                }
@@ -479,11 +654,27 @@
    @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)
    {
  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
@@ -493,14 +684,44 @@
        Agency_Report__c agency_report = new Agency_Report__c();
        if(Test.isRunningTest()){
            List<Agency_Report__c> 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];
      List<Agency_Report__c> 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];
      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);
@@ -522,22 +743,67 @@
        }
        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; }
    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 (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 (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 != '' ||
        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;
                }
@@ -555,7 +821,9 @@
                }
                update aopp;
            }
        } else { agency_report.Opportunity__c = null; }
    } else {
      agency_report.Opportunity__c = null;
    }
        system.debug(agency_report);
        
        agency_report = LightningUtil.updateAgencyReport(agency_report);
@@ -565,10 +833,16 @@
    
    @RemoteAction
    @AuraEnabled
    public static List<Agency_Opportunity__c> selectOpportunityByIdAndHospitalLinkId(String opportunity_id, String agency_hospital_link_id) {
  public static List<Agency_Opportunity__c> selectOpportunityByIdAndHospitalLinkId(
    String opportunity_id,
    String agency_hospital_link_id
  ) {
        List<Agency_Opportunity__c> ret = new List<Agency_Opportunity__c>();
        
        ret = LightningUtil.selectOpportunityByIdAndHospitalLinkId(opportunity_id, agency_hospital_link_id);
    ret = LightningUtil.selectOpportunityByIdAndHospitalLinkId(
      opportunity_id,
      agency_hospital_link_id
    );
        
        return ret;
    }
@@ -600,7 +874,10 @@
    // 批量添加周报by vivek start
    @RemoteAction
    @AuraEnabled
    public static List<Agency_Report__c> getReportsByDate(String date1, String date2) {
  public static List<Agency_Report__c> getReportsByDate(
    String date1,
    String date2
  ) {
        Date date1_date = Date.valueOf(date1);
        Date date2_date = Date.valueOf(date2);
        WeeklyReportCmp li = new WeeklyReportCmp();
@@ -623,7 +900,7 @@
        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];
    return [SELECT id, Name, Agency_User__c FROM contact];
    }
    // fy 导入 20220424 start
    public class GeDatass {
@@ -644,7 +921,7 @@
       // 创建周报
       try{
            if(fileData!=null){ 
                String[] fileLines = new String[]{};
        String[] fileLines = new List<String>{};
                fileLines = fileData.split('\n');
              
                // 经销商医院名称list
@@ -664,22 +941,36 @@
                // 经销商医院的ocsm医院id的list
                List<String> ahlOcsmIdList = new List<String>();
                System.debug('ahlNameList = ' + ahlNameList);
                List<Agency_Hospital_Link__c> ahlList = [select id,name,Hospital__c,MaxActivityDate__c from Agency_Hospital_Link__c where name = :ahlNameList and Agency_Campaign_Obj__c = true];
        List<Agency_Hospital_Link__c> ahlList = [
          SELECT id, name, Hospital__c, MaxActivityDate__c
          FROM Agency_Hospital_Link__c
          WHERE name = :ahlNameList AND Agency_Campaign_Obj__c = TRUE
        ];
                
                System.debug('ahlList.size() = ' + ahlList.size());
                for(Agency_Hospital_Link__c ahl : ahlList){
                    ahlOcsmIdList.add(ahl.Hospital__c);
                }
                List<Agency_Contact__c> doctor2list = new List<Agency_Contact__c>();
                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
          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('doctor2list = ' + doctor2list);
        System.debug('doctor2listStr = ' + doctor2listStr);
                return doctor2listStr;  
            }
        }catch(Exception e){
@@ -691,7 +982,11 @@
    // fy 导入 20220424 end
    @AuraEnabled// fy 导入 20220424  start  String sobjectName,List<String> fields,
    // public static String processData(String fileData,String Agency_ContactListjson) {
    public static String processData(String fileData,String sobjectName,List<String> fields) {
  public static String processData(
    String fileData,
    String sobjectName,
    List<String> fields
  ) {
        DateTime now =System.now();
        System.debug('当前时间:::'+now);
       System.debug('fileData:::'+filedata);
@@ -702,7 +997,6 @@
       // 创建周报
       try{
            if(fileData!=null){ 
                // List<GeDatass> Agency_ContactList = (List<GeDatass>)JSON.deserialize(Agency_ContactListjson,List<GeDatass>.class);
                // System.debug('Agency_ContactList::::'+Agency_ContactList);
@@ -710,7 +1004,7 @@
                // for(GeDatass agconobj :Agency_ContactList){
                //     Agency_ContactMap.put(agconobj.name.replace(' ',''),agconobj.dataId);
                // }
                String[] fileLines = new String[]{};
        String[] fileLines = new List<String>{};
                fileLines = fileData.split('\n');
                // 担当名称的list
                List<String> nameList = new List<String>();
@@ -748,7 +1042,11 @@
                         List<String> R = new List<String>();
                         R = inputvalues[1].split('/');
                         system.debug('R202216'+R);
                         Date rDate = Date.newInstance(Integer.Valueof(R[0]),Integer.Valueof(R[1]),Integer.Valueof(R[2]));
            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();
@@ -757,7 +1055,10 @@
                         if(rDate > endDay || rDate < startDay){
                             system.debug('rDate >= ssDate');
                             // return 'error1 第'+i+'行数据活动日不能为空';
                             errorMag += 'error1 第'+i+'行数据,导入周报仅可补报最近一月周报';
              errorMag +=
                'error1 第' +
                i +
                '行数据,导入周报仅可补报最近一月周报';
                             errorMag += '=';
                         }
                         //SWAG-C7AASP 【委托】DAMS系统周报补录时间调整  2022-1-10 pk end
@@ -772,9 +1073,18 @@
                            errorMag += '=';
                        }
                        String departmentstr = GetDepartment_Cateogy(inputvalues[3]);
                        if(departmentstr == 'no' && inputvalues[3] != '' && inputvalues[3] != null){
            if (
              departmentstr == 'no' &&
              inputvalues[3] != '' &&
              inputvalues[3] != null
            ) {
                            // return 'error3 第'+i+'行数据科室选项列表的值'+inputvalues[3]+'不存在';
                            errorMag += 'error3 第'+i+'行数据科室选项列表的值'+inputvalues[3]+'不存在';
              errorMag +=
                'error3 第' +
                i +
                '行数据科室选项列表的值' +
                inputvalues[3] +
                '不存在';
                            errorMag += '=';
                        }
                        if(inputvalues[4] == '' || inputvalues[4] == null){
@@ -787,21 +1097,40 @@
                            errorMag += 'error1 第'+i+'行数据产品区分1不能为空';
                            errorMag += '=';
                        }
                        if((inputvalues[6] != '' && inputvalues[6] != null)&& inputvalues[5] == inputvalues[6]){
            if (
              (inputvalues[6] != '' && inputvalues[6] != null) &&
              inputvalues[5] == inputvalues[6]
            ) {
                            // return 'error1 第'+i+'行数据产品区分1和产品区分2的值不能重复';
                            errorMag += 'error1 第'+i+'行数据产品区分1和产品区分2的值不能重复';
              errorMag +=
                'error1 第' +
                i +
                '行数据产品区分1和产品区分2的值不能重复';
                            errorMag += '=';
                        }
                        if((inputvalues[7] != '' && inputvalues[7] != null)&& inputvalues[5] == inputvalues[7]){
            if (
              (inputvalues[7] != '' && inputvalues[7] != null) &&
              inputvalues[5] == inputvalues[7]
            ) {
                            // return 'error1 第'+i+'行数据产品区分1和产品区分3的值不能重复';
                            errorMag += '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]){
            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 +=
                'error1 第' +
                i +
                '行数据产品区分2和产品区分3的值不能重复';
                            errorMag += '=';
                        }
                        if(inputvalues[8] == '' || inputvalues[8] == null){
@@ -810,27 +1139,50 @@
                            errorMag += '=';
                        }
                        boolean purposeType = GetPurposeType(inputvalues[8]);
                        if(!purposeType && inputvalues[8] != '' && inputvalues[8] != null){
            if (
              !purposeType &&
              inputvalues[8] != '' &&
              inputvalues[8] != null
            ) {
                            // return 'error3 第'+i+'行数据活动区分选项列表的值'+inputvalues[8]+'不存在';
                            errorMag += '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'){
            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 +=
                  '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 +=
                'error3 第' +
                i +
                '行数据结果选项列表的值' +
                inputvalues[9] +
                '不存在';
                            errorMag += '=';
                        }
                       system.debug('inputvalues[0]=================>'+inputvalues[0]);
@@ -845,11 +1197,16 @@
                        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]));
            departmentSet.add(
              '%' +
                GetDepartment_Cateogy(inputvalues[3]) +
                '%' +
                '-' +
                GetEPurposeType(inputvalues[8])
            );
                        inputList.add(inputvalues);
                    }
                }
@@ -882,23 +1239,34 @@
                // List<Contact> conList = [select id,name from Contact];
                List<Contact> conList = LightningUtil.selectAgencyPerson();
                System.debug('---===---===---====='+conList);
                List<OlympusCalendar__c> olympusDateList = [select Id,Date__c,FirstDayOfWeek__c,DayOfTheWeek__c from OlympusCalendar__c where Date__c= :dateList ];
        List<OlympusCalendar__c> olympusDateList = [
          SELECT Id, Date__c, FirstDayOfWeek__c, DayOfTheWeek__c
          FROM OlympusCalendar__c
          WHERE Date__c = :dateList
        ];
                // test用
                // String testuse = '';
                // testuse += '====='+ahlNameList;
                List<Agency_Hospital_Link__c> ahlList = [select id,name,Hospital__c,MaxActivityDate__c from Agency_Hospital_Link__c where name = :ahlNameList and Agency_Campaign_Obj__c = true];
        List<Agency_Hospital_Link__c> ahlList = [
          SELECT id, name, Hospital__c, MaxActivityDate__c
          FROM Agency_Hospital_Link__c
          WHERE name = :ahlNameList AND Agency_Campaign_Obj__c = TRUE
        ];
                // List<Agency_Hospital_Link__c> ahlList = [select id,name,Hospital__c,MaxActivityDate__c from Agency_Hospital_Link__c ];
                // List<ProductTypes__c> 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{
          } else {
                        dateMap.put(olym.Date__c, olym.FirstDayOfWeek__c);
                    }
                }
                System.debug('x'+dateMap);
                List<OlympusCalendar__c> olympusIdList = [select Id,Date__c,FirstDayOfWeek__c from OlympusCalendar__c where Date__c= :dateMap.values()];
        List<OlympusCalendar__c> 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);
                }
@@ -919,7 +1287,18 @@
                // }
                //fy 20220424 start AWS_Data_Id__c
                if(!Test.isRunningTest()){
                    List<Agency_Contact__c> 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
          List<Agency_Contact__c> 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);
@@ -929,8 +1308,6 @@
                        //fy 20220424 end
                    }
                }
                
                // List<Agency_Opportunity__c> 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){
@@ -946,7 +1323,9 @@
                    String s_agencyname = null;
                    System.debug('dateMap===='+dateMap);
                    // System.debug('lineList[0]====不等于空'+lineList[1]);
                    if(dateMap.get(Date.valueOf(lineList[1].replace('/','-'))) != null){
          if (
            dateMap.get(Date.valueOf(lineList[1].replace('/', '-'))) != null
          ) {
                        System.debug('dateMap====不等于空');
                        week = dateMap.get(Date.valueOf(lineList[1].replace('/','-')));
                        System.debug('===='+week);
@@ -955,7 +1334,9 @@
                    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(' ','')));
            s_agencyname = nameConMap.get(
              nameIdMap.get(lineList[0].replace(' ', ''))
            );
                        System.debug('===='+s_agency);
                    }
                    // if(s_agency == null || s_agencyname == null){
@@ -965,17 +1346,27 @@
                    // }
                    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.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);
          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+'');
@@ -992,7 +1383,9 @@
                    String s_agency = null;
                    System.debug('dateMap===='+dateMap);
                    System.debug('lineList[0]====不等于空'+lineList[1]);
                    if(dateMap.get(Date.valueOf(lineList[1].replace('/','-'))) != null){
          if (
            dateMap.get(Date.valueOf(lineList[1].replace('/', '-'))) != null
          ) {
                        System.debug('dateMap====不等于空');
                        week = dateMap.get(Date.valueOf(lineList[1].replace('/','-')));
                        System.debug('===='+week);
@@ -1006,18 +1399,35 @@
                    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 +=
              'error2 第' +
              hang +
              '行数据报告日' +
              lineList[1] +
              '填写有误';
                        errorMag += '=';
                    }
                    agencyReport.Submit_date__c = week;   // 提出周
                    if((s_agency == null || s_agency == '')&& lineList[0] != '' && lineList[0] != null){
          if (
            (s_agency == null ||
            s_agency == '') &&
            lineList[0] != '' &&
            lineList[0] != null
          ) {
                        // return 'error2 第'+hang+'行数据担当'+lineList[0]+'不存在';
                        errorMag += '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('/','-')); // 活动日
            agencyReport.Report_Date__c = Date.valueOf(
              lineList[1].replace('/', '-')
            ); // 活动日
                    }
                    if(ahlMap.containsKey(lineList[2])){
                        agencyReport.Agency_Hospital__c = ahlMap.get(lineList[2]).Id; //经销商医院
@@ -1025,12 +1435,15 @@
                        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 +=
                'error2 第' +
                hang +
                '行数据经销商医院' +
                lineList[2] +
                '不存在';
                            errorMag += '=';
                        }
                    }
                    
                    String departmentE = GetDepartment_Cateogy(lineList[3]);
@@ -1053,10 +1466,14 @@
                    }else{
                        if(lineList[4] != '' && lineList[4] != null){
                            // return 'error2 第'+hang+'行数据拜访人'+lineList[4]+'不存在';
                            errorMag += 'error2 第'+hang+'行数据拜访人'+lineList[4]+'不存在';
              errorMag +=
                'error2 第' +
                hang +
                '行数据拜访人' +
                lineList[4] +
                '不存在';
                            errorMag += '=';
                        }
                    }
                    if(GetPurposeType(lineList[8])){
@@ -1068,39 +1485,73 @@
                    }
                    // 科室产品区分关系判断
                    // 如果能找到,就是正确的
                    String departandprokey = '%'+GetDepartment_Cateogy(lineList[3])+'%'+'-'+GetEPurposeType(lineList[8]);
          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(
              '---===---===---===' +
              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]);
              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 +=
                '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]);
              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 +=
                  '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]);
              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 +=
                  'error4 第' +
                  hang +
                  '行数据产品区分3的赋值不正确' +
                  lineList[7];
                                errorMag += '=';
                            }
                        }
                    }
                    
                    // 通过map 科室,产品区分名 判断取值是否符合要求
                    // if(protypeMap.containsKey(lineList[5])){
@@ -1120,7 +1571,10 @@
                    }
                    String headerStr = createHeader(week,s_agency);
                    if(agency_report_headerMap.containsKey(headerStr)){
                        agencyReport.Agency_Report_Header__c = agency_report_headerMap.get(headerStr).Id; // 周报一览
            agencyReport.Agency_Report_Header__c = agency_report_headerMap.get(
                headerStr
              )
              .Id; // 周报一览
                    }
                    // if(aoMap.containsKey(lineList[6])){
                    //     agencyReport.Opportunity__c = aoMap.get(lineList[6]).Id; // 经销商询价
@@ -1151,8 +1605,6 @@
                    // insert arList;
                    LightningUtil.insertMAgencyReport(arList);
                }
            }
            return 'success';  
        }catch(Exception e){
@@ -1215,11 +1667,19 @@
        Schema.DescribeFieldResult fieldResult = Agency_Report__c.Result__c.getDescribe();
        List<Schema.PicklistEntry> ple = fieldResult.getPicklistValues();
        for( Schema.PicklistEntry pickListVal : ple){
            System.debug('weixiao'+resultlist.trim()+'111111'+pickListVal.getValue()+'222222');
      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());
        System.debug(
          'weixiaoweixiao' + resultlist + '' + pickListVal.getValue()
        );
                return false;
            }
        }
@@ -1238,7 +1698,10 @@
    }
    // 判断产品区分是否满足要求
    public static String ifTrueProduct(List<Map<String,String>> prolist,String str){
  public static String ifTrueProduct(
    List<Map<String, String>> prolist,
    String str
  ) {
        system.debug('=ifTrueProduct==============ifTrueProduct========='+str);
        system.debug('=prolist==============prolist========='+prolist);
@@ -1251,16 +1714,31 @@
        return '';
    }
    // 获取导入数据的科室和产品区分的匹配
    public static Map<String,List<Map<String,String>>> getImplProductList(Set<String> ptdc){
  public static Map<String, List<Map<String, String>>> getImplProductList(
    Set<String> ptdc
  ) {
         Map<String,List<Map<String,String>>> impProMap = new  Map<String,List<Map<String,String>>>();
         List<String> dc = new List<String>(ptdc);
        if(dc.size() > 0){
            List<ProductTypes__c> ptList1 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList1){
@@ -1270,15 +1748,27 @@
                impProList.add(productMap);
            }
            impProMap.put(dc[0], impProList);
        }
        if(dc.size() > 1){
            List<ProductTypes__c> ptList2 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList2){
@@ -1293,9 +1783,22 @@
            List<ProductTypes__c> ptList3 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList3){
@@ -1310,9 +1813,22 @@
            List<ProductTypes__c> ptList4 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList4){
@@ -1327,9 +1843,22 @@
            List<ProductTypes__c> ptList5 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList5){
@@ -1344,9 +1873,22 @@
            List<ProductTypes__c> ptList6 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList6){
@@ -1361,9 +1903,22 @@
            List<ProductTypes__c> ptList7 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList7){
@@ -1378,9 +1933,22 @@
            List<ProductTypes__c> ptList8 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList8){
@@ -1396,9 +1964,22 @@
            List<ProductTypes__c> ptList9 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList9){
@@ -1413,9 +1994,22 @@
            List<ProductTypes__c> ptList10 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList10){
@@ -1430,9 +2024,22 @@
            List<ProductTypes__c> ptList11 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList11){
@@ -1447,9 +2054,22 @@
            List<ProductTypes__c> ptList12 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList12){
@@ -1464,9 +2084,22 @@
            List<ProductTypes__c> ptList13 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList13){
@@ -1481,9 +2114,22 @@
            List<ProductTypes__c> ptList14 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList14){
@@ -1498,9 +2144,22 @@
            List<ProductTypes__c> ptList15 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList15){
@@ -1515,9 +2174,22 @@
            List<ProductTypes__c> ptList16 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList16){
@@ -1532,9 +2204,22 @@
            List<ProductTypes__c> ptList17 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList17){
@@ -1549,9 +2234,22 @@
            List<ProductTypes__c> ptList18 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList18){
@@ -1566,9 +2264,22 @@
            List<ProductTypes__c> ptList19 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList19){
@@ -1583,9 +2294,22 @@
            List<ProductTypes__c> ptList20 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList20){
@@ -1600,9 +2324,22 @@
            List<ProductTypes__c> ptList21 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList21){
@@ -1617,9 +2354,22 @@
            List<ProductTypes__c> ptList22 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList22){
@@ -1634,9 +2384,22 @@
            List<ProductTypes__c> ptList23 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList23){
@@ -1651,9 +2414,22 @@
            List<ProductTypes__c> ptList24 = new List<ProductTypes__c>();
            List<String> 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]];
        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]];
        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<Map<String,String>> impProList = new List<Map<String,String>>();
            for(ProductTypes__c pt : ptList24){
@@ -1666,7 +2442,6 @@
        }
        return impProMap;
    }
    // 批量添加周报by vivek end 
@@ -1680,7 +2455,11 @@
                r.Message = 'noHospitalId';
                return r;
            }
            List<Agency_Contact__c> acList = [select id,AWS_Data_Id__c,Agency_Hospital__r.Name from Agency_Contact__c where Agency_Hospital__c=:hospitalId];
      List<Agency_Contact__c> 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;