JSelectMultiSomeContainer.vue 2.18 KB
<template>
  <!-- 定义在这里的参数都是不可在外部覆盖的,防止出现问题 -->
  <j-select-biz-component
    :value="value"
    :multiple="false"
    :ellipsisLength="25"
    :listUrl="url.list"
    :columns="columns"
    v-on="$listeners"
    v-bind="attrs"
  />
</template>

<script>
import JDate from '@comp/jeecg/JDate'
import JSelectBizComponent from './JSelectBizComponent'

export default {
  name: 'JSelectMultiSomeContainer',
  components: {JDate, JSelectBizComponent},
  props: {
    value: null, // any type
    queryConfig: {
      type: Array,
      default: () => []
    },
  },
  data() {
    return {
      url: {list: '/inventory/inventoryDetail/queryPageListList'},
      columns: [
        {title: this.$t('task.containerCode'), align: 'center', dataIndex: 'containerCode'},
        {title: this.$t('config.locationCode'), align: 'center', width: '15%', dataIndex: 'locationCode'},
        {
          title: this.$t('config.zoneCode'), align: 'center', width: '15%', dataIndex: 'zoneCode', key: 'zoneCode',
          scopedSlots: {customRender: 'zoneCode'}
        },
        {title: this.$t('config.materialCode'), align: 'center', width: '15%', dataIndex: 'materialCode'},
        {title: this.$t('config.materialName'), align: 'center', width: '15%', dataIndex: 'materialName'},
        {title: this.$t('config.materialNumber'), align: 'center', width: '15%', dataIndex: 'qty'},
      ],
      // 定义在这里的参数都是可以在外部传递覆盖的,可以更灵活的定制化使用的组件
      default: {
        name: this.$t('config.containerCode'),
        width: 1250,
        displayKey: 'containerCode',
        returnKeys: ['id', 'containerCode'],
        queryParamText: this.$t('config.containerCode'),
      },
      // 多条件查询配置
      queryConfigDefault: [
        {
          key: 'materialCode',
          label: this.$t('config.materialCode'),
          placeholder: this.$t('config.inputMaterialCode')
        },
      ],
    }
  },
  computed: {
    attrs() {
      return Object.assign(this.default, this.$attrs, {
        queryConfig: this.queryConfigDefault.concat(this.queryConfig)
      })
    }
  }
}
</script>

<style lang="less" scoped></style>