| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383 |
- <template>
- <view class="jnpf-wrap jnpf-wrap-workflow">
- <u-form :model="dataForm" :rules="rules" ref="dataForm" :errorType="['toast']" label-position="left"
- label-width="150" label-align="left" v-show="hide">
- <view class="u-p-l-20 u-p-r-20 form-item-box">
- <u-form-item label="订单编码" prop="orderCode" v-if="judgeShow('orderCode')"
- :required="requiredList.orderCode">
- <u-input v-model="dataForm.orderCode" placeholder="订单编码" disabled input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="客户名称" prop="customerId" :required="requiredList.customerName"
- v-if="judgeShow('customerName')">
- <JnpfTreeSelect v-model="dataForm.customerId" placeholder="请选择客户名称" :options="customerOptions"
- @change="onCustomerChange" :props="props" :disabled="judgeWrite('customerName')" />
- </u-form-item>
- <u-form-item label="业务人员" prop="salesmanId" :required="requiredList.salesmanId"
- v-if="judgeShow('salesmanId')">
- <JnpfUserSelect v-model="dataForm.salesmanId" placeholder="请选择业务人员" @change="onChange"
- :disabled="judgeWrite('salesmanId')" />
- </u-form-item>
- <u-form-item label="订单日期" prop="orderDate" :required="requiredList.orderDate"
- v-if="judgeShow('orderDate')">
- <JnpfDatePicker format="yyyy-MM-dd" placeholder="请选择订单日期" v-model="dataForm.orderDate"
- :disabled="judgeWrite('orderDate')" />
- </u-form-item>
- </view>
- <view class="jnpf-card">
- <view class="u-p-l-20 u-p-r-20 form-item-box">
- <u-form-item label="付款方式" prop="paymentMode" :required="requiredList.paymentMode"
- v-if="judgeShow('paymentMode')">
- <JnpfSelect v-model="dataForm.paymentMode" placeholder="请选择付款方式" :options="options"
- :disabled="judgeWrite('paymentMode')" />
- </u-form-item>
- <u-form-item label="付款金额" prop="receivableMoney" v-if="judgeShow('receivableMoney')"
- :required="requiredList.receivableMoney">
- <u-input v-model="dataForm.receivableMoney" type="number" placeholder="付款金额"
- :disabled="judgeWrite('receivableMoney')" input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="定金比率" prop="earnestRate" v-if="judgeShow('earnestRate')"
- :required="requiredList.earnestRate">
- <u-input v-model="dataForm.earnestRate" type="number" placeholder="请输入定金比率"
- :disabled="judgeWrite('earnestRate')" input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="预付定金" prop="prepayEarnest" v-if="judgeShow('prepayEarnest')"
- :required="requiredList.prepayEarnest">
- <u-input v-model="dataForm.prepayEarnest" type="number" placeholder="请输入预付定金"
- :disabled="judgeWrite('prepayEarnest')" input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="运输方式" prop="transportMode" v-if="judgeShow('transportMode')"
- :required="requiredList.transportMode">
- <JnpfSelect v-model="dataForm.transportMode" placeholder="请选择运输方式" :options="transportOptions"
- :disabled="judgeWrite('transportMode')" />
- </u-form-item>
- <u-form-item label="发货日期" prop="deliveryDate" v-if="judgeShow('deliveryDate')"
- :required="requiredList.deliveryDate">
- <JnpfDatePicker format="yyyy-MM-dd" placeholder="请选择发货日期" v-model="dataForm.deliveryDate"
- :disabled="judgeWrite('deliveryDate')" />
- </u-form-item>
- <u-form-item label="发货地址" prop="deliveryAddress" v-if="judgeShow('deliveryAddress')"
- :required="requiredList.deliveryAddress">
- <u-input v-model="dataForm.deliveryAddress" type="textarea" placeholder="请输入发货地址"
- :disabled="judgeWrite('deliveryAddress')" input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="订单备注" prop="description" v-if="judgeShow('description')"
- :required="requiredList.description">
- <u-input v-model="dataForm.description" type="textarea" placeholder="请输入订单备注"
- :disabled="judgeWrite('description')" input-align="right"></u-input>
- </u-form-item>
- <!-- #ifndef APP-HARMONY -->
- <u-form-item label="相关附件" prop="fileJson" :required="requiredList.fileJson">
- <JnpfUploadFile v-model="fileList" :disabled="judgeWrite('fileJson')" />
- </u-form-item>
- <!-- #endif -->
- </view>
- </view>
- <view class="jnpf-table" v-if="judgeShow('goodsList')">
- <view class="jnpf-table-item-title u-flex u-row-between">
- <text class="jnpf-table-item-title-num">商品添购</text>
- </view>
- <view class="jnpf-table-item" v-for="(item,i) in dataForm.goodsList" :key="i">
- <view class="jnpf-table-item-title u-flex u-row-between">
- <text class="jnpf-table-item-title-num">({{i+1}})</text>
- <view class="jnpf-table-delete-btn" v-if="!judgeWrite('goodsList')" @click="delGoods(i)">
- 删除
- </view>
- </view>
- <view class="u-p-l-20 u-p-r-20 form-item-box">
- <u-form-item label="商品名称" prop="dataForm.goodsList[i].goodsId"
- :required="requiredList['goodsList-goodsId']">
- <JnpfTreeSelect v-model="dataForm.goodsList[i].goodsId" placeholder="请选择商品名称"
- :options="goodsOptions" @change="onGoodsChange($event,i)" :props="props"
- :disabled="judgeWrite('goodsList')" />
- </u-form-item>
- <u-form-item label="规格型号" prop="dataForm.goodsList[i].specifications"
- :required="requiredList['goodsList-specifications']">
- <u-input v-model="dataForm.goodsList[i].specifications" placeholder="规格型号"
- :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="单位" prop="dataForm.goodsList[i].unit"
- :required="requiredList['goodsList-unit']">
- <u-input v-model="dataForm.goodsList[i].unit" placeholder="单位"
- :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="数量" prop="dataForm.goodsList[i].qty"
- :required="requiredList['goodsList-qty']">
- <u-input v-model="dataForm.goodsList[i].qty" placeholder="数量" type="number"
- @input="count(i)" :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="单价" prop="dataForm.goodsList[i].price"
- :required="requiredList['goodsList-price']">
- <u-input v-model="dataForm.goodsList[i].price" placeholder="单价" type="number"
- @input="count(i)" :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="金额" prop="dataForm.goodsList[i].amount"
- :required="requiredList['goodsList-amount']">
- <u-input v-model="dataForm.goodsList[i].amount" type="number" placeholder="金额" disabled
- input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="折扣%" prop="dataForm.goodsList[i].discount"
- :required="requiredList['goodsList-discount']">
- <u-input v-model="dataForm.goodsList[i].discount" placeholder="折扣" type="number"
- @input="count(i)" :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="税率%" prop="dataForm.goodsList[i].cess"
- :required="requiredList['goodsList-cess']">
- <u-input v-model="dataForm.goodsList[i].cess" placeholder="税率" type="number"
- @input="count(i)" :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="实际单价" prop="dataForm.goodsList[i].actualPrice"
- :required="requiredList['goodsList-actualPrice']">
- <u-input v-model="dataForm.goodsList[i].actualPrice" placeholder="实际单价" type="number"
- disabled input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="实际金额" prop="dataForm.goodsList[i].actualAmount"
- :required="requiredList['goodsList-actualAmount']">
- <u-input v-model="dataForm.goodsList[i].actualAmount" type="number" placeholder="实际金额"
- disabled input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="备注" prop="dataForm.goodsList[i].description"
- :required="requiredList['goodsList-description']">
- <u-input v-model="dataForm.goodsList[i].description" placeholder="备注" type="textarea"
- :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
- </u-form-item>
- </view>
- </view>
- <view class="jnpf-table-addBtn" @click="addGoods" v-if="!judgeWrite('goodsList')">
- <u-icon name="plus" color="#2979ff"></u-icon>商品添购
- </view>
- </view>
- <view class="jnpf-table" v-if="judgeShow('collectionPlanList')">
- <view class="jnpf-table-item-title u-flex u-row-between">
- <text class="jnpf-table-item-title-num">收款计划</text>
- </view>
- <view class="jnpf-table-item" v-for="(item,i) in dataForm.collectionPlanList" :key="i">
- <view class="jnpf-table-item-title u-flex u-row-between">
- <text class="jnpf-table-item-title-num">({{i+1}})</text>
- <view class="jnpf-table-delete-btn" v-if="!judgeWrite('collectionPlanList')"
- @click="delPlan(i)">删除
- </view>
- </view>
- <view class="u-p-l-20 u-p-r-20 form-item-box">
- <u-form-item label="收款日期" prop="dataForm.collectionPlanList[i].receivableDate"
- :required="requiredList['collectionPlanList-receivableDate']">
- <JnpfDatePicker format="yyyy-MM-dd HH:mm:ss" placeholder="请选择收款日期"
- v-model="dataForm.collectionPlanList[i].receivableDate"
- :disabled="judgeWrite('collectionPlanList')" />
- </u-form-item>
- <u-form-item label="收款比率%" prop="dataForm.collectionPlanList[i].receivableRate"
- :required="requiredList['collectionPlanList-receivableRate']">
- <u-input v-model="dataForm.collectionPlanList[i].receivableRate" placeholder="收款比率"
- type="number" :disabled="judgeWrite('collectionPlanList')"
- input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="收款金额" prop="dataForm.collectionPlanList[i].receivableMoney"
- :required="requiredList['collectionPlanList-receivableMoney']">
- <u-input v-model="dataForm.collectionPlanList[i].receivableMoney" placeholder="收款金额"
- type="number" :disabled="judgeWrite('collectionPlanList')"
- input-align="right"></u-input>
- </u-form-item>
- <u-form-item label="收款方式" prop="dataForm.collectionPlanList[i].receivableMode"
- :required="requiredList['collectionPlanList-receivableMode']">
- <JnpfSelect v-model="dataForm.collectionPlanList[i].receivableMode" placeholder="请选择收款方式"
- :options="options" :disabled="judgeWrite('collectionPlanList')" />
- </u-form-item>
- <u-form-item label="收款摘要" prop="dataForm.collectionPlanList[i].abstract"
- :required="requiredList['collectionPlanList-abstract']">
- <u-input v-model="dataForm.collectionPlanList[i].abstract" placeholder="收款摘要"
- type="textarea" :disabled="judgeWrite('collectionPlanList')" input-align="right">
- </u-input>
- </u-form-item>
- </view>
- </view>
- <view class="jnpf-table-addBtn" @click="addPlan" v-if="!judgeWrite('collectionPlanList')">
- <u-icon name="plus" color="#2979ff"></u-icon>收款计划
- </view>
- </view>
- </u-form>
- </view>
- </template>
- <script>
- import comMixin from '../mixin'
- import {
- getGoodsList,
- getCustomerList,
- } from '@/api/apply/order'
- export default {
- name: 'crmOrder',
- mixins: [comMixin],
- data() {
- return {
- hide: false,
- billEnCode: 'OrderNumber',
- dataForm: {
- id: '',
- customerName: '',
- salesmanId: '',
- orderDate: undefined,
- orderCode: '',
- paymentMode: '',
- receivableMoney: undefined,
- earnestRate: undefined,
- prepayEarnest: undefined,
- transportMode: '',
- deliveryDate: undefined,
- deliveryAddress: '',
- description: '',
- customerId: '',
- salesmanName: '',
- goodsList: [],
- collectionPlanList: [],
- fileJson: ''
- },
- rules: {
- customerId: [{
- required: true,
- message: '客户名称不能为空',
- trigger: 'input'
- }],
- salesmanId: [{
- required: true,
- message: '业务人员不能为空',
- trigger: 'input'
- }],
- orderDate: [{
- required: true,
- message: '订单日期不能为空',
- trigger: 'change',
- type: 'number'
- }],
- paymentMode: [{
- required: true,
- message: '付款方式不能为空',
- trigger: 'input'
- }]
- },
- options: [{
- id: '现金',
- fullName: '现金'
- }, {
- id: '转帐',
- fullName: '转帐'
- }, {
- id: '汇票',
- fullName: '汇票'
- }],
- transportOptions: [{
- id: '快递',
- fullName: '快递'
- }, {
- id: '物流',
- fullName: '物流'
- }, {
- id: '配送',
- fullName: '配送'
- }, {
- id: '自提',
- fullName: '自提'
- }],
- props: {
- label: 'text',
- value: 'id',
- children: 'children'
- },
- goodsOptions: [],
- customerOptions: []
- }
- },
- created() {
- uni.showLoading({
- title: '正在加载.....',
- mask: true
- });
- setTimeout(() => {
- this.hide = true
- this.initData()
- uni.hideLoading()
- }, 800)
- },
- methods: {
- initData() {
- getGoodsList().then(res => {
- this.goodsOptions = res.data.list
- })
- getCustomerList().then(res => {
- this.customerOptions = res.data.list
- })
- },
- onChange(val, e) {
- this.dataForm.salesmanName = e.fullName
- },
- addGoods() {
- const item = {
- goodsId: '',
- goodsCode: '',
- goodsName: '',
- specifications: '',
- unit: '',
- qty: undefined,
- price: undefined,
- amount: '',
- discount: undefined,
- cess: undefined,
- actualPrice: undefined,
- actualAmount: undefined,
- description: ''
- }
- this.dataForm.goodsList.push(item)
- },
- delGoods(index) {
- this.dataForm.goodsList.splice(index, 1)
- },
- addPlan() {
- const item = {
- receivableDate: undefined,
- receivableRate: undefined,
- receivableMoney: undefined,
- receivableMode: '',
- abstract: ''
- }
- this.dataForm.collectionPlanList.push(item)
- },
- delPlan(index) {
- this.dataForm.collectionPlanList.splice(index, 1)
- },
- onGoodsChange(e, i) {
- const goods = e[0]
- this.dataForm.goodsList[i] = {
- goodsId: goods.id,
- goodsCode: goods.code,
- goodsName: goods.text,
- specifications: goods.specifications,
- unit: goods.unit,
- qty: 1,
- price: goods.price,
- amount: goods.price,
- discount: 100,
- cess: 0,
- actualPrice: goods.price,
- actualAmount: goods.price,
- description: ''
- }
- this.$forceUpdate()
- },
- onCustomerChange(val, e) {
- this.dataForm.customerName = e.text
- },
- count(i) {
- this.$nextTick(() => {
- const row = this.dataForm.goodsList[i]
- //金额 = 数量*单价
- row.amount = this.jnpf.toDecimal(parseFloat(row.price) * parseFloat(row.qty))
- //折扣价 = (单价*折扣)
- var discountPrice = row.price * (row.discount / 100);
- //实际单价 = 折扣价 * (1 + (税率 / 100))
- row.actualPrice = this.jnpf.toDecimal(discountPrice * (1 + (row.cess / 100)));
- //实际金额
- row.actualAmount = this.jnpf.toDecimal(parseFloat(row.actualPrice) * parseFloat(row
- .qty))
- this.$forceUpdate()
- })
- }
- }
- }
- </script>
|