| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583 | <!-- by 7527189 2 0 --><template>  <a-row :gutter="24">    <a-col :md="24">      <a-card :style="cardStyle" :bordered="false">        <!-- 查询区域 -->        <div class="table-page-search-wrapper">          <!-- 搜索区域 -->          <a-form layout="inline" @keyup.enter.native="searchQuery">            <a-row :gutter="24">              <a-col :md="6" :sm="24">                <a-form-item label="类别" :labelCol="labelCol" :wrapperCol="wrapperCol">                  <a-tree-select                    style="width: 100%"                    :dropdownStyle="{ maxHeight: '200px', overflow: 'auto' }"                    allow-clear                    :treeData="categoryTree"                    v-model="queryParam.categoryId"                    placeholder="请选择类别"                  >                  </a-tree-select>                </a-form-item>              </a-col>              <a-col :md="6" :sm="24">                <a-form-item label="关键词" :labelCol="labelCol" :wrapperCol="wrapperCol">                  <a-input placeholder="请输入条码、名称、助记码等查询" v-model="queryParam.materialParam"></a-input>                </a-form-item>              </a-col>              <a-col :md="6" :sm="24">                <a-form-item label="规格" :labelCol="labelCol" :wrapperCol="wrapperCol">                  <a-input placeholder="请输入规格查询" v-model="queryParam.standard"></a-input>                </a-form-item>              </a-col>              <span style="float: left; overflow: hidden" class="table-page-search-submitButtons">                <a-col :md="6" :sm="24">                  <a-button type="primary" @click="searchQuery">查询</a-button>                  <a-button style="margin-left: 8px" @click="searchReset">重置</a-button>                  <a @click="handleToggleSearch" style="margin-left: 8px">                    {{ toggleSearchStatus ? '收起' : '展开' }}                    <a-icon :type="toggleSearchStatus ? 'up' : 'down'" />                  </a>                </a-col>              </span>            </a-row>            <template v-if="toggleSearchStatus">              <a-row :gutter="24">                <a-col :md="6" :sm="24">                  <a-form-item label="型号" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-input placeholder="请输入型号查询" v-model="queryParam.model"></a-input>                  </a-form-item>                </a-col>                <a-col :md="6" :sm="24">                  <a-form-item label="颜色" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-input placeholder="请输入颜色查询" v-model="queryParam.color"></a-input>                  </a-form-item>                </a-col>                <a-col :md="6" :sm="24">                  <a-form-item label="品牌" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-input placeholder="请输入品牌查询" v-model="queryParam.brand"></a-input>                  </a-form-item>                </a-col>                <!-- <a-col :md="6" :sm="24">                  <a-form-item label="制造商" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-input placeholder="请输入制造商查询" v-model="queryParam.mfrs"></a-input>                  </a-form-item>                </a-col> -->                <a-col :md="6" :sm="24">                  <a-form-item label="状态" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-select placeholder="请选择状态" v-model="queryParam.enabled">                      <a-select-option value="1">启用</a-select-option>                      <a-select-option value="0">禁用</a-select-option>                    </a-select>                  </a-form-item>                </a-col>                <a-col :md="6" :sm="24">                  <a-form-item label="序列号" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-select placeholder="有无序列号" v-model="queryParam.enableSerialNumber">                      <a-select-option value="1">有</a-select-option>                      <a-select-option value="0">无</a-select-option>                    </a-select>                  </a-form-item>                </a-col>                <!-- <a-col :md="6" :sm="24">                  <a-form-item label="批号" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-select placeholder="有无批号" v-model="queryParam.enableBatchNumber">                      <a-select-option value="1">有</a-select-option>                      <a-select-option value="0">无</a-select-option>                    </a-select>                  </a-form-item>                </a-col> -->                <!-- <a-col :md="6" :sm="24">                  <a-form-item label="仓位货架" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-input                      style="width: 100%"                      placeholder="请输入仓位货架查询"                      v-model="queryParam.position"                    ></a-input>                  </a-form-item>                </a-col> -->                <a-col :md="6" :sm="24">                  <a-form-item label="扩展信息" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-input                      style="width: 100%"                      placeholder="请输入扩展信息查询"                      v-model="queryParam.materialOther"                    ></a-input>                  </a-form-item>                </a-col>                <a-col :md="6" :sm="24">                  <a-form-item label="基础重量" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-input-number                      style="width: 100%"                      placeholder="请输入基础重量查询"                      v-model="queryParam.weight"                    ></a-input-number>                  </a-form-item>                </a-col>                <!-- <a-col :md="6" :sm="24">                  <a-form-item label="保质期" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-input-number                      style="width: 100%"                      placeholder="请输入保质期查询"                      v-model="queryParam.expiryNum"                    ></a-input-number>                  </a-form-item>                </a-col> -->                <a-col :md="6" :sm="24">                  <a-form-item label="备注" :labelCol="labelCol" :wrapperCol="wrapperCol">                    <a-input placeholder="请输入备注查询" v-model="queryParam.remark"></a-input>                  </a-form-item>                </a-col>              </a-row>            </template>          </a-form>        </div>        <!-- 操作按钮区域 -->        <div class="table-operator" style="margin-top: 5px">          <a-button v-if="btnEnableList.indexOf(1) > -1" @click="handleAdd" type="primary" icon="plus">新增</a-button>          <a-button v-if="btnEnableList.indexOf(1) > -1" @click="batchDel" icon="delete">删除</a-button>          <a-button v-if="btnEnableList.indexOf(1) > -1" @click="batchSetStatus(true)" icon="check-square"            >启用</a-button          >          <a-button v-if="btnEnableList.indexOf(1) > -1" @click="batchSetStatus(false)" icon="close-square"            >禁用</a-button          >          <a-button v-if="btnEnableList.indexOf(1) > -1" @click="handleImportXls()" icon="import">导入</a-button>          <a-button v-if="btnEnableList.indexOf(3) > -1" @click="handleExportXls('商品信息')" icon="download"            >导出</a-button          >          <a-button v-if="btnEnableList.indexOf(1) > -1" @click="batchEdit()" icon="edit">批量编辑</a-button>          <a-button v-if="btnEnableList.indexOf(1) > -1" @click="batchSetMaterialCurrentStock()" icon="stock"            >修正库存</a-button          >          <a-button v-if="btnEnableList.indexOf(1) > -1" @click="batchSetMaterialCurrentUnitPrice()" icon="fund"            >修正成本</a-button          >          <a-popover trigger="click" placement="right">            <template slot="content">              <a-checkbox-group @change="onColChange" v-model="settingDataIndex" :defaultValue="settingDataIndex">                <a-row style="width: 500px">                  <template v-for="(item, index) in defColumns">                    <template>                      <a-col :span="8">                        <a-checkbox :value="item.dataIndex">                          <j-ellipsis :value="item.title" :length="10"></j-ellipsis>                        </a-checkbox>                      </a-col>                    </template>                  </template>                </a-row>                <a-row style="padding-top: 10px">                  <a-col>                    恢复默认列配置:<a-button @click="handleRestDefault" type="link" size="small">恢复默认</a-button>                  </a-col>                </a-row>              </a-checkbox-group>            </template>            <a-button icon="setting">列设置</a-button>          </a-popover>        </div>        <!-- table区域-begin -->        <div>          <a-table            ref="table"            size="middle"            bordered            rowKey="id"            :columns="columns"            :dataSource="dataSource"            :components="handleDrag(columns)"            :pagination="ipagination"            :scroll="scroll"            :loading="loading"            :rowSelection="{ selectedRowKeys: selectedRowKeys, onChange: onSelectChange, columnWidth: '40px' }"            @change="handleTableChange"          >            <span slot="action" slot-scope="text, record">              <a @click="handleEdit(record)">编辑</a>              <a-divider v-if="btnEnableList.indexOf(1) > -1" type="vertical" />              <a-popconfirm                v-if="btnEnableList.indexOf(1) > -1"                title="确定删除吗?"                @confirm="() => handleDelete(record.id)"              >                <a>删除</a>              </a-popconfirm>            </span>            <template slot="customPic" slot-scope="text, record">              <a-popover placement="right" trigger="click">                <template slot="content">                  <img :src="getImgUrl(record.imgName, record.imgLarge)" width="500px" />                </template>                <div class="item-info" v-if="record.imgName">                  <img                    v-if="record.imgName"                    :src="getImgUrl(record.imgName, record.imgSmall)"                    class="item-img"                    title="查看大图"                  />                </div>              </a-popover>            </template>            <template slot="customBarCode" slot-scope="text, record">              {{ record.mBarCode }}            </template>            <template slot="customName" slot-scope="text, record">              {{ record.name }}              <a-tag v-if="record.enableSerialNumber == 1" color="orange">序</a-tag>              <a-tag v-if="record.enableBatchNumber == 1" color="orange">批</a-tag>            </template>            <template slot="customRenderInitialStock" slot-scope="text, record">              <a-tooltip :title="record.bigUnitInitialStock">                {{ text }}              </a-tooltip>            </template>            <template slot="customRenderStock" slot-scope="text, record">              <a-tooltip :title="record.bigUnitStock">                {{ text }}              </a-tooltip>            </template>            <template slot="customRenderEnabled" slot-scope="enabled">              <a-tag v-if="enabled" color="green">启用</a-tag>              <a-tag v-if="!enabled" color="orange">禁用</a-tag>            </template>          </a-table>        </div>        <!-- table区域-end -->        <!-- 表单区域 -->        <material-modal ref="modalForm" @ok="modalFormOk"></material-modal>        <import-file-modal ref="modalImportForm" @ok="modalFormOk"></import-file-modal>        <batch-set-info-modal ref="batchSetInfoModalForm" @ok="modalFormOk"></batch-set-info-modal>      </a-card>    </a-col>  </a-row></template><script>import MaterialModal from './modules/MaterialModal'import ImportFileModal from '@/components/tools/ImportFileModal'import BatchSetInfoModal from './modules/BatchSetInfoModal'import { queryMaterialCategoryTreeList } from '@/api/api'import { postAction, getFileAccessHttpUrl } from '@/api/manage'import { getMpListShort } from '@/utils/util'import { JeecgListMixin } from '@/mixins/JeecgListMixin'import JEllipsis from '@/components/jeecg/JEllipsis'import JDate from '@/components/jeecg/JDate'import Vue from 'vue'export default {  name: 'MaterialList',  mixins: [JeecgListMixin],  components: {    MaterialModal,    ImportFileModal,    BatchSetInfoModal,    JEllipsis,    JDate,  },  data() {    return {      categoryTree: [],      mPropertyListShort: '',      model: {},      labelCol: {        span: 5,      },      wrapperCol: {        span: 18,        offset: 1,      },      // 查询条件      queryParam: {        categoryId: undefined,        materialParam: '',        standard: '',        model: '',        color: '',        brand: '',        mfrs: '',        materialOther: '',        weight: '',        expiryNum: '',        enabled: undefined,        enableSerialNumber: undefined,        enableBatchNumber: undefined,        position: '',        remark: '',        mpList: getMpListShort(Vue.ls.get('materialPropertyList')), //扩展属性      },      ipagination: {        pageSizeOptions: ['10', '20', '30', '50', '100', '200'],      },      // 实际索引      settingDataIndex: [],      // 实际列      columns: [],      // 默认索引      defDataIndex: [        'action',        'mBarCode',        'name',        'standard',        'model',        'color',        'categoryName',        'materialOther',        'unit',        'stock',        'purchaseDecimal',        'commodityDecimal',        'wholesaleDecimal',        'lowDecimal',        'enabled',      ],      // 默认列      defColumns: [        {          title: '操作',          dataIndex: 'action',          align: 'center',          width: 100,          scopedSlots: { customRender: 'action' },        },        { title: '图片', dataIndex: 'pic', width: 60, scopedSlots: { customRender: 'customPic' } },        { title: '条码', dataIndex: 'mBarCode', width: 120 },        { title: '名称', dataIndex: 'name', width: 160, scopedSlots: { customRender: 'customName' } },        { title: '规格', dataIndex: 'standard', width: 120 },        { title: '型号', dataIndex: 'model', width: 120 },        { title: '颜色', dataIndex: 'color', width: 70, ellipsis: true },        { title: '品牌', dataIndex: 'brand', width: 100, ellipsis: true },        { title: '助记码', dataIndex: 'mnemonic', width: 80, ellipsis: true },        { title: '类别', dataIndex: 'categoryName', width: 100, ellipsis: true },        { title: '扩展信息', dataIndex: 'materialOther', width: 100, ellipsis: true },        {          title: '单位',          dataIndex: 'unit',          width: 100,          ellipsis: true,          customRender: function (t, r, index) {            if (r) {              let name = t ? t : r.unitName              if (r.sku) {                return name + '[SKU]'              } else {                return name              }            }          },        },        { title: '基础重量', dataIndex: 'weight', width: 80 },        { title: '保质期', dataIndex: 'expiryNum', width: 60 },        { title: '制造商', dataIndex: 'mfrs', width: 120, ellipsis: true },        {          title: '初始库存',          dataIndex: 'initialStock',          width: 80,          scopedSlots: { customRender: 'customRenderInitialStock' },        },        { title: '库存', dataIndex: 'stock', width: 80, scopedSlots: { customRender: 'customRenderStock' } },        { title: '采购价', dataIndex: 'purchaseDecimal', width: 80 },        { title: '零售价', dataIndex: 'commodityDecimal', width: 80 },        { title: '销售价', dataIndex: 'wholesaleDecimal', width: 80 },        { title: '最低售价', dataIndex: 'lowDecimal', width: 80 },        { title: '仓位货架', dataIndex: 'position', width: 80 },        { title: '备注', dataIndex: 'remark', width: 80 },        {          title: '状态',          dataIndex: 'enabled',          align: 'center',          width: 60,          scopedSlots: { customRender: 'customRenderEnabled' },        },      ],      url: {        list: '/material/list',        delete: '/material/delete',        deleteBatch: '/material/deleteBatch',        importExcelUrl: '/material/importExcel',        exportXlsUrl: '/material/exportExcel',        batchSetStatusUrl: '/material/batchSetStatus',        batchSetMaterialCurrentStockUrl: '/material/batchSetMaterialCurrentStock',        batchSetMaterialCurrentUnitPriceUrl: '/material/batchSetMaterialCurrentUnitPrice',      },    }  },  created() {    this.model = Object.assign({}, {})    this.initColumnsSetting()    this.loadTreeData()  },  computed: {    importExcelUrl: function () {      return `${window._CONFIG['domianURL']}${this.url.importExcelUrl}`    },  },  methods: {    //加载初始化列    initColumnsSetting() {      let columnsStr = Vue.ls.get('materialColumns')      if (columnsStr && columnsStr.indexOf(',') > -1) {        this.settingDataIndex = columnsStr.split(',')      } else {        this.settingDataIndex = this.defDataIndex      }      this.columns = this.defColumns.filter((item) => {        return this.settingDataIndex.includes(item.dataIndex)      })    },    //列设置更改事件    onColChange(checkedValues) {      this.columns = this.defColumns.filter((item) => {        return checkedValues.includes(item.dataIndex)      })      let columnsStr = checkedValues.join()      Vue.ls.set('materialColumns', columnsStr)    },    //恢复默认    handleRestDefault() {      Vue.ls.remove('materialColumns')      this.initColumnsSetting()    },    loadTreeData() {      let that = this      let params = {}      params.id = ''      queryMaterialCategoryTreeList(params).then((res) => {        if (res) {          that.categoryTree = []          for (let i = 0; i < res.length; i++) {            let temp = res[i]            that.categoryTree.push(temp)          }        }      })    },    batchSetMaterialCurrentStock() {      if (this.selectedRowKeys.length <= 0) {        this.$message.warning('请选择一条记录!')      } else {        let ids = ''        for (let a = 0; a < this.selectedRowKeys.length; a++) {          ids += this.selectedRowKeys[a] + ','        }        let that = this        this.$confirm({          title: '确认操作',          content: '是否操作选中数据?',          onOk: function () {            that.loading = true            postAction(that.url.batchSetMaterialCurrentStockUrl, { ids: ids })              .then((res) => {                if (res.code === 200) {                  that.$message.info('修正库存成功!')                  that.loadData()                  that.onClearSelected()                } else {                  that.$message.warning(res.data.message)                }              })              .finally(() => {                that.loading = false              })          },        })      }    },    batchSetMaterialCurrentUnitPrice() {      if (this.selectedRowKeys.length <= 0) {        this.$message.warning('请选择一条记录!')      } else {        let ids = ''        for (let a = 0; a < this.selectedRowKeys.length; a++) {          ids += this.selectedRowKeys[a] + ','        }        let that = this        this.$confirm({          title: '确认操作',          content: '是否操作选中数据?',          onOk: function () {            that.loading = true            postAction(that.url.batchSetMaterialCurrentUnitPriceUrl, { ids: ids })              .then((res) => {                if (res.code === 200) {                  that.$message.info('修正成本成功!')                  that.loadData()                  that.onClearSelected()                } else {                  that.$message.warning(res.data.message)                }              })              .finally(() => {                that.loading = false              })          },        })      }    },    batchEdit() {      if (this.selectedRowKeys.length <= 0) {        this.$message.warning('请选择一条记录!')      } else {        let ids = ''        for (let a = 0; a < this.selectedRowKeys.length; a++) {          if (a === this.selectedRowKeys.length - 1) {            ids += this.selectedRowKeys[a]          } else {            ids += this.selectedRowKeys[a] + ','          }        }        this.$refs.batchSetInfoModalForm.edit(ids)        this.$refs.batchSetInfoModalForm.title = '批量编辑'      }    },    handleEdit: function (record) {      this.$refs.modalForm.edit(record)      this.$refs.modalForm.title = '编辑'      this.$refs.modalForm.disableSubmit = false      if (this.btnEnableList.indexOf(1) === -1) {        this.$refs.modalForm.showOkFlag = false      }    },    getImgUrl(imgName, type) {      if (imgName && imgName.split(',')) {        type = type ? type + '/' : ''        return getFileAccessHttpUrl('systemConfig/static/' + type + imgName.split(',')[0])      } else {        return ''      }    },    handleImportXls() {      let importExcelUrl = this.url.importExcelUrl      let templateUrl = '/doc/goods_template.xls'      let templateName = '商品Excel模板[下载]'      this.$refs.modalImportForm.initModal(importExcelUrl, templateUrl, templateName)      this.$refs.modalImportForm.title = '商品导入'    },    searchReset() {      this.queryParam = {        mpList: getMpListShort(Vue.ls.get('materialPropertyList')), //扩展属性      }      this.loadData(1)    },  },}</script><style scoped>@import '~@assets/less/common.less';</style><style>.item-info {  float: left;  width: 38px;  height: 38px;  margin-left: 6px;}.item-img {  cursor: pointer;  position: static;  display: block;  width: 100%;  height: 100%;  object-fit: cover;}</style>
 |