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

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

  <!-- 列表 -->
  <ContentWrap>
    <Table
      :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 }">
        <ButtonBase :Butttondata="butttondata(row)" @button-base-click="buttonTableClick($event,row)" />
      </template>
    </Table>
  </ContentWrap>

  <!-- 表单弹窗:添加/修改 -->
  <BasicForm
    ref="formRef"
    @success="getList"
    :rules="InventorymoveRequestMainRules"
    :formAllSchemas="InventorymoveRequestMain.allSchemas"
    :tableAllSchemas="InventorymoveRequestDetail.allSchemas"
    :tableFormRules="InventorymoveRequestDetailRules"
    :tableData="tableData"
    :apiUpdate="InventorymoveRequestMainApi.updateInventorymoveRequestMain"
    :apiCreate="InventorymoveRequestMainApi.createInventorymoveRequestMain"
    :isBusiness="true"
    @handleAddTable="handleAddTable"
    @handleDeleteTable="handleDeleteTable"
    @searchTableSuccess="searchTableSuccess"
    @submitForm="submitForm"
  />

  <!-- 详情 -->
  <Detail
    ref="detailRef"
    :isBasic="false"
    :allSchemas="InventorymoveRequestMain.allSchemas"
    :detailAllSchemas="InventorymoveRequestDetail.allSchemas"
    :detailAllSchemasRules="InventorymoveRequestDetailRules"
    :apiCreate="InventorymoveRequestDetailApi.createInventorymoveRequestDetail"
    :apiUpdate="InventorymoveRequestDetailApi.updateInventorymoveRequestDetail"
    :apiPage="InventorymoveRequestDetailApi.getInventorymoveRequestDetailPage"
    :apiDelete="InventorymoveRequestDetailApi.deleteInventorymoveRequestDetail"
    :Echo="Echo"
    @searchTableSuccessDetail="searchTableSuccessDetail"
  />

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

<script setup lang="ts">
import download from '@/utils/download'
import { InventorymoveRequestMain,InventorymoveRequestMainRules,InventorymoveRequestDetail,InventorymoveRequestDetailRules } from './inventorymoveRequestMain.data'
import * as InventorymoveRequestMainApi from '@/api/wms/inventorymoveRequestMain'
import * as InventorymoveRequestDetailApi from '@/api/wms/inventorymoveRequestDetail'
import * as defaultButtons from '@/utils/disposition/defaultButtons'

// 库存转移申请
defineOptions({ name: 'InventorymoveRequestMain' })

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

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

console.log(99 ,  routeName.value)
const fromInventoryStatus = ref()
const toInventoryStatus = ref()

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

// 判断 路由名称 进行条件过滤
/**
 * OktoholdRequestMain 合格转隔离
 */
 if ( routeName.value == 'OktoholdRequestMain') {
  tableObject.params = {
    fromInventoryStatus: 'OK',
    toInventoryStatus:'HOLD'
  }
  fromInventoryStatus.value = 'OK'
  toInventoryStatus.value = "HOLD"
  businessType.value = 'OkToHoldRequest'
} else if ( routeName.value == 'HoldtookRequestMain') {
  tableObject.params = {
    fromInventoryStatus: 'HOLD',
    toInventoryStatus:'OK'
  }
  fromInventoryStatus.value = 'HOLD'
  toInventoryStatus.value = "OK"
  businessType.value = 'HoldToOkRequest'
} else if ( routeName.value == 'HoldtoscrapRequestMain') {
  tableObject.params = {
    fromInventoryStatus: 'HOLD',
    toInventoryStatus:'SCRAP'
  }
  fromInventoryStatus.value = 'HOLD'
  toInventoryStatus.value = "SCRAP"
  businessType.value = 'HoldToScrapRequest'
} else if ( routeName.value == 'OktoscrapRequestMain') {
  tableObject.params = {
    fromInventoryStatus: 'OK',
    toInventoryStatus:'SCRAP'
  }
  fromInventoryStatus.value = 'OK'
  toInventoryStatus.value = "SCRAP"
  businessType.value = 'OkToScrapRequest'
} else if ( routeName.value == 'ScraptoholdRequestMain') {
  tableObject.params = {
    fromInventoryStatus: 'SCRAP',
    toInventoryStatus:'HOLD'
  }
  fromInventoryStatus.value = 'SCRAP'
  toInventoryStatus.value = "HOLD"
  businessType.value = 'ScrapToHoldRequest'
} else if( routeName.value == 'InventorymoveRequestMain'){
  fromInventoryStatus.value = null
  businessType.value = 'InventorymoveRequest'
  console.log(146 , businessType.value)
}else {
  tableObject.params = {
    fromInventoryStatus: 'OK',
    toInventoryStatus:'SCRAP'
  }
}

// 修改 tableform 属性
InventorymoveRequestDetail.allSchemas.tableFormColumns.map(item => {
  if(item.field == 'fromPackingNumber') {
    if (fromInventoryStatus.value) {
      item.tableForm.searchCondition = [
      {
        key: 'businessType',
        value: businessType.value ,
        isMainValue: false
      }]
      item.form.componentProps.searchCondition = [
      {
        key: 'businessType',
        value: businessType.value,
        isMainValue: false
      }]
    } else if (fromInventoryStatus.value == null) {
      item.tableForm.searchCondition = [
      {
        key: 'businessType',
        value: businessType.value ,
        isMainValue: false
      }]
      item.form.componentProps.searchCondition = [
      {
        key: 'businessType',
        value: businessType.value,
        isMainValue: false
      }]
    } else {
      delete item.tableForm.searchCondition
    }
  }
  if(item.field == "toLocationCode"){
    if (toInventoryStatus.value) {
      item.tableForm.searchCondition = [
      {
        key: 'businessType',
        value: businessType.value,
        isMainValue: false
      }]
      item.form.componentProps.searchCondition = [
      {
        key: 'businessType',
        value: businessType.value,
        isMainValue: false
      }]
    }else if (toInventoryStatus.value == null) {
      item.tableForm.searchCondition = [
      {
        key: 'businessType',
        value: businessType.value ,
        isMainValue: false
      }]
      item.form.componentProps.searchCondition = [
      {
        key: 'businessType',
        value: businessType.value,
        isMainValue: false
      }]
    }
  }
})

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

// 查询页面返回
const searchTableSuccess = (formField, searchField, val, formRef, type, row ) => {
  nextTick(() => {
    if (type == 'tableForm') {
      if(formField == 'fromPackingNumber'){
        row['fromPackingNumber'] = val[0]['packingNumber']
        row['fromContainerNumber'] = val[0]['containerNumber']
        row['itemCode'] = val[0]['itemCode']
        row['fromBatch'] = val[0]['batch']
        row['fromInventoryStatus'] = val[0]['inventoryStatus']
        row['fromLocationCode'] = val[0]['locationCode']
        row['uom'] = val[0]['uom']
        if(routeName.value == 'OktoholdRequestMain'){
          row['toInventoryStatus'] = "HOLD"
        }else if ( routeName.value == 'HoldtookRequestMain') {
          row['toInventoryStatus'] = "OK"
        }else if ( routeName.value == 'HoldtoscrapRequestMain') {
          row['toInventoryStatus'] = "SCRAP"
        }else if ( routeName.value == 'OktoscrapRequestMain') {
          row['toInventoryStatus'] = "SCRAP"
        }else if ( routeName.value == 'ScraptoholdRequestMain') {
          row['toInventoryStatus'] = "HOLD"
        }else{
          row['toInventoryStatus'] = val[0]['inventoryStatus']
        }
      } else {
        row[formField] = val[0][searchField]
      }
    } else {
      const setV = {}
      setV[formField] = val[0][searchField]
      formRef.setValues(setV)
    }
  })
}
// 查询页面返回——详情
const searchTableSuccessDetail = (formField, searchField, val, formRef ) => {
  nextTick(() => {
    const setV = {}
    if(formField == 'fromPackingNumber') {
      setV['fromPackingNumber'] = val[0]['packingNumber']
      setV['fromContainerNumber'] = val[0]['containerNumber']
      setV['itemCode'] = val[0]['itemCode']
      setV['fromBatch'] = val[0]['batch']
      setV['fromInventoryStatus'] = val[0]['inventoryStatus']
      setV['fromLocationCode'] = val[0]['locationCode']
      setV['uom'] = val[0]['uom']
      if(routeName.value == 'OktoholdRequestMain'){
        setV['toInventoryStatus'] = "HOLD"
        }else if ( routeName.value == 'HoldtookRequestMain') {
          setV['toInventoryStatus'] = "OK"
        }else if ( routeName.value == 'HoldtoscrapRequestMain') {
          setV['toInventoryStatus'] = "SCRAP"
        }else if ( routeName.value == 'OktoscrapRequestMain') {
          setV['toInventoryStatus'] = "SCRAP"
        }else if ( routeName.value == 'ScraptoholdRequestMain') {
          setV['toInventoryStatus'] = "HOLD"
        }else{
          setV['toInventoryStatus'] = val[0]['inventoryStatus']
        }
    } else {
      setV[formField] = val[0][searchField]
    }
    formRef.setValues(setV)
  })
}

// 子表新增的时候选择表格之后需要会显得字段
// const Echo = ['ppNumber','poLine', 'batch', 'altBatch', 'itemCode', 'itemName', 'itemDesc1', 'itemDesc2', 'projectCode', 'qty', 'uom']
const Echo =  []

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

// 列表头部按钮
const HeadButttondata = [
  defaultButtons.defaultAddBtn({hasPermi:'wms:inventorymove-request-main:create'}), // 新增——需要手动修改下权限
  defaultButtons.defaultImportBtn({hasPermi:'wms:inventorymove-request-main:import'}), // 导入
  defaultButtons.defaultExportBtn({hasPermi:'wms:inventorymove-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') { // 刷新
    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) => {
    return [
    defaultButtons.mainListCloseBtn({hide:isShowMainButton(row,['1','2','3','4','6']),hasPermi:'wms:inventorymove-request-main:close'}), // 关闭
        defaultButtons.mainListReAddBtn({hide:isShowMainButton(row,['4','5']),hasPermi:'wms:inventorymove-request-main:reAdd'}), //重新添加
        defaultButtons.mainListSubmitBtn({hide:isShowMainButton(row,['1']),hasPermi:'wms:inventorymove-request-main:submit'}), // 提交审批
        defaultButtons.mainListTurnDownBtn({hide:isShowMainButton(row,['2']),hasPermi:'wms:inventorymove-request-main:refused'}), // 驳回
        defaultButtons.mainListApproveBtn({hide:isShowMainButton(row,['2']),hasPermi:'wms:inventorymove-request-main:agree'}), // 审批通过
        defaultButtons.mainListHandleBtn({hide:isShowMainButton(row,['3']),hasPermi:'wms:inventorymove-request-main:handle'}), // 处理
        defaultButtons.mainListEditBtn({hide:isShowMainButton(row,['1']),hasPermi:'wms:inventorymove-request-main:update'}), // 编辑
        // defaultButtons.mainListDeleteBtn({hasPermi:'wms:inventorymove-request-main:delete'}), // 删除
    ]
}



// 列表-操作按钮事件
const buttonTableClick = async (val, row) => {
  if (val == 'mainClose') { // 关闭
    await message.confirm('确认要关闭吗?')
    InventorymoveRequestMainApi.close(row.id).then(() => {
      message.success(t('common.updateSuccess'))
      getList()
    }).catch(err => {
      console.log(err)
    })
  } else if (val == 'mainReAdd') { // 重新添加
    await message.confirm('确认要重新添加吗?')
    InventorymoveRequestMainApi.reAdd(row.id).then(() => {
      message.success(t('common.updateSuccess'))
      getList()
    }).catch(err => {
      console.log(err)
    })
  } else if (val == 'mainSubmit') { // 提交审批
    await message.confirm('确认要提交审批吗?')
    InventorymoveRequestMainApi.submit(row.id).then(() => {
      message.success(t('common.updateSuccess'))
      getList()
    }).catch(err => {
      console.log(err)
    })
  } else if (val == 'mainTurnDown') { // 驳回
    await message.confirm('确认要驳回吗?')
    InventorymoveRequestMainApi.refused(row.id).then(() => {
      message.success(t('common.updateSuccess'))
      getList()
    }).catch(err => {
      console.log(err)
    })
  } else if (val == 'mainApprove') { // 审批通过
    await message.confirm('确认要审批通过吗?')
    InventorymoveRequestMainApi.agree(row.id).then(() => {
      message.success(t('common.updateSuccess'))
      getList()
    }).catch(err => {
      console.log(err)
    })
  } else if (val == 'mainHandle') { // 处理
    await message.confirm('确认要处理吗?')
    InventorymoveRequestMainApi.handle(row.id).then(() => {
      message.success(t('common.updateSuccess'))
      getList()
    }).catch(err => {
      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 detailRef = ref()
const openDetail = (row: any, titleName: any, titleValue: any) => {
  detailRef.value.openDetail(row, titleName, titleValue)
}

/** 删除按钮操作 */
const handleDelete = async (id: number) => {
  try {
    // 删除的二次确认
    await message.delConfirm()
    // 发起删除
    await InventorymoveRequestMainApi.deleteInventorymoveRequestMain(id)
    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 InventorymoveRequestMainApi.exportInventorymoveRequestMain(tableObject.params)
    if(routeName.value == 'OktoholdRequestMain'){
      download.excel(data, '合格转隔离申请主.xlsx')
        }else if ( routeName.value == 'HoldtookRequestMain') {
          download.excel(data, '隔离转合格申请主.xlsx')
        }else if ( routeName.value == 'HoldtoscrapRequestMain') {
          download.excel(data, '隔离转报废申请主.xlsx')
        }else if ( routeName.value == 'OktoscrapRequestMain') {
          download.excel(data, '合格转报废申请主.xlsx')
        }else if ( routeName.value == 'ScraptoholdRequestMain') {
          download.excel(data, '报废转隔离申请主.xlsx')
        }else{
          download.excel(data, '库存转移申请主.xlsx')
        }
    
  } catch {
  } finally {
    exportLoading.value = false
  }
}

/**
  * tableForm方法
*/
const tableFormKeys = {}
InventorymoveRequestDetail.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) => {
  tableData.value.splice(index, 1)
}

//为true表示子表数据中存在数量为0的数据
const flag = ref()

// 主子数据 提交
const submitForm = async (formType, data) => {
  data.subList = tableData.value // 拼接子表数据参数  
  data.subList.forEach(item => {
    console.log(556565,item);
    if(fromInventoryStatus.value){
      item.fromInventoryStatus = fromInventoryStatus.value
      item.toInventoryStatus = toInventoryStatus.value
    }   
    if(item.qty == 0){
      message.error(`到数量不能为0!`)
      flag.value = true
      return;
    } 
          })
  if(flag.value){
    formRef.value.formLoading = false
    return
  }
  try {
    if (formType === 'create') {
      await InventorymoveRequestMainApi.createInventorymoveRequestMain(data)
      message.success(t('common.createSuccess'))
    } else {
      await InventorymoveRequestMainApi.updateInventorymoveRequestMain(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 InventorymoveRequestMainApi.importTemplate()
})
</script>