| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220 |
- <!-- 添加商品-钻石首饰 -->
- <template>
- <el-form ref="formRef" class="el-form--horizontal" label-width="130px" :model="formData" :rules="formRules">
- <el-form-item label="商品编号" prop="GoodsNo">
- <el-input placeholder="请输入" v-model="formData.GoodsNo" />
- </el-form-item>
- <el-form-item label="履约方式" prop="PerformanceTemplateID" v-if="code === 'warehousing_goods_sell'">
- <component :is="components.performance" v-model="performanceId" />
- </el-form-item>
- <el-form-item label="货币类型" prop="ZSCurrencyType">
- <el-radio-group v-model="formData.ZSCurrencyType">
- <el-radio :label="item.value" v-for="(item, index) in enums.currencyTypeList" :key="index">
- {{ item.label }}
- </el-radio>
- </el-radio-group>
- </el-form-item>
- <el-form-item :label="`价格(${currencyInfo?.enumitemvalue})`" prop="Price">
- <el-input-number placeholder="请输入" :min="0" :max="maxValue" :precision="2" v-model="formData.Price" />
- </el-form-item>
- <el-form-item label="主石重量(克拉)" prop="Weight">
- <el-input-number placeholder="请输入" :min="0" :max="maxValue" :precision="2" v-model="formData.Weight" />
- </el-form-item>
- <el-form-item label="款式" prop="ZSStyleType">
- <el-select v-model="formData.ZSStyleType">
- <el-option :label="item.label" :value="item.value" v-for="(item, index) in enums.styleTypeList"
- :key="index" />
- </el-select>
- </el-form-item>
- <el-form-item label="尺寸" prop="Size">
- <div class="el-form-item--col">
- <el-input v-model="formData.Size1" />
- <span>×</span>
- <el-input v-model="formData.Size2" />
- <span>×</span>
- <el-input v-model="formData.Size3" />
- </div>
- </el-form-item>
- <el-form-item label="形状" prop="ZSShapeType">
- <el-select v-model="shapeId" @change="shapeChange">
- <el-option :label="item.label" :value="item.value" v-for="(item, index) in enums.shapeTypeList"
- :key="index" />
- </el-select>
- </el-form-item>
- <el-form-item label="切工" prop="ZSCutType1">
- <el-select v-model="formData.ZSCutType1" clearable>
- <el-option :label="item.label" :value="item.value" v-for="(item, index) in enums.cutTypeList"
- :key="index" />
- </el-select>
- </el-form-item>
- <el-form-item label="颜色" prop="ZSColorType1">
- <el-select v-model="formData.ZSColorType1">
- <el-option :label="item.label" :value="item.value" v-for="(item, index) in enums.colorTypeList"
- :key="index" />
- </el-select>
- </el-form-item>
- <el-form-item label="抛光" prop="ZSPolishType1">
- <el-select v-model="formData.ZSPolishType1" clearable>
- <el-option :label="item.label" :value="item.value" v-for="(item, index) in enums.polishTypeList"
- :key="index" />
- </el-select>
- </el-form-item>
- <el-form-item label="净度" prop="ZSClarityType1">
- <el-select v-model="formData.ZSClarityType1">
- <el-option :label="item.label" :value="item.value" v-for="(item, index) in enums.clarityTypeList"
- :key="index" />
- </el-select>
- </el-form-item>
- <el-form-item label="荧光" prop="ZSFluorescenceType1">
- <el-select v-model="formData.ZSFluorescenceType1" clearable>
- <el-option :label="item.label" :value="item.value" v-for="(item, index) in enums.fluorescenceTypeList"
- :key="index" />
- </el-select>
- </el-form-item>
- <el-form-item label="对称" prop="ZSSymmetryType1">
- <el-select v-model="formData.ZSSymmetryType1" clearable>
- <el-option :label="item.label" :value="item.value" v-for="(item, index) in enums.symmetryTypeList"
- :key="index" />
- </el-select>
- </el-form-item>
- <el-form-item :label="`市场价(${currencyInfo?.enumitemvalue})`" prop="MarketPrice">
- <el-input-number placeholder="请输入" :min="0" :max="maxValue" :precision="2" v-model="formData.MarketPrice" />
- </el-form-item>
- <el-form-item label="仓库" prop="WarehouseID">
- <el-select v-model="formData.WarehouseID">
- <el-option :label="item.warehousename" :value="item.autoid" v-for="(item, index) in warehouseList"
- :key="index" />
- </el-select>
- </el-form-item>
- <el-form-item label="镶嵌材料" prop="SettingMaterial">
- <el-input placeholder="请输入" v-model="formData.SettingMaterial" />
- </el-form-item>
- <el-form-item label="证书类型" prop="ZSCertType">
- <el-select v-model="formData.ZSCertType" clearable>
- <el-option :label="item.label" :value="item.value" v-for="(item, index) in enums.certTypeList"
- :key="index" />
- </el-select>
- </el-form-item>
- <el-form-item label="证书编号" prop="CerNo">
- <el-input placeholder="请输入" v-model="formData.CerNo" />
- </el-form-item>
- <el-form-item label="配石描述" prop="StoneDesc">
- <el-input placeholder="请输入" v-model="formData.StoneDesc" />
- </el-form-item>
- <el-form-item label="商品图片" prop="ImagePath">
- <app-upload :file-types="['image']" type-message="请选择正确的图片类型" @change="onUploadChange" />
- </el-form-item>
- <el-form-item class="el-form-item--row" label="备注" prop="Remark">
- <el-input type="textarea" v-model="formData.Remark" />
- </el-form-item>
- </el-form>
- </template>
- <script lang="ts" setup>
- import { ref, PropType, defineAsyncComponent } from 'vue'
- import { ElMessage, FormInstance, FormRules } from 'element-plus'
- import { regular } from '@/constants/regex'
- import { Category } from '@/constants/diamond'
- import { maxValue } from '@/constants/common'
- import { useDiamondForm } from '@/business/goods'
- import AppUpload from '@pc/components/base/upload/index.vue'
- defineProps({
- code: String,
- selectedRow: {
- type: Object as PropType<Ermcp.UserRole>,
- default: () => ({})
- }
- })
- const components = {
- performance: defineAsyncComponent(() => import('@pc/components/modules/performance/index.vue')),
- }
- const emit = defineEmits(['cancel'])
- const { loading, formData, performanceId, shapeId, enums, warehouseList, currencyInfo, addOrUpdate } = useDiamondForm(Category.Jewelry)
- const formRef = ref<FormInstance>()
- const formRules: FormRules = {
- ZSCategory: [{ required: true, message: '请选择商品分类' }],
- GoodsNo: [{ required: true, message: '请输入商品编号', trigger: 'blur' }],
- SettingMaterial: [{ required: true, message: '请输入镶嵌材料', trigger: 'blur' }],
- ZSCurrencyType: [{ required: true, message: '请选择货币类型' }],
- ZSStyleType: [{ required: true, message: '请选择款式' }],
- Price: [{
- required: true,
- message: '请输入价格',
- pattern: regular.positive.reg
- }],
- Weight: [{
- required: true,
- message: '请输入主石重量',
- pattern: regular.positive.reg
- }],
- ZSColorType1: [{ required: true, message: '请选择颜色' }],
- ZSClarityType1: [{ required: true, message: '请选择净度' }],
- WarehouseID: [{ required: true, message: '请选择仓库' }],
- PerformanceTemplateID: [{
- required: true,
- validator: (rule, value, callback) => {
- if (performanceId.value) {
- callback()
- } else {
- callback(new Error('请选择履约方式'))
- }
- }
- }],
- ZSShapeType: [{
- required: true,
- validator: (rule, value, callback) => {
- if (shapeId.value) {
- callback()
- } else {
- callback(new Error('请选择形状'))
- }
- }
- }],
- Size: [{
- validator: (rule, value, callback) => {
- const { Size1, Size2, Size3 } = formData
- if ((!Size1 && !Size2 && !Size3) || (Size1 && Size2 && Size3)) {
- callback()
- } else {
- callback(new Error('请输入尺寸'))
- }
- }
- }],
- }
- // 选择形状
- const shapeChange = (value: number) => {
- if (value) {
- formData.ZSShapeType = [value]
- } else {
- formData.ZSShapeType = []
- }
- }
- const onUploadChange = (file: { filePath: string }) => {
- formData.ImagePath = file.filePath
- }
- const onSubmit = () => {
- formRef.value?.validate((valid) => {
- if (valid) {
- addOrUpdate().then(() => {
- ElMessage.success('提交成功')
- emit('cancel', true)
- }).catch((err) => {
- ElMessage.error('提交失败:' + err)
- })
- }
- })
- }
- // 暴露组件属性给父组件调用
- defineExpose({
- loading,
- submit: onSubmit
- })
- </script>
|