|
@@ -1,302 +1,74 @@
|
|
|
<template>
|
|
|
- <div class="mod-prod-info">
|
|
|
- <el-form :model="dataForm"
|
|
|
- ref="dataForm"
|
|
|
- label-width="100px">
|
|
|
- <el-form-item label="产品图片">
|
|
|
- <mul-pic-upload v-model="dataForm.imgs" />
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="状态">
|
|
|
- <el-radio-group v-model="dataForm.status">
|
|
|
- <el-radio :label="1">上架</el-radio>
|
|
|
- <el-radio :label="0">下架</el-radio>
|
|
|
- </el-radio-group>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="产品分类"
|
|
|
- :rules="[{ required: true, message: '请选择产品分类'}]"
|
|
|
- prop="categoryId">
|
|
|
- <el-col :span="8">
|
|
|
- <el-cascader expand-trigger="hover"
|
|
|
- :options="category.list"
|
|
|
- :props="category.props"
|
|
|
- v-model="category.selected"
|
|
|
- change-on-select
|
|
|
- @change="handleCategoryChange">
|
|
|
- </el-cascader>
|
|
|
- </el-col>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="产品分组" :rules="[{ required: true, message: '请选择产品分组'}]">
|
|
|
- <el-col :span="8">
|
|
|
- <el-select v-model="dataForm.tagList"
|
|
|
- multiple
|
|
|
- style="width: 250px"
|
|
|
- placeholder="请选择">
|
|
|
- <el-option v-for="item in this.tags"
|
|
|
- :key="item.id"
|
|
|
- :label="item.title"
|
|
|
- :value="item.id">
|
|
|
- </el-option>
|
|
|
- </el-select>
|
|
|
- </el-col>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="产品名称"
|
|
|
- prop="prodName"
|
|
|
- :rules="[
|
|
|
- { required: true, message: '产品名称不能为空'},
|
|
|
- { pattern: /\s\S+|S+\s|\S/, message: '请输入正确的产品名称', trigger: 'blur' }
|
|
|
- ]">
|
|
|
- <el-col :span="8">
|
|
|
- <el-input v-model="dataForm.prodName"
|
|
|
- placeholder="产品名称"
|
|
|
- maxlength="50"></el-input>
|
|
|
- </el-col>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="产品卖点"
|
|
|
- prop="brief":rules="[
|
|
|
- { required: false, pattern: /\s\S+|S+\s|\S/, message: '请输入正确的产品卖点', trigger: 'blur' }
|
|
|
- ]">
|
|
|
- <el-col :span="8">
|
|
|
- <el-input v-model="dataForm.brief"
|
|
|
- type="textarea"
|
|
|
- :autosize="{minRows: 2, maxRows: 4}"
|
|
|
- placeholder="产品卖点"></el-input>
|
|
|
- </el-col>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item label="配送方式">
|
|
|
- <el-checkbox v-model="dataForm.deliveryMode.hasShopDelivery">商家配送</el-checkbox>
|
|
|
- <el-checkbox v-model="dataForm.deliveryMode.hasUserPickUp">用户自提</el-checkbox>
|
|
|
- </el-form-item>
|
|
|
- <prod-transport v-show="dataForm.deliveryMode.hasShopDelivery"
|
|
|
- v-model="dataForm.deliveryTemplateId"></prod-transport>
|
|
|
- <sku-tag ref="skuTag"
|
|
|
- :skuList="dataForm.skuList"
|
|
|
- @change="skuTagChangeSkuHandler"></sku-tag>
|
|
|
- <sku-table ref="skuTable"
|
|
|
- v-model="dataForm.skuList"
|
|
|
- :prodName.sync="dataForm.prodName"></sku-table>
|
|
|
-
|
|
|
- <el-form-item label="产品详情"
|
|
|
- prop="content">
|
|
|
- <tiny-mce v-model="dataForm.content"
|
|
|
- ref="content"
|
|
|
- style="width:1000px"></tiny-mce>
|
|
|
- </el-form-item>
|
|
|
- <el-form-item>
|
|
|
- <el-button type="primary"
|
|
|
- @click="dataFormSubmit()">确定</el-button>
|
|
|
- </el-form-item>
|
|
|
- </el-form>
|
|
|
- </div>
|
|
|
+ <avue-form :option="option" v-model="form" @submit="onSubmit">
|
|
|
+ <template slot="kind">
|
|
|
+ <el-transfer v-model="form.kind" filterable :data="categories_selections" :titles="['备选项', '已选项']"></el-transfer>
|
|
|
+ </template>
|
|
|
+ </avue-form>
|
|
|
</template>
|
|
|
|
|
|
-<script>
|
|
|
-import { treeDataTranslate, idList } from '@/utils'
|
|
|
-import MulPicUpload from '@/components/mul-pic-upload'
|
|
|
-import ProdTransport from './prod-transport'
|
|
|
-import SkuTag from './sku-tag'
|
|
|
-import SkuTable from './sku-table'
|
|
|
-import TinyMce from '@/components/tiny-mce'
|
|
|
-import { Debounce } from '@/utils/debounce'
|
|
|
+<script lang="ts">
|
|
|
+import Vue from 'vue'
|
|
|
+import httpx, { AxiosResponse } from '@/utils/httpx'
|
|
|
+import formOption from "@/avue/form/prodinfo"
|
|
|
+import { ICategory } from '@/utils/vo'
|
|
|
+// import TransferBox from '@/components/transfer-box'
|
|
|
+
|
|
|
+interface ISelection {
|
|
|
+ key: number,
|
|
|
+ label: string,
|
|
|
+ disabled?: boolean
|
|
|
+ hidden?: boolean
|
|
|
+}
|
|
|
|
|
|
-export default {
|
|
|
- data () {
|
|
|
+export default Vue.extend({
|
|
|
+ data() {
|
|
|
return {
|
|
|
- // 分类树展示与回显
|
|
|
- category: {
|
|
|
- list: [],
|
|
|
- selected: [],
|
|
|
- props: {
|
|
|
- value: 'categoryId',
|
|
|
- label: 'categoryName'
|
|
|
- }
|
|
|
+ form: {
|
|
|
+ name: "",
|
|
|
+ desc: "",
|
|
|
+ price: 0,
|
|
|
+ deliverPrice: 0,
|
|
|
+ stockAmount: 0,
|
|
|
+ soldAmount: 0,
|
|
|
+ cover: "",
|
|
|
+ kind: [] as number[],
|
|
|
},
|
|
|
- // 规格列表
|
|
|
- dataForm: {
|
|
|
- prodName: '',
|
|
|
- brief: '',
|
|
|
- pic: '',
|
|
|
- imgs: '',
|
|
|
- categoryId: 0,
|
|
|
- prodId: 0,
|
|
|
- skuList: [],
|
|
|
- tagList: [],
|
|
|
- content: '',
|
|
|
- status: 1,
|
|
|
- deliveryMode: {
|
|
|
- hasShopDelivery: false,
|
|
|
- hasUserPickUp: false
|
|
|
- },
|
|
|
- deliveryTemplateId: null
|
|
|
- },
|
|
|
- tags: [],
|
|
|
- resourcesUrl: process.env.VUE_APP_RESOURCES_URL
|
|
|
- }
|
|
|
- },
|
|
|
- components: {
|
|
|
- MulPicUpload,
|
|
|
- ProdTransport,
|
|
|
- TinyMce,
|
|
|
- SkuTag,
|
|
|
- SkuTable
|
|
|
- },
|
|
|
- computed: {
|
|
|
- defalutSku () {
|
|
|
- return this.$store.state.prod.defalutSku
|
|
|
+ option: formOption,
|
|
|
+ categories: [] as ICategory[],
|
|
|
}
|
|
|
},
|
|
|
- activated () {
|
|
|
- this.dataForm.prodId = this.$route.query.prodId
|
|
|
- this.getDataList()
|
|
|
+ // components: {
|
|
|
+ // TransferBox
|
|
|
+ // },
|
|
|
+
|
|
|
+ mounted() {
|
|
|
+ this.getCategoryList("")
|
|
|
},
|
|
|
+
|
|
|
methods: {
|
|
|
- // 获取分类数据
|
|
|
- getDataList () {
|
|
|
- this.getTagList()
|
|
|
- this.getCategoryList().then(() => {
|
|
|
- if (this.dataForm.prodId) {
|
|
|
- // 获取产品数据
|
|
|
- this.$http({
|
|
|
- url: this.$http.adornUrl(`/prod/prod/info/${this.dataForm.prodId}`),
|
|
|
- method: 'get',
|
|
|
- params: this.$http.adornParams()
|
|
|
- }).then(({ data }) => {
|
|
|
- this.dataForm = data
|
|
|
- this.dataForm.deliveryMode = JSON.parse(data.deliveryMode)
|
|
|
- this.$refs.skuTag.init(data.skuList)
|
|
|
- this.$refs.skuTable.init()
|
|
|
- this.category.selected = idList(this.category.list, this.dataForm.categoryId, 'categoryId', 'children').reverse()
|
|
|
- this.dataForm.tagList = data.tagList
|
|
|
- })
|
|
|
- } else {
|
|
|
- this.$nextTick(() => {
|
|
|
- this.$refs['dataForm'].resetFields()
|
|
|
- this.$refs.skuTag.init()
|
|
|
- this.dataForm.pic = ''
|
|
|
- this.dataForm.imgs = ''
|
|
|
- })
|
|
|
- }
|
|
|
+ getCategoryList(name: string = "") {
|
|
|
+ return httpx.post("/goodsTypes/queryGoodsTypeList", {
|
|
|
+ name: name, limit: 1000, page: 1
|
|
|
+ }).then(({ data }: AxiosResponse<{ goodsTypeList: ICategory[], total: number }>) => {
|
|
|
+ this.categories = data.goodsTypeList
|
|
|
})
|
|
|
},
|
|
|
- // 获取分类信息
|
|
|
- getCategoryList () {
|
|
|
- return this.$http({
|
|
|
- url: this.$http.adornUrl('/prod/category/listCategory'),
|
|
|
- method: 'get',
|
|
|
- params: this.$http.adornParams()
|
|
|
- }).then(({ data }) => {
|
|
|
- this.category.list = treeDataTranslate(data, 'categoryId', 'parentId')
|
|
|
- })
|
|
|
- },
|
|
|
- // 选择分类改变事件
|
|
|
- handleCategoryChange (val) {
|
|
|
- this.dataForm.categoryId = val[val.length - 1]
|
|
|
+ onSubmit(form: typeof this.form, done: Function) {
|
|
|
+ console.log(form)
|
|
|
+ // TODO
|
|
|
+ done()
|
|
|
},
|
|
|
- // 表单提交
|
|
|
- dataFormSubmit: Debounce(function () {
|
|
|
- this.$refs['dataForm'].validate((valid) => {
|
|
|
- if (!valid) {
|
|
|
- return
|
|
|
- }
|
|
|
- if (!this.dataForm.imgs) {
|
|
|
- this.errorMsg('请选择图片上传')
|
|
|
- return
|
|
|
- }
|
|
|
- if (!this.dataForm.deliveryMode) {
|
|
|
- this.errorMsg('请选择配送方式')
|
|
|
- return
|
|
|
- }
|
|
|
- if (this.dataForm.deliveryMode.hasShopDelivery && !this.dataForm.deliveryTemplateId) {
|
|
|
- this.errorMsg('请选择运费模板')
|
|
|
- return
|
|
|
- }
|
|
|
- let param = Object.assign({}, this.dataForm)
|
|
|
- // 设置价格和库存
|
|
|
- this.paramSetPriceAndStocks(param)
|
|
|
+ },
|
|
|
|
|
|
- param.deliveryMode = undefined
|
|
|
- param.deliveryModeVo = this.dataForm.deliveryMode
|
|
|
- // 商品主图
|
|
|
- param.pic = this.dataForm.imgs.split(',')[0]
|
|
|
- this.$http({
|
|
|
- url: this.$http.adornUrl(`/prod/prod`),
|
|
|
- method: param.prodId ? 'put' : 'post',
|
|
|
- data: this.$http.adornData(param)
|
|
|
- }).then(({ data }) => {
|
|
|
- this.$message({
|
|
|
- message: '操作成功',
|
|
|
- type: 'success',
|
|
|
- duration: 1500,
|
|
|
- onClose: () => {
|
|
|
- this.visible = false
|
|
|
- this.$store.commit('common/removeMainActiveTab')
|
|
|
- this.$router.push({ name: 'prod-prodList' })
|
|
|
- this.$emit('refreshDataList')
|
|
|
- }
|
|
|
- })
|
|
|
- })
|
|
|
- })
|
|
|
- }),
|
|
|
- paramSetPriceAndStocks (param) {
|
|
|
- // 获取规格属性信息
|
|
|
- // param.skuList = this.$refs.prodSpec.getTableSpecData()
|
|
|
- // 商品库存
|
|
|
- param.totalStocks = 0
|
|
|
- // 商品价格
|
|
|
- param.price = 0
|
|
|
- // 商品原价
|
|
|
- param.oriPrice = 0
|
|
|
- // 商品实际库存
|
|
|
- for (let i = 0; i < param.skuList.length; i++) {
|
|
|
- const element = param.skuList[i]
|
|
|
- if (element.status !== 1) {
|
|
|
- continue
|
|
|
- }
|
|
|
- if (param.price === 0) {
|
|
|
- param.price = element.price ? Number.parseFloat(element.price) : 0
|
|
|
- }
|
|
|
- // 商品价格为最低价的那件商品的价格
|
|
|
- param.price = Math.min(param.price, element.price)
|
|
|
- if (param.price === element.price) {
|
|
|
- param.oriPrice = element.oriPrice ? Number.parseFloat(element.oriPrice) : 0
|
|
|
- }
|
|
|
- param.totalStocks += element.stocks ? Number.parseInt(element.stocks) : 0
|
|
|
- }
|
|
|
- // 如果sku没有商品名称,则使用商品的商品名称
|
|
|
- if (param.skuList.length === 1) {
|
|
|
- param.skuList[0].prodName = this.dataForm.prodName
|
|
|
- }
|
|
|
- },
|
|
|
- skuTagChangeSkuHandler (skuList) {
|
|
|
- const prodName = this.dataForm.prodName
|
|
|
- skuList.forEach(sku => {
|
|
|
- if (sku.properties) {
|
|
|
- sku.skuName = ''
|
|
|
- let properties = sku.properties.split(';')
|
|
|
- for (const propertiesKey in properties) {
|
|
|
- sku.skuName += properties[propertiesKey].split(':')[1] + ' '
|
|
|
- }
|
|
|
- sku.prodName = prodName + ' ' + sku.skuName
|
|
|
+ computed: {
|
|
|
+ categories_selections(): ISelection[] {
|
|
|
+ return this.categories.map((v, i) => {
|
|
|
+ return {
|
|
|
+ key: v.id,
|
|
|
+ label: v.name,
|
|
|
}
|
|
|
})
|
|
|
- this.dataForm.skuList = skuList
|
|
|
- },
|
|
|
- errorMsg (message) {
|
|
|
- this.$message({
|
|
|
- message: message,
|
|
|
- type: 'error',
|
|
|
- duration: 1500
|
|
|
- })
|
|
|
- },
|
|
|
- // 获取所有的分组信息
|
|
|
- getTagList () {
|
|
|
- this.$http({
|
|
|
- url: this.$http.adornUrl('/prod/prodTag/listTagList'),
|
|
|
- method: 'get',
|
|
|
- params: this.$http.adornParams()
|
|
|
- }).then(({ data }) => {
|
|
|
- this.tags = data
|
|
|
- })
|
|
|
}
|
|
|
- }
|
|
|
-}
|
|
|
-</script>
|
|
|
+ },
|
|
|
+})
|
|
|
+</script>
|