From 089bf5d2378b3c4a61d795b2a92bede2c193b771 Mon Sep 17 00:00:00 2001
From: admin <344137771@qq.com>
Date: Tue, 06 Jan 2026 11:22:58 +0800
Subject: [PATCH] 1
---
src/views/modules/prod/prodInfo.vue | 302 ++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 302 insertions(+), 0 deletions(-)
diff --git a/src/views/modules/prod/prodInfo.vue b/src/views/modules/prod/prodInfo.vue
new file mode 100644
index 0000000..ea6f123
--- /dev/null
+++ b/src/views/modules/prod/prodInfo.vue
@@ -0,0 +1,302 @@
+<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>
+</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'
+
+export default {
+ data () {
+ return {
+ // 分类树展示与回显
+ category: {
+ list: [],
+ selected: [],
+ props: {
+ value: 'categoryId',
+ label: 'categoryName'
+ }
+ },
+ // 规格列表
+ 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
+ }
+ },
+ activated () {
+ this.dataForm.prodId = this.$route.query.prodId
+ this.getDataList()
+ },
+ 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 () {
+ 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]
+ },
+ // 表单提交
+ 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
+ }
+ })
+ 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>
--
Gitblit v1.9.3