渔品和渔品SKU管理

basefishproduct.vue

<template>
  <el-card shadow="never" class="aui-card--fill">
    <div class="mod-base__basefishproduct}">
      <el-form :inline="true" :model="dataForm" @keyup.enter.native="getDataList()">
        <el-form-item>
          <el-input v-model="dataForm.name" placeholder="请输入渔品名称" clearable></el-input>
        </el-form-item>
        <el-form-item>
          <el-select v-model="dataForm.typeId" placeholder="请选择渔品类型" clearable>
            <el-option
                    v-for="item in childFishProductTypeList"
                    :key="item.id"
                    :label="item.name"
                    :value="item.id">
            </el-option>
          </el-select>
        </el-form-item>
        <el-form-item>
          <el-button @click="getDataList()">{{ $t('query') }}</el-button>
        </el-form-item>
        <el-form-item>
          <el-button type="info" @click="exportHandle()">{{ $t('export') }}</el-button>
        </el-form-item>
        <el-form-item>
          <el-button v-if="$hasPermission('base:basefishproduct:save')" type="primary" @click="addOrUpdateHandle()">{{ $t('add') }}</el-button>
        </el-form-item>
        <el-form-item>
          <el-button v-if="$hasPermission('base:basefishproduct:delete')" type="danger" @click="deleteHandle()">{{ $t('deleteBatch') }}</el-button>
        </el-form-item>
      </el-form>
      <el-table v-loading="dataListLoading" :data="dataList" border @selection-change="dataListSelectionChangeHandle" style="width: 100%;">
        <el-table-column type="selection" header-align="center" align="center" width="50"></el-table-column>
        <el-table-column type="expand" label="SKU" width="60px">
          <template slot-scope="scope">
              <el-tag
                      v-for="sku in scope.row.skuList"
                      :key="sku.name"
                      closable
                      @close="deleteSkuTag(sku)">
                {{sku.sku}}
              </el-tag>
          </template>
        </el-table-column>
        <!--<el-table-column prop="id" label="主键" header-align="center" align="center"></el-table-column>-->
        <!--<el-table-column prop="delFlg" label="是否删除" header-align="center" align="center"></el-table-column>-->
        <el-table-column prop="name" label="渔品名称" header-align="center" align="center"></el-table-column>
        <!--<el-table-column prop="typeId" label="所属渔品类型ID" header-align="center" align="center"></el-table-column>-->
        <el-table-column prop="typeName" label="所属渔品类型" header-align="center" align="center"></el-table-column>
        <el-table-column prop="picUrl" label="基础图片地址" header-align="center" align="center">
          <template slot-scope="scope">
            <img :src="scope.row.picUrl" height="50px">
          </template>
        </el-table-column>
        <!--<el-table-column prop="createUser" label="创建人" header-align="center" align="center"></el-table-column>-->
        <!--<el-table-column prop="jsonCreateTime" label="创建时间" header-align="center" align="center"></el-table-column>-->
        <!--<el-table-column prop="updateUser" label="更新人" header-align="center" align="center"></el-table-column>-->
        <!--<el-table-column prop="jsonUpdateTime" label="更新时间" header-align="center" align="center"></el-table-column>-->
        <el-table-column :label="$t('handle')" fixed="right" header-align="center" align="center" width="150">
          <template slot-scope="scope">
            <el-button v-if="$hasPermission('base:basefishproduct:update')" type="text" size="small" @click="addOrUpdateHandle(scope.row.id)">{{ $t('update') }}</el-button>
            <el-button v-if="$hasPermission('base:basefishproduct:delete')" type="text" size="small" @click="deleteHandle(scope.row.id)">{{ $t('delete') }}</el-button>
            <el-button @click="addFishProductSKU(scope.row.id)">添加渔品SKU</el-button>
          </template>
        </el-table-column>
      </el-table>
      <el-pagination
        :current-page="page"
        :page-sizes="[10, 20, 50, 100]"
        :page-size="limit"
        :total="total"
        layout="total, sizes, prev, pager, next, jumper"
        @size-change="pageSizeChangeHandle"
        @current-change="pageCurrentChangeHandle">
      </el-pagination>
      <!-- 弹窗, 新增 / 修改 -->
      <add-or-update v-if="addOrUpdateVisible" ref="addOrUpdate" @refreshDataList="getDataList"></add-or-update>
      <s-k-u-add-or-update v-if="SKUaddOrUpdateVisible" ref="skuAddOrUpdate" @refreshDataList="getDataList"></s-k-u-add-or-update>
    </div>
  </el-card>
</template>

<script>
import mixinViewModule from '@/mixins/view-module'
import AddOrUpdate from './basefishproduct-add-or-update'
import SKUAddOrUpdate from './basefishproductsku-add-or-update'
export default {
  mixins: [mixinViewModule],
  data () {
    return {
      mixinViewModuleOptions: {
        getDataListURL: '/base/basefishproduct/page',
        getDataListIsPage: true,
        exportURL: '/base/basefishproduct/export',
        deleteURL: '/base/basefishproduct',
        deleteIsBatch: true
      },
      dataForm: {
        id: ''
      },
      childFishProductTypeList: [],
      SKUaddOrUpdateVisible: false
    }
  },
  components: {
    AddOrUpdate,
    SKUAddOrUpdate
  },
  created () {
    // 查询所有渔品子类型
    this.$http.get('/base/basefishproducttype/selectAllChildProductType').then(({ data: res }) => {
      if (res.code !== 0) {
        return this.$message.error(res.msg)
      }
      // console.log(res)
      this.childFishProductTypeList = res.data
    }).catch(() => {})
  },
  methods: {
    // 添加渔品SKU
    addFishProductSKU (productId) {
      this.SKUaddOrUpdateVisible = true
      this.$nextTick(() => {
        this.$refs.skuAddOrUpdate.dataForm.productId = productId
        this.$refs.skuAddOrUpdate.init()
      })
    },
    // 删除渔品SKU标签
    deleteSkuTag (sku) {
      this.$confirm('此操作将删除该渔品SKU, 是否继续?', '提示', {
        confirmButtonText: '确定',
        cancelButtonText: '取消',
        type: 'warning'
      }).then(() => {
        // console.log(sku)
        this.$http.delete(
          '/base/basefishproductsku',
          {
            data: [sku.id]
          }
        ).then(({ data: res }) => {
          if (res.code !== 0) {
            return this.$message.error(res.msg)
          }
          this.$message({
            message: this.$t('prompt.success'),
            type: 'success',
            duration: 500,
            onClose: () => {
              this.query()
            }
          })
        }).catch(() => {})
      }).catch(() => {
      })
    }
  }
}
</script>

basefishproduct-add-or-update.vue

<template>
  <el-dialog :visible.sync="visible" :title="!dataForm.id ? $t('add') : $t('update')" :close-on-click-modal="false" :close-on-press-escape="false">
    <el-form :model="dataForm" :rules="dataRule" ref="dataForm" @keyup.enter.native="dataFormSubmitHandle()" :label-width="$i18n.locale === 'en-US' ? '120px' : '80px'">
          <!--<el-form-item label="创建人" prop="createUser">
          <el-input v-model="dataForm.createUser" placeholder="创建人"></el-input>
      </el-form-item>
          <el-form-item label="创建时间" prop="createTime">
          <el-input v-model="dataForm.createTime" placeholder="创建时间"></el-input>
      </el-form-item>
          <el-form-item label="更新人" prop="updateUser">
          <el-input v-model="dataForm.updateUser" placeholder="更新人"></el-input>
      </el-form-item>
          <el-form-item label="更新时间" prop="updateTime">
          <el-input v-model="dataForm.updateTime" placeholder="更新时间"></el-input>
      </el-form-item>-->
          <!--<el-form-item label="逻辑位 0失效1有效" prop="delFlg">
          <el-input v-model="dataForm.delFlg" placeholder="逻辑位 0失效1有效"></el-input>
      </el-form-item>-->
          <el-form-item label="渔品名称" prop="name">
          <el-input v-model="dataForm.name" placeholder="渔品名称"></el-input>
      </el-form-item>
          <!--<el-form-item label="所属渔品类型ID" prop="typeId">
          <el-input v-model="dataForm.typeId" placeholder="所属渔品类型ID"></el-input>
      </el-form-item>-->
        <el-form-item label="所属渔品类型" prop="typeId">
            <el-select v-model="dataForm.typeId" placeholder="所属渔品类型">
                <el-option
                        v-for="item in childFishProductTypeList"
                        :key="item.id"
                        :label="item.name"
                        :value="item.id">
                </el-option>
            </el-select>
        </el-form-item>
          <!--<el-form-item label="基础图片地址" prop="picUrl">
          <el-input v-model="dataForm.picUrl" placeholder="基础图片地址"></el-input>
      </el-form-item>-->
        <el-form-item label="基础图片上传" prop="picUrl">
            <el-upload
                    class="avatar-uploader"
                    :action="uploadUrl"
                    :show-file-list="false"
                    :on-success="handleAvatarSuccess"
                    :before-upload="beforeAvatarUpload">
                <img v-if="imageUrl" :src="imageUrl" class="avatar">
                <i v-else class="el-icon-plus avatar-uploader-icon"></i>
            </el-upload>
        </el-form-item>
      </el-form>
    <template slot="footer">
      <el-button @click="visible = false">{{ $t('cancel') }}</el-button>
      <el-button type="primary" @click="dataFormSubmitHandle()">{{ $t('confirm') }}</el-button>
    </template>
  </el-dialog>
</template>

<script>
import debounce from 'lodash/debounce'
import Cookies from 'js-cookie'
export default {
  data () {
    return {
      visible: false,
      dataForm: {
        id: '',
        createUser: '',
        createTime: '',
        updateUser: '',
        updateTime: '',
        delFlg: '',
        name: '',
        typeId: '',
        picUrl: ''
      },
      childFishProductTypeList: [],
      uploadUrl: '',
      imageUrl: ''
    }
  },
  computed: {
    dataRule () {
      return {
        createUser: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        createTime: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        updateUser: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        updateTime: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        delFlg: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        name: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        typeId: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        picUrl: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ]
      }
    }
  },
  methods: {
    init () {
      // 查询所有子分类
      this.$http.get('/base/basefishproducttype/selectAllChildProductType').then(({ data: res }) => {
        if (res.code !== 0) {
          return this.$message.error(res.msg)
        }
        // console.log(res)
        this.childFishProductTypeList = res.data
      }).catch(() => {})
      // 上传图片
      this.uploadUrl = `${window.SITE_CONFIG.apiURL}/sys/oss/upload?token=${Cookies.get('token')}`
      // this.dataForm.picUrl = this.uploadUrl
      this.visible = true
      this.$nextTick(() => {
        this.$refs.dataForm.resetFields()
        if (this.dataForm.id) {
          this.getInfo()
        }
      })
    },
    handleAvatarSuccess (res) {
      this.dataForm.picUrl = res.data.src
      this.imageUrl = res.data.src
    },
    beforeAvatarUpload (file) {
      const isJPG = file.type === 'image/jpeg'
      const isLt2M = file.size / 1024 / 1024 < 2

      if (!isJPG) {
        this.$message.error('上传头像图片只能是 JPG 格式!')
      }
      if (!isLt2M) {
        this.$message.error('上传头像图片大小不能超过 2MB!')
      }
      return isJPG && isLt2M
    },
    // 获取信息
    getInfo () {
      this.$http.get(`/base/basefishproduct/${this.dataForm.id}`).then(({ data: res }) => {
        if (res.code !== 0) {
          return this.$message.error(res.msg)
        }
        this.dataForm = {
          ...this.dataForm,
          ...res.data
        }
        // 给表单项中图片的src属性复制,显示图片,注意此处res不同于图片上传成功回调函数中的res!!!!!!!!!!!
        this.imageUrl = res.data.picUrl
      }).catch(() => {})
    },
    // 表单提交
    dataFormSubmitHandle: debounce(function () {
      this.$refs.dataForm.validate((valid) => {
        if (!valid) {
          return false
        }
        this.$http[!this.dataForm.id ? 'post' : 'put']('/base/basefishproduct/', this.dataForm).then(({ data: res }) => {
          if (res.code !== 0) {
            return this.$message.error(res.msg)
          }
          this.$message({
            message: this.$t('prompt.success'),
            type: 'success',
            duration: 500,
            onClose: () => {
              this.visible = false
              this.$emit('refreshDataList')
            }
          })
        }).catch(() => {})
      })
    }, 1000, { leading: true, trailing: false })
  }
}
</script>
<style>
    .avatar-uploader .el-upload {
        border: 1px dashed #d9d9d9;
        border-radius: 6px;
        cursor: pointer;
        position: relative;
        overflow: hidden;
    }
    .avatar-uploader .el-upload:hover {
        border-color: #409EFF;
    }
    .avatar-uploader-icon {
        font-size: 28px;
        color: #8c939d;
        width: 178px;
        height: 178px;
        line-height: 178px;
        text-align: center;
    }
    .avatar {
        width: 178px;
        height: 178px;
        display: block;
    }
</style>

basefishproductsku-add-or-update.vue

<template>
  <el-dialog :visible.sync="visible" :title="!dataForm.id ? $t('add') : $t('update')" :close-on-click-modal="false" :close-on-press-escape="false">
    <el-form :model="dataForm" :rules="dataRule" ref="dataForm" @keyup.enter.native="dataFormSubmitHandle()" :label-width="$i18n.locale === 'en-US' ? '120px' : '80px'">
          <!--<el-form-item label="创建人" prop="createUser">
          <el-input v-model="dataForm.createUser" placeholder="创建人"></el-input>
      </el-form-item>
          <el-form-item label="创建时间" prop="createTime">
          <el-input v-model="dataForm.createTime" placeholder="创建时间"></el-input>
      </el-form-item>
          <el-form-item label="更新人" prop="updateUser">
          <el-input v-model="dataForm.updateUser" placeholder="更新人"></el-input>
      </el-form-item>
          <el-form-item label="更新时间" prop="updateTime">
          <el-input v-model="dataForm.updateTime" placeholder="更新时间"></el-input>
      </el-form-item>-->
          <!--<el-form-item label="逻辑位 0失效1有效" prop="delFlg">
          <el-input v-model="dataForm.delFlg" placeholder="逻辑位 0失效1有效"></el-input>
      </el-form-item>-->
          <el-form-item label="SKU名称" prop="sku">
          <el-input v-model="dataForm.sku" placeholder="SKU名称"></el-input>
      </el-form-item>
          <!--<el-form-item label="所属渔品ID" prop="productId">
          <el-input v-model="dataForm.productId" placeholder="所属渔品ID"></el-input>
      </el-form-item>-->
       <!-- <el-form-item label="所属渔品" prop="productId">
            <el-select v-model="dataForm.productId" placeholder="所属渔品">
                <el-option
                        v-for="item in FishProductList"
                        :key="item.id"
                        :label="item.name"
                        :value="item.id">
                </el-option>
            </el-select>
        </el-form-item>-->
      </el-form>
    <template slot="footer">
      <el-button @click="visible = false">{{ $t('cancel') }}</el-button>
      <el-button type="primary" @click="dataFormSubmitHandle()">{{ $t('confirm') }}</el-button>
    </template>
  </el-dialog>
</template>

<script>
import debounce from 'lodash/debounce'
export default {
  data () {
    return {
      visible: false,
      dataForm: {
        id: '',
        createUser: '',
        createTime: '',
        updateUser: '',
        updateTime: '',
        delFlg: '',
        sku: '',
        productId: ''
      },
      FishProductList: []
    }
  },
  computed: {
    dataRule () {
      return {
        createUser: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        createTime: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        updateUser: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        updateTime: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        delFlg: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        sku: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ],
        productId: [
          { required: true, message: this.$t('validate.required'), trigger: 'blur' }
        ]
      }
    }
  },
  methods: {
    init () {
      /* // 查询所有渔品
      this.$http.get('/base/basefishproduct/selectAll').then(({ data: res }) => {
        if (res.code !== 0) {
          return this.$message.error(res.msg)
        }
        // console.log(res)
        this.FishProductList = res.data
      }).catch(() => {}) */
      this.visible = true
      this.$nextTick(() => {
        this.$refs.dataForm.resetFields()
        if (this.dataForm.id) {
          this.getInfo()
        }
      })
    },
    // 获取信息
    getInfo () {
      this.$http.get(`/base/basefishproductsku/${this.dataForm.id}`).then(({ data: res }) => {
        if (res.code !== 0) {
          return this.$message.error(res.msg)
        }
        this.dataForm = {
          ...this.dataForm,
          ...res.data
        }
      }).catch(() => {})
    },
    // 表单提交
    dataFormSubmitHandle: debounce(function () {
      this.$refs.dataForm.validate((valid) => {
        if (!valid) {
          return false
        }
        this.$http[!this.dataForm.id ? 'post' : 'put']('/base/basefishproductsku/', this.dataForm).then(({ data: res }) => {
          if (res.code !== 0) {
            return this.$message.error(res.msg)
          }
          this.$message({
            message: this.$t('prompt.success'),
            type: 'success',
            duration: 500,
            onClose: () => {
              this.visible = false
              this.$emit('refreshDataList')
            }
          })
        }).catch(() => {})
      })
    }, 1000, { leading: true, trailing: false })
  }
}
</script>
posted @ 2020-12-10 15:37  yx袁祥  阅读(139)  评论(0)    收藏  举报