import type { CrudSchema } from '@/hooks/web/useCrudSchemas'
import { dateFormatter, dateFormatter2 } from '@/utils/formatTime'
import * as getRequestsettingApi  from '@/api/wms/requestsetting/index'

import * as ItembasicApi  from '@/api/wms/itembasic'
import { Itembasic } from '@/views/wms/basicDataManage/itemManage/itembasic/itembasic.data'

import * as LocationApi  from '@/api/wms/location'
import { Location } from '@/views/wms/basicDataManage/factoryModeling/location/location.data'

import * as WarehouseApi from '@/api/wms/warehouse'
import { Warehouse } from '@/views/wms/basicDataManage/factoryModeling/warehouse/warehouse.data'

const { t } = useI18n() // 国际化

// 获取自动提交自动通过自动执行,跳过任务直接删生成记录的默认值
const queryParams = {
  pageSize:10,
  pageNo:1,
  code:'RepleinmentRequest',
  businessTypeCode: 'Repleinment'
}
 const data = await getRequestsettingApi.getRequestsettingPage(queryParams)
 const requestsettingData =data?.list[0]||{}

 // 获取当前操作人的部门
 import { useUserStore } from '@/store/modules/user'
 import { TableColumn } from '@/types/table'
import {getLocationPageRepleinsh} from "@/api/wms/location";
 const userStore = useUserStore()
 const userDept = userStore.userSelfInfo.dept
 // id 转str 否则form回显匹配不到
 userDept.id = userDept.id.toString()
 const userDeptArray:any = [userDept]

/**
 * @returns {Array} 补料申请主表
 */
export const RepleinshRequestMain = useCrudSchemas(reactive<CrudSchema[]>([
  {
    label: '单据号',
    field: 'number',
    sort: 'custom',
    table: {
      width: 180,
      fixed: 'left'
    },
    isForm: false,
    isSearch: true,
    sortSearchDefault:1,
  },
  {
    label: '状态',
    field: 'status',
    dictType: DICT_TYPE.REQUEST_STATUS,
    dictClass: 'string',
    isForm:false,
    isTable: true,
    isSearch: true,
    sort: 'custom',
    sortTableDefault:1,
    table: {
      width: 150
    },
    form: {
      value: '1',
      componentProps: {
        disabled: true
      }
    }
  },
  {
    label: '到库位代码',
    field: 'toLocationCode',
    sort: 'custom',
    table: {
      width: 150
    },
    hiddenInMain:true,
    // isTableForm: false,
    form: {
      // labelMessage: '信息提示说明!!!',
      componentProps: {
        enterSearch:true,
        isSearchList: true, // 开启查询弹窗
        searchListPlaceholder: '请选择到库位代码', // 输入框占位文本
        searchField: 'code', // 查询弹窗赋值字段
        searchTitle: '库位信息', // 查询弹窗标题
        searchAllSchemas: Location.allSchemas, // 查询弹窗所需类
        searchPage: LocationApi.getLocationPageRepleinsh, // 查询弹窗所需分页方法
        searchCondition:[{
          key: 'available',
          value: 'TRUE',
          isMainValue: false
        }],
        verificationParams: [{
          key: 'code',
          action: '==',
          value: '',
          isMainValue: false,
          isSearch: true,
          isFormModel: true,
        }], // 失去焦点校验参数
      }
    },
    tableForm:{
      isInpuFocusShow: true,
      searchListPlaceholder: '请选择到库位代码', // 输入框占位文本
      searchField: 'code', // 查询弹窗赋值字段
      searchTitle: '库位信息', // 查询弹窗标题
      searchAllSchemas: Location.allSchemas, // 查询弹窗所需类
      searchPage: LocationApi.getLocationPageRepleinsh, // 查询弹窗所需分页方法
      searchCondition:[{
        key: 'available',
        value: 'TRUE',
        isMainValue: false
      }]
    },
  },
  {
    label: '来源',
    field: 'sourceType',
    sort: 'custom',
    table: {
      width: 150
    },
    isForm: false,
    isTable: true,
    isDetail: true
  },
{
      label: '日期',
      sortTableDefault:5,
      field: 'day',
      sort: 'custom',
      isDetail: true,
      isTable: true,
      isForm: true,
      isTableForm: false,
      isSearch: true,
      sortSearchDefault: 3,
      formatter: dateFormatter2,
      search: {
        component: 'DatePicker',
        componentProps: {
          valueFormat: 'YYYY-MM-DD HH:mm:ss',
          type: 'daterange',
          defaultTime: [new Date('1 '), new Date('1 ')]
        }
      },
      form: {
        component: 'DatePicker',
        componentProps: {
          format: 'YYYY-MM-DD',
          valueFormat: 'x',
          defaultTime: [new Date('1 '), new Date('1 ')]
        }
      },
      table: {
        width: 150
      },
      detail: {
        dateFormat:'YYYY-MM-DD'
      }
    },
    {
      label: '便次',
      field: 'deliNo',
      sort: 'custom',
      sortTableDefault: 5,
      table: {
        width: 150
      },
      isTable:true,
      form: {
        component: 'InputNumber',
        componentProps: {
          min: 1,
        },
      }
    },
  {
    label: '从库区类型范围',
    field: 'fromAreaTypes',
    dictType: DICT_TYPE.AREA_TYPE,
    dictClass: 'string',
    isTable: false,
    sort: 'custom',
    table: {
      width: 150
    },
    isForm: false,
  },
  {
    label: '到库区类型范围',
    field: 'toAreaTypes',
    dictType: DICT_TYPE.AREA_TYPE,
    dictClass: 'string',
    isTable: false,
    sort: 'custom',
    table: {
      width: 150
    },
    isForm: false,
  },
  {
    label: '从库区代码范围',
    field: 'fromAreaCodes',
    sort: 'custom',
    table: {
      width: 150
    },
    isTable: false,
    isForm: false,
  },
  {
    label: '到库区代码范围',
    field: 'toAreaCodes',
    sort: 'custom',
    table: {
      width: 150
    },
    isTable: false,
    isForm: false,
  },
  {
    label: '申请时间',
    field: 'requestTime',
    formatter: dateFormatter,
    detail: {
      dateFormat: 'YYYY-MM-DD HH:mm:ss'
    },
    sort: 'custom',
    table: {
      width: 180
    },
    isTable: false,
    form: {
      component: 'DatePicker',
      componentProps: {
        style: { width:'100%'},
        type: 'datetime',
        dateFormat: 'YYYY-MM-DD HH:mm:ss',
        valueFormat: 'x',
      }
    },
    isForm: false,
  },
  {
    label: '截止时间',
    field: 'dueTime',
    formatter: dateFormatter,
    detail: {
      dateFormat: 'YYYY-MM-DD HH:mm:ss'
    },
    sort: 'custom',
    table: {
      width: 180
    },
    isTable: false,
    form: {
      component: 'DatePicker',
      componentProps: {
        style: { width:'100%'},
        type: 'datetime',
        dateFormat: 'YYYY-MM-DD HH:mm:ss',
        valueFormat: 'x',
      }
    },
  },
  {
    label: '部门',
    field: 'departmentCode',
    sort: 'custom',
    isForm:false,
    table: {
      width: 150
    },
    isTable: false,
    formatter: (_: Recordable, __: TableColumn, cellValue: number) => {
      return userDeptArray.find((account) => account.id == cellValue)?.name
    },
    form: {
      value: userDept.id,
      component: 'Select',
      api: () => userDeptArray,
      componentProps: {
        disabled: true,
        optionsAlias: {
          labelField: 'name',
          valueField: 'id'
        }
      }
    }
  },
  {
    label: '业务类型',
    field: 'businessType',
    sort: 'custom',
    table: {
      width: 150
    },
    isTable:false,
    form: {
      value: 'Repleinment',
      componentProps: {
        disabled: true
      }
    },
    isForm: false,
  },
  {
    label: '备注',
    field: 'remark',
    sort: 'custom',
    table: {
      width: 150
    },
    isForm: false,
    isTable: true,
    isDetail: true
  },

  // {
  //   label: '从仓库代码',
  //   field: 'fromWarehouseCode',
  //   sort: 'custom',
  //   table: {
  //     width: 150
  //   },
  //   isTable: false,
  //   form: {
  //     // labelMessage: '信息提示说明!!!',
  //     componentProps: {
  //       isSearchList: true, // 开启查询弹窗
  //       searchListPlaceholder: '请选择仓库代码', // 输入框占位文本
  //       searchField: 'code', // 查询弹窗赋值字段
  //       searchTitle: '仓库信息', // 查询弹窗标题
  //       searchAllSchemas: Warehouse.allSchemas, // 查询弹窗所需类
  //       searchPage: WarehouseApi.getWarehousePage, // 查询弹窗所需分页方法
  //       searchCondition: [{
  //         key: 'available',
  //         value: 'TRUE',
  //         isMainValue: false
  //       }]
  //     }
  //   }
  // },
  // {
  //   label: '到仓库代码',
  //   field: 'toWarehouseCode',
  //   sort: 'custom',
  //   table: {
  //     width: 150
  //   },
  //   isTable: false,
  //   form: {
  //     componentProps: {
  //       disabled: true
  //     }
  //   }
  // },
  {
    label: '自动提交',
    field: 'autoCommit',
    dictType: DICT_TYPE.TRUE_FALSE,
    dictClass: 'string',
    isTable: false,
    isForm:false,
    sort: 'custom',
    table: {
      width: 150
    },
    form: {
      component: 'Switch',
      value: requestsettingData.autoCommit,
      componentProps: {
        inactiveValue: 'FALSE',
        activeValue: 'TRUE',
        disabled: true
      }
    }
  },
  {
    label: '自动通过',
    field: 'autoAgree',
    dictType: DICT_TYPE.TRUE_FALSE,
    dictClass: 'string',
    isForm:false,
    isTable: false,
    sort: 'custom',
    table: {
      width: 150
    },
    form: {
      component: 'Switch',
      value: requestsettingData.autoAgree,
      componentProps: {
        inactiveValue: 'FALSE',
        activeValue: 'TRUE',
        disabled: true
      }
    }
  },
  {
    label: '自动执行',
    field: 'autoExecute',
    dictType: DICT_TYPE.TRUE_FALSE,
    dictClass: 'string',
    isForm:false,
    isTable: false,
    sort: 'custom',
    table: {
      width: 150
    },
    form: {
      component: 'Switch',
      value: requestsettingData.autoExecute,
      componentProps: {
        inactiveValue: 'FALSE',
        activeValue: 'TRUE',
        disabled: true
      }
    }
  },
  // {
  //   label: '直接生成记录',
  //   field: 'directCreateRecord',
  //   dictType: DICT_TYPE.TRUE_FALSE,
  //   dictClass: 'string',
  //   isTable: true,
  //   sort: 'custom',
  //   table: {
  //     width: 150
  //   },
  //   form: {
  //     component: 'Switch',
  //     value: requestsettingData.directCreateRecord,
  //     componentProps: {
  //       inactiveValue: 'FALSE',
  //       activeValue: 'TRUE',
  //       disabled: true
  //     }
  //   }
  // },
  {
    label: '创建时间',
    field: 'createTime',
    formatter: dateFormatter,
    detail: {
      dateFormat: 'YYYY-MM-DD HH:mm:ss'
    },
    sort: 'custom',
    table: {
      width: 180
    },
    isTable: true,
    form: {
      component: 'DatePicker',
      componentProps: {
        type: 'datetime',
        dateFormat: 'YYYY-MM-DD HH:mm:ss',
        valueFormat: 'x',
      }
    },
    isForm: false,
    isSearch: true,
    search: {
      component: 'DatePicker',
      componentProps: {
        valueFormat: 'YYYY-MM-DD HH:mm:ss',
        type: 'daterange',
        defaultTime: [new Date('1 00:00:00'), new Date('1 23:59:59')]
      },
    },
  },
  {
    label: '创建者',
    field: 'creator',
    sort: 'custom',
    table: {
      width: 150
    },
    isTable: true,
    isForm: false,
  },
  {
    label: '最后更新时间',
    field: 'updateTime',
    formatter: dateFormatter,
    detail: {
      dateFormat: 'YYYY-MM-DD HH:mm:ss'
    },
    sort: 'custom',
    table: {
      width: 180
    },
    isDetail: true,
    hiddenInMain:true,
    isTable: false,
    form: {
      component: 'DatePicker',
      componentProps: {
        style: { width:'100%'},
        type: 'datetime',
        dateFormat: 'YYYY-MM-DD HH:mm:ss',
        valueFormat: 'x',
      }
    },
    isForm: false,
  },
  {
    label: '最后更新者',
    field: 'updater',
    sort: 'custom',
    table: {
      width: 150
    },
    hiddenInMain:true,
    isTable: false,
    isDetail: true,
    isForm: false,
  },
  // {
  //   label: '操作',
  //   field: 'action',
  //   isDetail: false,
  //   isForm: false,
  //   table: {
  //     width: 300,
  //     fixed: 'right'
  //   },
  // },
  // {
  //   label: '包装规格',
  //   field: 'packUnit',
  //   sort: 'custom',
  //   isForm:false,
  //   table: {
  //     width: 150
  //   },
  //   sortTableDefault:7,
  // },
  // {
  //   label: '包装数量',
  //   field: 'packQty',
  //   sort: 'custom',
  //   isForm:false,
  //   table: {
  //     width: 150
  //   },
  //   sortTableDefault:8,
  // },
]))

//表单校验
export const RepleinshRequestMainRules = reactive({
  fromWarehouseCode: [
    { required: true, message: '请输入从仓库代码', trigger: 'blur' }
  ],
  fromAreaTypes: [
    { required: true, message: '请选择从库区类型范围', trigger: 'change' }
  ],
  toWarehouseCode: [
    { required: true, message: '请输入到仓库代码', trigger: 'blur' }
  ],
  toAreaTypes: [
    { required: true, message: '请选择到库区类型范围', trigger: 'change' }
  ],
  departmentCode: [
    { required: true, message: '请输入部门', trigger: 'blur' }
  ],
  autoCommit: [
    { required: true, message: '请选择是否自动提交', trigger: 'change' }
  ],
  autoAgree: [
    { required: true, message: '请选择是否自动通过', trigger: 'change' }
  ],
  autoExecute: [
    { required: true, message: '请选择是否自动执行', trigger: 'change' }
  ],
  toLocationCode: [
    { required: true, message: '请输入到库位代码', trigger: ['change', 'blur']}
  ],
  directCreateRecord: [
    { required: true, message: '请选择是否跳过任务直接生成记录', trigger: 'change' }
  ],
  businessType: [
    { required: true, message: '请输入业务类型', trigger: 'blur' }
  ],
  remark:  [
    { max: 50, message: '不得超过50个字符', trigger: 'blur' }
  ],
})

/**
 * @returns {Array} 补料申请子表
 */
export const RepleinshRequestDetail = useCrudSchemas(reactive<CrudSchema[]>([
  {
    label: '品番',
    field: 'itemCode',
    sort: 'custom',
    table: {
      width: 150
    },
    isSearch:true,
    sortSearchDefault:2,
    sortTableDefault:3,
    form: {
      // labelMessage: '信息提示说明!!!',
      componentProps: {
        isSearchList: true, // 开启查询弹窗
        searchListPlaceholder: '请选择品番', // 输入框占位文本
        searchField: 'code', // 查询弹窗赋值字段
        searchTitle: '物料基础信息', // 查询弹窗标题
        searchAllSchemas: Itembasic.allSchemas, // 查询弹窗所需类
        searchPage: ItembasicApi.getItembasicPage, // 查询弹窗所需分页方法
        searchCondition:[{
          key: 'available',
          value: 'TRUE',
          isMainValue: false
        }]
      }
    },
    tableForm:{
      multiple:true,
      disabled:true,
      // isInpuFocusShow: true,
      searchListPlaceholder: '请选择品番', // 输入框占位文本
      searchField: 'code', // 查询弹窗赋值字段
      searchTitle: '物料基础信息', // 查询弹窗标题
      searchAllSchemas: Itembasic.allSchemas, // 查询弹窗所需类
      searchPage: ItembasicApi.getItembasicPage, // 查询弹窗所需分页方法
      searchCondition:[{
        key: 'available',
        value: 'TRUE',
        isMainValue: false
      },{
        key : 'businessTypeCode',
        value: queryParams.businessTypeCode
        }],
      verificationPage: ItembasicApi.getItemListByCodes, // 校验数去焦点输入是否正确的方法
      isShowTableFormSearch: true,
      verificationParams: [{
        key: 'code',
        action: '==',
        value: '',
        isMainValue: false,
        isSearch: true,
        isFormModel: true,
      }], // 失去焦点校验参数
    },
  },
  {
    label: '品名',
    field: 'itemName',
    sort: 'custom',
    sortTableDefault:4,
    isTableForm: false,
    isForm: false,
  },
  {
    label: '背番',
    field: 'itemDesc1',
    sort: 'custom',
    table: {
      width: 150
    },
    hiddenInMain:true,
    isTableForm: false,
    isForm: false,
  },
  {
    label: '描述',
    field: 'itemDesc2',
    sort: 'custom',
    table: {
      width: 150
    },
    hiddenInMain:true,
    isTableForm: false,
    isForm: false,
  },
  {
    label: '数量',
    field: 'unexecutedQty',
    sort: 'custom',
    sortTableDefault:4,
    isTableForm: false,
    isForm: false,
  },
  {
    label: '计量单位',
    field: 'uom',
    dictType: DICT_TYPE.UOM,
    dictClass: 'string',
    isTable: true,
    sort: 'custom',
    table: {
      width: 150
    },
    sortTableDefault:9,
    tableForm: {
      type: 'Select',
      disabled: true
    },
    form: {
      componentProps: {
        disabled: true
      }
    }
  },
  {
    label: '到库位代码',
    field: 'toLocationCode',
    sort: 'custom',
    table: {
      width: 150
    },
    hiddenInMain:true,
    sortSearchDefault:1000,
    // isSearch: true,
    sortTableDefault:1100,
    isTableForm: false,
    form: {
      componentProps: {
        disabled:true,
      }
    }
  },
 
  // {
  //   label: '包装号',
  //   field: 'packingNumber',
  //   sort: 'custom',
  //   table: {
  //     width: 150
  //   },
  //   isTableForm: false,
  //   isForm: false,
  //   sortTableDefault:6,
  //   sortSearchDefault:4,
  // },
  // {
  //   label: '批次',
  //   field: 'batch',
  //   sort: 'custom',
  //   table: {
  //     width: 150
  //   },
  //   isTableForm: false,
  //   sortTableDefault:5,
  //   sortSearchDefault:3,
  // },
  {
    label: '库存状态',
    field: 'inventoryStatus',
    dictType: DICT_TYPE.INVENTORY_STATUS,
    dictClass: 'string',
    isTableForm: false,
    isTable:false,
    sort: 'custom',
    form: {
      value: 'OK',
      componentProps: {
        disabled: true,
        searchCondition:[{
          key: 'available',
          value: 'TRUE',
          isMainValue: false
        }]
      }
    },
    table: {
      width: 150
    },
    tableForm: {
      type: 'Select',
      default: 'OK',
      disabled: true
    }
  },

  {
    label: '单据号',
    field: 'number',
    sort: 'custom',
    table: {
      width: 180
    },
    hiddenInMain:true,
    isTableForm: false,
    isTable:false,
    form: {
      componentProps: {
        disabled: true
      }
    }
  },
 
  {
    label: '备注',
    field: 'remark',
    sort: 'custom',
    isTableForm:false,
    table: {
      width: 150
    },
    isTable:false,
    hiddenInMain:true,
  },
  {
    label: '创建时间',
    field: 'createTime',
    formatter: dateFormatter,
    detail: {
      dateFormat: 'YYYY-MM-DD HH:mm:ss'
    },
    sort: 'custom',
    table: {
      width: 180
    },
    hiddenInMain:true,
    form: {
      component: 'DatePicker',
      componentProps: {
        style: { width:'100%'},
        type: 'datetime',
        dateFormat: 'YYYY-MM-DD HH:mm:ss',
        valueFormat: 'x',
      }
    },
    isTableForm: false,
    isForm: false
  },
  {
    label: '创建者',
    field: 'creator',
    sort: 'custom',
    table: {
      width: 150
    },
    hiddenInMain:true,
    isTableForm: false,
    isForm: false
  },

  {
    label: '项目代码',
    field: 'projectCode',
    sort: 'custom',
    table: {
      width: 150
    },
    hiddenInMain:true,
    isTableForm: false,
    isTable:false,
    isForm: false,
  },

  {
    label: '采购订单号',
    field: 'poNumber',
    sort: 'custom',
    table: {
      width: 150
    },
    hiddenInMain:true,
    isTableForm: false,
    sortTableDefault:1,
    isTable:false,
  },
  {
    label: '订单行',
    field: 'poLine',
    sort: 'custom',
    table: {
      width: 150
    },
    hiddenInMain:true,
    isTableForm: false,
    sortTableDefault:2,
    isTable:false,
  },
 
  {
    label: '从货主代码',
    field: 'fromOwnerCode',
    sort: 'custom',
    table: {
      width: 150
    },
    isTableForm: false,
    isForm: false,
    hiddenInMain:true,
    isTable:false,
  },
  {
    label: '到货主代码',
    field: 'toOwnerCode',
    sort: 'custom',
    table: {
      width: 150
    },
    isTableForm: false,
    isForm: false,
    hiddenInMain:true,
    isTable:false, 
  },
  {
    label: '最后更新时间',
    field: 'updateTime',
    formatter: dateFormatter,
    detail: {
      dateFormat: 'YYYY-MM-DD HH:mm:ss'
    },
    sort: 'custom',
    table: {
      width: 180
    },
    isTable:false,
    form: {
      component: 'DatePicker',
      componentProps: {
        style: { width:'100%'},
        type: 'datetime',
        dateFormat: 'YYYY-MM-DD HH:mm:ss',
        valueFormat: 'x',
      }
    },
    hiddenInMain:true,
    isTableForm: false,
    isForm: false
  },
  {
    label: '最后更新者',
    field: 'updater',
    sort: 'custom',
    table: {
      width: 150
    },
    isTableForm: false,
    hiddenInMain:true,
    isTable:false,
    isForm: false
  },
  // {
  //   label: '未执行任务数量',
  //   field: 'unexecutedQty',
  //   sort: 'custom',
  //   table: {
  //     width: 150
  //   },
  //   form: {
  //     component: 'InputNumber',
  //   },
  //   isTableForm:false,
  //   hiddenInMain:true,
  // },
  // {
  //   label: '操作',
  //   field: 'action',
  //   hiddenInMain:true,
  //   isDetail: false,
  //   isForm: false ,
  //   table: {
  //     width: 150,
  //     fixed: 'right'
  //   },
  //   isTableForm:false,
  // }
]))

//表单校验
export const RepleinshRequestDetailRules = reactive({
  // inventoryStatus: [
  //   { required: true, message: '请选择库存状态', trigger: 'change' }
  // ],
  // toLocationCode: [
  //   { required: true, message: '请输入到库位代码', trigger: 'blur' }
  // ],
  itemCode: [
    { required: true, message: '请输入品番', trigger: 'blur' }
  ],
  remark:  [
    { max: 50, message: '不得超过50个字符', trigger: 'blur' }
  ],
})