You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
wangzong/pages/product/addGoods/singleSpecification.vue

199 lines
4.4 KiB

8 months ago
<template>
<view class="container">
<select-form :platformClassification="formList" :form="singleSpecification" @input="input"></select-form>
<view class="more_than" @click="selectMoreThan" v-if="moreThanFlag">
<view>更多</view>
</view>
<view class="handle">
<view class="button" @click="saveSingleSpecification">
保存
</view>
</view>
</view>
</template>
<script>
// +----------------------------------------------------------------------
// | CRMEB [ CRMEB赋能开发者,助力企业发展 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2016~2024 https://www.crmeb.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed CRMEB并不是自由软件,未经许可不能去掉CRMEB相关版权
// +----------------------------------------------------------------------
// | Author: CRMEB Team <admin@crmeb.com>
// +----------------------------------------------------------------------
import selectForm from '../components/selectForm.vue';
import { navigateTo, navigateBack, serialize, setStorage, getStorage} from '../../../libs/uniApi.js';
// 单规格商品 attrValue
export default {
components:{
selectForm
},
data() {
return {
singleSpecification: {
price: '', // 售价
cost: '', // 成本价
ot_price: '', // 原价
stock: '', // 库存
bar_code: '', // 商品编号
weight: '', // 重量
volume: '', // 体积
image: '',
extension_one: '',
extension_two: ''
},
moreThanFlag: true,
formList: [
{
id: 1,
label: '售价',
type: 'input',
model: 'price',
holder: '请填写售价'
},
{
id: 2,
label: '成本价',
type: 'input',
holder: '请填写成本价',
model: 'cost'
},
{
id: 3,
label: '原价',
type: 'input',
holder: '请填写原价',
model: 'ot_price'
},
{
id: 4,
label: '库存',
type: 'input',
holder: '请填写库存',
model: 'stock'
}
],
moreThanList: [
{
id: 5,
label: '商品编号',
type: 'input',
holder: '请填写商品编号',
model: 'bar_code'
},
{
id: 6,
label: '重量',
type: 'input',
holder: '请输入重量',
model: 'weight'
},
{
id: 7,
label: '体积',
type: 'input',
holder: '请输入体积',
model: 'volume'
},
{
id: 8,
label: '佣金(一级)',
type: 'input',
holder: '请输入一级佣金',
model: 'extension_one'
},
{
id: 8,
label: '佣金(二级)',
type: 'input',
holder: '请输入二级佣金',
model: 'extension_two'
}
],
}
},
watch: {
singleSpecification: {
handler(val) {
this.singleSpecification = val
},
deep: true
}
},
onShow() {
if(getStorage('addGoodsFormData').image) {
this.singleSpecification.image = getStorage('addGoodsFormData').image;
}
if(getStorage('singleSpecification')) {
Object.keys(this.singleSpecification).forEach(item => {
if(getStorage('singleSpecification')[item]) {
this.singleSpecification[item] = getStorage('singleSpecification')[item]
}
})
}
},
methods: {
selectMoreThan() {
this.formList = this.formList.concat(this.moreThanList);
this.moreThanFlag = false;
},
spliceMoreThan() {
this.moreThanFlag = true;
this.formList.splice(3, 4);
},
input(val) {
this.singleSpecification = val
},
// 保存
saveSingleSpecification() {
setStorage('singleSpecification', this.singleSpecification);
navigateBack(1);
}
}
}
</script>
<style lang="scss" scoped>
.container {
padding-bottom: 126rpx;
}
.more_than {
background: #FFFFFF;
border-radius: 10px;
margin: auto;
margin-top: 15rpx;
display: flex;
align-items: center;
justify-content: center;
width: 710rpx;
height: 84rpx;
color: #333333;
font-size: 30rpx;
}
.handle {
position: fixed;
left: 0;
bottom: 0;
width: 100%;
height: 126rpx;
background: #FFFFFF;
display: flex;
align-items: center;
justify-content: center;
.button {
display: flex;
align-items: center;
justify-content: center;
color: #FFFFFF;
font-size: 32rpx;
width: 690rpx;
height: 86rpx;
background: #E93323;
border-radius: 43rpx;
}
}
</style>