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

  <!-- 列表头部 -->
  <TableHead
    :HeadButttondata="HeadButttondata"
    @button-base-click="buttonBaseClick"
    :routeName="routeName"
    @updataTableColumns="updataTableColumns"
    @searchFormClick="searchFormClick"
    :allSchemas="CountRequestMain.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="CountRequestMainRules"
    :formAllSchemas="CountRequestMain.allSchemas"
    :searchTableParams="searchTableParams"
    :tableAllSchemas="CountRequestDetail.allSchemas"
    :tableFormRules="CountRequestDetailRules"
    :tableData="tableData"
    :apiUpdate="CountRequestMainApi.updateCountRequestMain"
    :apiCreate="CountRequestMainApi.createCountRequestMain"
    :isBusiness="true"
    @handleAddTable="handleAddTable"
    @handleDeleteTable="handleDeleteTable"
    :isShowReduceButtonSelection="true"
    @tableSelectionDelete="tableSelectionDelete"
    @searchTableSuccess="searchTableSuccess"
    @submitForm="submitForm"
  />

  <!-- 详情 -->
  <Detail
    ref="detailRef"
    :isBasic="false"
    :allSchemas="CountRequestMain.allSchemas"
    :detailAllSchemas="CountRequestDetail.allSchemas"
    :detailAllSchemasRules="CountRequestDetailRules"
    :searchTableParams="searchTableParams"
    :apiCreate="CountRequestDetailApi.createCountRequestDetail"
    :apiUpdate="CountRequestDetailApi.updateCountRequestDetail"
    :apiPage="CountRequestDetailApi.getCountRequestDetailPage"
    :apiDelete="CountRequestDetailApi.deleteCountRequestDetail"
    :Echo="Echo"
    :detailButtonIsShowAdd="false"
    :detailButtonIsShowEdit="false"
    :detailButtonIsShowDelete="false"
  />

  <!-- 导入 -->
  <ImportForm
    ref="importFormRef"
    url="/wms/count-request-main/import"
    :importTemplateData="importTemplateData"
    @success="importSuccess"
    :updateIsDisable="true"
    :coverIsDisable="true"
    :mode="2"
  />

  <SearchTableCount
    ref="searchTableRef"
    @searchTableSuccess="searchTableSuccessCount"
  />
</template>

<script setup lang="ts">
import download from '@/utils/download'
import { CACHE_KEY, useCache } from '@/hooks/web/useCache'
import {
  CountRequestMain,
  CountRequestMainRules,
  CountRequestDetail,
  CountRequestDetailRules
} from './countRequestMain.data'
import * as CountRequestMainApi from '@/api/wms/countRequestMain'
import * as CountRequestDetailApi from '@/api/wms/countRequestDetail'
import * as defaultButtons from '@/utils/disposition/defaultButtons'
import { SearchTableCount } from '@/components/SearchTableCount'

// 盘点申请
defineOptions({ name: 'CountRequestMain' })

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

const route = useRoute() // 路由信息
const routeName = ref()
routeName.value = route.name
const tableColumns = ref(CountRequestMain.allSchemas.tableColumns)

// 字段设置 更新主列表字段
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 searchTableSuccessCount = (formField, searchField, val, type,row,count) => {
  nextTick(() => {
    if (formField == 'reCount') {
      // 重盘
      if(type == 3){
        row.subList = val
      }
      row.type = type
      CountRequestMainApi.reCount(row).then((res)=>{
        message.success('重盘成功')
        getList()
      })
    } else {
      // 监盘
      if(type == 2){
        row.subList = val
      }else if(type == 1){
        row.count = count
      }
      row.type = type
      CountRequestMainApi.superviseCount(row).then((res)=>{
        message.success('监盘成功')
        getList()
      })
    }
  })
}
// 子表新增的时候选择表格之后需要会显得字段
// const Echo = ['ppNumber','poLine', 'batch', 'altBatch', 'itemCode', 'itemName', 'itemDesc1', 'itemDesc2', 'projectCode', 'qty', 'uom']
const Echo = []

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

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

// 列表头部按钮
const HeadButttondata = [
  // defaultButtons.defaultAddBtn({hasPermi:'wms:count-request-main:create'}), // 新增
  // defaultButtons.defaultImportBtn({hasPermi:'wms:count-request-main:import'}), // 导入
  defaultButtons.defaultExportBtn({ hasPermi: 'wms:count-request-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 == 'add') {
    // 新增
    openForm('create')
  } else if (val == 'import') {
    // 导入
    handleImport()
  } else 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 if (val == 'mainReCount') {
    // 重盘
  } else if (val == 'mainSuperviseCount') {
    // 监盘
  } else {
    // 其他按钮
    console.log('其他按钮', item)
  }
}

// 根据状态返回该按钮是否显示
const isShowMainButton = (row, val) => {
  if (val.indexOf(row.status) > -1) {
    return false
  } else {
    return true
  }
}
// 根据状态返回该按钮是否显示
const isShowReCountMainButton = (row, val) => {
  if (row.jobStatus1 == 3 && (row.jobStatus2 == null || row.jobStatus2 == 3)) {
    return false
  } else {
    return true
  }
}
// 根据状态返回该按钮是否显示
const isShowGenerateMainButton = (row, val) => {
  if (val.indexOf(row.countAdjustStatus) > -1) {
    return false
  } else {
    return true
  }
}


const searchTableRef = ref()
// 列表-操作按钮
const butttondata = (row,$index) => {

  return [
    defaultButtons.mainListCloseBtn({hide: isShowMainButton(row, ['1', '2', '3', '4', '6']),hasPermi: 'wms:count-request-main:close'}), // 关闭
    defaultButtons.mainListReAddBtn({hide: isShowMainButton(row, ['5']),hasPermi: 'wms:count-request-main:reAdd'}), //重新添加
    defaultButtons.mainListSubmitBtn({hide: isShowMainButton(row, ['1']),hasPermi: 'wms:count-request-main:submit'}), // 提交审批
    defaultButtons.mainListTurnDownBtn({hide: isShowMainButton(row, ['2']),hasPermi: 'wms:count-request-main:refused'}), // 驳回
    defaultButtons.mainListApproveBtn({hide: isShowMainButton(row, ['2']),hasPermi: 'wms:count-request-main:agree'}), // 审批通过
    defaultButtons.mainListHandleBtn({hide: isShowMainButton(row, ['3']),hasPermi: 'wms:count-request-main:handle'}), // 处理
    // defaultButtons.mainListEditBtn({hide: isShowMainButton(row, ['1']),hasPermi: 'wms:count-request-main:update'}), // 编辑
    defaultButtons.mainReCountBtn({hide: isShowReCountMainButton(row, ['1']),hasPermi: 'wms:count-request-main:reCount'}), // 重盘
    defaultButtons.mainSuperviseCountBtn({hide: isShowReCountMainButton(row, ['1']),hasPermi: 'wms:count-request-main:supervise'}), // 监盘
    defaultButtons.mainCountAdjustRequesttBtn({hide: isShowGenerateMainButton(row, ['2']),hasPermi: 'wms:count-request-main:generate'}), // 生成盘点调整
    defaultButtons.mainThawRequesttBtn({hide: isShowGenerateMainButton(row, ['3']),hasPermi: 'wms:count-request-main:thaw'}) // 解冻
  ]
}

// 列表-操作按钮事件
const buttonTableClick = async (val, row) => {
  console.log(val)
  if (val == 'mainClose') {
    // 关闭
    await message.confirm('确认要关闭吗?')
    tableObject.loading = true
    CountRequestMainApi.close(row.id)
      .then(() => {
        message.success(t('关闭成功'))
        tableObject.loading = false
        getList()
      })
      .catch((err) => {
        tableObject.loading = false
        console.log(err)
      })
  } else if (val == 'mainReAdd') {
    // 重新添加
    await message.confirm('确认要重新添加吗?')
    tableObject.loading = true
    CountRequestMainApi.reAdd(row.id)
      .then(() => {
        message.success(t('添加成功'))
        tableObject.loading = false
        getList()
      })
      .catch((err) => {
        tableObject.loading = false
        console.log(err)
      })
  } else if (val == 'mainSubmit') {
    // 提交审批
    await message.confirm('确认要提交审批吗?')
    tableObject.loading = true
    CountRequestMainApi.submit(row.id)
      .then(() => {
        message.success(t('提交审批成功'))
        tableObject.loading = false
        getList()
      })
      .catch((err) => {
        tableObject.loading = false
        console.log(err)
      })
  } else if (val == 'mainTurnDown') {
    // 驳回
    await message.confirm('确认要驳回吗?')
    tableObject.loading = true
    CountRequestMainApi.refused(row.id)
      .then(() => {
        message.success(t('驳回成功'))
        tableObject.loading = false
        getList()
      })
      .catch((err) => {
        tableObject.loading = false
        console.log(err)
      })
  } else if (val == 'mainApprove') {
    // 审批通过
    await message.confirm('确认要审批通过吗?')
    tableObject.loading = true
    CountRequestMainApi.agree(row.id)
      .then(() => {
        message.success(t('审批已通过'))
        tableObject.loading = false
        getList()
      })
      .catch((err) => {
        tableObject.loading = false
        console.log(err)
      })
  } else if (val == 'mainHandle') {
    // 处理
    await message.confirm('确认要处理吗?')
    tableObject.loading = true
    CountRequestMainApi.handle(row.id)
      .then(() => {
        message.success(t('处理成功'))
        tableObject.loading = false
        getList()
      })
      .catch((err) => {
        tableObject.loading = false
        console.log(err)
      })
  } else if (val == 'mainReCount') {
    // 重盘
    const radioList = ref([{
      label:1,
      title:'全部'
    },{
      label:2,
      title:'差异'
    },{
      label:3,
      title:'选择'
    }])
    searchTableRef.value.open('盘点申请明细',CountRequestDetail.allSchemas,CountRequestDetailApi.getCountRequestDetailPage,'reCount','',true,'',row,{masterId:row.id},'',radioList.value)
  } else if (val == 'mainSuperviseCount') {
    // 监盘
    const radioList = ref([{
      label:1,
      title:'数量'
    },{
      label:2,
      title:'选择'
    }])
    searchTableRef.value.open('盘点申请明细',CountRequestDetail.allSchemas,CountRequestDetailApi.getCountRequestDetailPage,'superviseCount','',true,'',row,{masterId:row.id},'',radioList.value)
  } else if (val == 'countAdjustRequest') {
    // 生成盘点调整申请
    await message.confirm('确认要生成盘点调整申请吗?')
    CountRequestMainApi.generateCountadjustRequest(row.id)
      .then(() => {
        message.success(t('已生成盘点调整申请'))
        getList()
      })
      .catch((err) => {
        console.log(err)
      })
  }  else if (val == 'mainThaw') {
    // 解冻
    await message.confirm('确认要解冻吗?')
    tableObject.loading = true
    CountRequestMainApi.thaw(row.id)
      .then(() => {
        message.success(t('解冻成功'))
        tableObject.loading = false
        getList()
      })
      .catch((err) => {
        tableObject.loading = false
        console.log(err)
      })
  } else if (val == 'edit') {
    // 编辑
    openForm('update', row)
  } else if (val == 'delete') {
    // 删除
    handleDelete(row.id)
  }
}

/** 添加/修改操作 */
const formRef = ref()
const openForm = async (type: string, row?: number) => {
  tableData.value = [] // 重置明细数据
  formRef.value.open(type, row)
}

// 获取部门 用于详情 部门回显
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,"requestCountMain")
}

/** 删除按钮操作 */
const handleDelete = async (id: number) => {
  try {
    // 删除的二次确认
    await message.delConfirm()
    tableObject.loading = true
    // 发起删除
    await CountRequestMainApi.deleteCountRequestMain(id)
    tableObject.loading = false
    message.success(t('common.delSuccess'))
    // 刷新列表
    await getList()
  } catch {}
}

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

/**
 * tableForm方法
 */
const tableFormKeys = {}
CountRequestDetail.allSchemas.tableFormColumns.forEach((item) => {
  tableFormKeys[item.field] = item.default ? item.default : ''
})
const tableData = ref([])

// 添加明细
const handleAddTable = () => {
  tableData.value.push(JSON.parse(JSON.stringify(tableFormKeys)))
}
// 删除明细
const handleDeleteTable = (item, index) => {
  let itemIndex = tableData.value.indexOf(item)
  if(itemIndex>-1){
    tableData.value.splice(itemIndex, 1)
  }
}
const tableSelectionDelete = (selection) => {
  tableData.value = tableData.value.filter(item => !selection.includes(item))
}
// 主子数据 提交
const submitForm = async (formType, data) => {
  data.subList = tableData.value // 拼接子表数据参数
  try {
    if (formType === 'create') {
      await CountRequestMainApi.createCountRequestMain(data)
      message.success(t('common.createSuccess'))
    } else {
      await CountRequestMainApi.updateCountRequestMain(data)
      message.success(t('common.updateSuccess'))
    }
    formRef.value.dialogVisible = false
    // 刷新当前列表
    getList()
  } finally {
    formRef.value.formLoading = false
  }
}

/** 导入 */
const importFormRef = ref()
const handleImport = () => {
  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()
  importTemplateData.templateUrl = await CountRequestMainApi.importTemplate()
})
</script>