<template>
  <ContentWrap>
    <!-- 搜索工作栏 -->
    <Search :schema="[...CountJobMain.allSchemas.searchSchema,...CountJobDetail.allSchemas.searchSchema]" @search="setSearchParams" @reset="setSearchParams" />
  </ContentWrap>

    <!-- 列表头部 -->
    <TableHead
      :HeadButttondata="HeadButttondata"
      @button-base-click="buttonBaseClick"
      :routeName="routeName"
      @updataTableColumns="updataTableColumns"
      @searchFormClick="searchFormClick"
      :allSchemas="CountJobMain.allSchemas"
      :detailAllSchemas="CountJobDetail.allSchemas"
    />

  <!-- 列表 -->
  <ContentWrap>
    <Table v-clientTable
      :columns="tableColumns"
      :data="tableObject.tableList"
      :loading="tableObject.loading"
      :pagination="{
        total: tableObject.total
      }"
      v-model:pageSize="tableObject.pageSize"
      v-model:currentPage="tableObject.currentPage"
      v-model:sort="tableObject.sort"
    >
      <template #number="{row}">
        <el-button type="primary" link @click="openDetail(row, '单据号', row.number)">
          <span>{{ row.number }}</span>
        </el-button>
      </template>
      <template #action="{ row,$index }">
        <ButtonBase :Butttondata="butttondata(row,$index)" @button-base-click="buttonTableClick($event,row)" />
      </template>
    </Table>
  </ContentWrap>

  <!-- 表单弹窗:添加/修改 -->
  <BasicForm
    ref="formRef"
    @success="getList"
    :rules="CountJobMainRules"
    :formAllSchemas="CountJobMain.allSchemas"
    :searchTableParams="searchTableParams"
    :tableAllSchemas="CountJobDetail.allSchemas"
    :tableFormRules="CountJobDetailRules"
    :apiUpdate="CountJobMainApi.updateCountJobMain"
    :apiCreate="CountJobMainApi.createCountJobMain"
    :isBusiness="true"
    @searchTableSuccess="searchTableSuccess"
  />

  <!-- 详情 -->
  <Detail
    ref="detailRef"
    :isBasic="false"
    :allSchemas="CountJobMain.allSchemas"
    :detailAllSchemas="CountJobDetail.allSchemas"
    :detailAllSchemasRules="CountJobDetailRules"
    :searchTableParams="searchTableParams"
    :apiPage="CountJobDetailApi.getCountJobDetailPage"
  />

  <!-- 导入 -->
  <ImportDetailForm 
    ref="importFormRef" 
    url="/wms/count-job-main/import" 
    :importTemplateData="importTemplateData" 
    @success="importSuccess" 
    :updateIsDisable="true"
    :coverIsDisable="true"
    :mode="1"
    :extend="rowMasterIdRef"
  />

</template>

<script setup lang="ts">
import download from '@/utils/download'
import { CountJobMain,CountJobMainRules,CountJobDetail,CountJobDetailRules } from './countJobMain.data'
import * as CountJobMainApi from '@/api/wms/countJobMain'
import * as CountJobDetailApi from '@/api/wms/countJobDetail'
import * as defaultButtons from '@/utils/disposition/defaultButtons'
import { CACHE_KEY, useCache } from '@/hooks/web/useCache'
// 盘点任务主
defineOptions({ name: 'CountJobMain' })

const message = useMessage() // 消息弹窗
const { t } = useI18n() // 国际化

const route = useRoute() // 路由信息
const routeName = ref()
routeName.value = route.name
const tableColumns = ref([...CountJobMain.allSchemas.tableColumns,...CountJobDetail.allSchemas.tableMainColumns])

// 字段设置 更新主列表字段
const updataTableColumns = (val) => {
  tableColumns.value = val
}

// 查询列表页面参数设置
const searchTableParams = ref([
//{
//  formField: 'productItemCode',
//  searchTableTitle: '物料信息',
//  searchTableAllSchemas: Itembasic.allSchemas,
//  searchTablePage: ItembasicApi.getItembasicPage
//}
])

// 查询页面返回
const searchTableSuccess = (formField, searchField, val, formRef, type, row ) => {
  nextTick(() => {
    if (type == 'tableForm') {
      // 明细查询页赋值
      //row[formField] = val[0][searchField]
      //row['poLine'] = val[0]['poLine']
      //row['batch'] = val[0]['toBatch']
      //row['altBatch'] = val[0]['altBatch']
      //row['itemCode'] = val[0]['itemCode']
      //row['itemName'] = val[0]['itemName']
      //row['itemDesc1'] = val[0]['itemDesc1']
      //row['itemDesc2'] = val[0]['itemDesc2']
      //row['projectCode'] = val[0]['projectCode']
      //row['qty'] = val[0]['qty']
      //row['uom'] = val[0]['uom']
    } else {
      const setV = {}
      setV[formField] = val[0][searchField]
      //setV['ppNumber'] = val[0]['ppNumber']
      //setV['supplierCode'] = val[0]['supplierCode']
      formRef.setValues(setV)
    }
  })
}
// 子表新增的时候选择表格之后需要会显得字段
// const Echo = ['ppNumber','poLine', 'batch', 'altBatch', 'itemCode', 'itemName', 'itemDesc1', 'itemDesc2', 'projectCode', 'qty', 'uom']
const Echo =  []

const { tableObject, tableMethods } = useTable({
  getListApi: CountJobDetailApi.getCountJobDetailPage // 分页接口
})

// 获得表格的各种操作
const { getList, setSearchParams } = tableMethods

// 列表头部按钮
const HeadButttondata = [
  defaultButtons.defaultExportBtn({hasPermi:'wms:count-job-main:export'}), // 导出
  defaultButtons.defaultFreshBtn(null), // 刷新
  defaultButtons.defaultFilterBtn(null), // 筛选
  defaultButtons.defaultSetBtn(null), // 设置
  // {
  //   label: '自定义扩展按钮',
  //   name: 'zdy',
  //   hide: false,
  //   type: 'primary',
  //   icon: 'Select',
  //   color: ''
  // },
]

// 头部按钮事件
const buttonBaseClick = (val, item) => {
  if (val == 'export') { // 导出
    handleExport()
  } else if (val == 'refresh') { // 刷新
    if (tableObject.params.filters && tableObject.params.filters.length > 0 ) {
      searchFormClick({
        filters: tableObject.params.filters
      })
    } else {
      getList()
    }
  } else if (val == 'filtrate') { // 筛选
  } else { // 其他按钮
    console.log('其他按钮', item)
  }
}

// 根据状态返回该按钮是否显示
const isShowMainButton = (row,val) => {
  if (val.indexOf(row.status) > -1) {
    return false
  } else {
    return true
  }
}

// 列表-操作按钮
const butttondata = (row,$index) => {
  const findIndex = row['masterId']?tableObject.tableList.findIndex(item=>item['masterId'] == row['masterId']):-1
  if(findIndex>0&&findIndex<$index){
    return []
  }
  return [
    // defaultButtons.mainListJobAccBtn({hide:isShowMainButton(row,['1'])}), // 承接
    defaultButtons.mainListJobCloBtn({hide:isShowMainButton(row,['1','2']),hasPermi:'wms:count-job-main:close'}), // 关闭
    {
      label: '导出',
      name: 'exportCountJob',
      hide: isShowMainButton(row,['1','2']),
      type: 'primary',
      color: '',
      link: true, //文本展现按钮
      hasPermi: '' // wms:count-job-main:exportCountJob
    },
    {
      label: '导入',
      name: 'importCountJob',
      hide: isShowMainButton(row,['1','2']),
      type: 'success',
      color: '',
      link: true, //文本展现按钮
      hasPermi: '' // wms:count-job-main:importCountJob
    }
    // defaultButtons.mainListJobAbaBtn({hide:isShowMainButton(row,['2'])}), // 放弃
    // defaultButtons.mainListJobExeBtn({hide:isShowMainButton(row,['2'])}), // 执行
  ]
}

// 列表-操作按钮事件
const buttonTableClick = async (val, row) => {
  if (val == 'mainJobExe') { // 执行
    console.log('列表-操作按钮事件-执行')
  } else if (val == 'mainJobAba') { // 放弃
    console.log('列表-操作按钮事件-放弃')
  } else if (val == 'mainJobClo') { // 关闭
    handleClose(row.masterId)
  } else if (val == 'mainJobAcc') { // 承接
    console.log('列表-操作按钮事件-承接')
  } else if (val == 'exportCountJob'){// 当前任务导出
    handleExportCountJob(row.masterId,row.number)
  } else if( val == 'importCountJob'){ // 导入
    handleImport(row.masterId)
  }
}

/** 关闭按钮操作 */
const handleClose = async (id: number) => {
  try {
    await message.confirm(t('common.confirmColse'))
    await CountJobMainApi.closeCountJobMain(id)
    message.success(t('common.closeSuccess'))
    await getList()
  } catch {}
}
// 获取部门 用于详情 部门回显
const { wsCache } = useCache()
/** 详情操作 */
const detailRef = ref()
const openDetail = (row: any, titleName: any, titleValue: any) => {
  const departmentCode = wsCache.get(CACHE_KEY.DEPT).find((account) => account.id == row.departmentCode)?.name
  if (departmentCode) row.departmentCode = JSON.parse(JSON.stringify(departmentCode))
  detailRef.value.openDetail(row, titleName, titleValue)
}

/** 导出按钮操作 */
const exportLoading = ref(false) // 导出的加载中
const handleExport = async () => {
  try {
    // 导出的二次确认
    await message.exportConfirm()
    // 发起导出
    exportLoading.value = true
    const data = await CountJobMainApi.exportCountJobMain(tableObject.params)
    download.excel(data, '盘点任务主.xlsx')
  } catch {
  } finally {
    exportLoading.value = false
  }
}

/** 单条任务导出 */
const handleExportCountJob = async (id: number,number: string) => {
  try {
    await message.exportConfirm()
    exportLoading.value = true
    const data = await CountJobMainApi.handleExportCountJob(id)
    download.excel(data, '盘点任务主'+number+'.xlsx')
  } catch {
  }finally {
    exportLoading.value = false
  }
}

/** 导入 */
const importFormRef = ref()
const rowMasterIdRef = ref('')
const handleImport = (id: string) => {
  rowMasterIdRef.value = id;
  importFormRef.value.open()
}

// 导入附件弹窗所需的参数
const importTemplateData = reactive({
  templateUrl: '',
  templateTitle: '盘点任务导入模版.xlsx'
})

// 导入成功之后
const importSuccess = () => {
  getList()
}

// 筛选提交
const searchFormClick = (searchData) => {
  tableObject.params = {
    isSearch: true,
    filters: searchData.filters
  }
  getList() // 刷新当前列表
}

/** 初始化 **/
onMounted(async () => {
  getList()
})
</script>