index.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383
  1. <template>
  2. <view class="jnpf-wrap jnpf-wrap-workflow">
  3. <u-form :model="dataForm" :rules="rules" ref="dataForm" :errorType="['toast']" label-position="left"
  4. label-width="150" label-align="left" v-show="hide">
  5. <view class="u-p-l-20 u-p-r-20 form-item-box">
  6. <u-form-item label="订单编码" prop="orderCode" v-if="judgeShow('orderCode')"
  7. :required="requiredList.orderCode">
  8. <u-input v-model="dataForm.orderCode" placeholder="订单编码" disabled input-align="right"></u-input>
  9. </u-form-item>
  10. <u-form-item label="客户名称" prop="customerId" :required="requiredList.customerName"
  11. v-if="judgeShow('customerName')">
  12. <JnpfTreeSelect v-model="dataForm.customerId" placeholder="请选择客户名称" :options="customerOptions"
  13. @change="onCustomerChange" :props="props" :disabled="judgeWrite('customerName')" />
  14. </u-form-item>
  15. <u-form-item label="业务人员" prop="salesmanId" :required="requiredList.salesmanId"
  16. v-if="judgeShow('salesmanId')">
  17. <JnpfUserSelect v-model="dataForm.salesmanId" placeholder="请选择业务人员" @change="onChange"
  18. :disabled="judgeWrite('salesmanId')" />
  19. </u-form-item>
  20. <u-form-item label="订单日期" prop="orderDate" :required="requiredList.orderDate"
  21. v-if="judgeShow('orderDate')">
  22. <JnpfDatePicker format="yyyy-MM-dd" placeholder="请选择订单日期" v-model="dataForm.orderDate"
  23. :disabled="judgeWrite('orderDate')" />
  24. </u-form-item>
  25. </view>
  26. <view class="jnpf-card">
  27. <view class="u-p-l-20 u-p-r-20 form-item-box">
  28. <u-form-item label="付款方式" prop="paymentMode" :required="requiredList.paymentMode"
  29. v-if="judgeShow('paymentMode')">
  30. <JnpfSelect v-model="dataForm.paymentMode" placeholder="请选择付款方式" :options="options"
  31. :disabled="judgeWrite('paymentMode')" />
  32. </u-form-item>
  33. <u-form-item label="付款金额" prop="receivableMoney" v-if="judgeShow('receivableMoney')"
  34. :required="requiredList.receivableMoney">
  35. <u-input v-model="dataForm.receivableMoney" type="number" placeholder="付款金额"
  36. :disabled="judgeWrite('receivableMoney')" input-align="right"></u-input>
  37. </u-form-item>
  38. <u-form-item label="定金比率" prop="earnestRate" v-if="judgeShow('earnestRate')"
  39. :required="requiredList.earnestRate">
  40. <u-input v-model="dataForm.earnestRate" type="number" placeholder="请输入定金比率"
  41. :disabled="judgeWrite('earnestRate')" input-align="right"></u-input>
  42. </u-form-item>
  43. <u-form-item label="预付定金" prop="prepayEarnest" v-if="judgeShow('prepayEarnest')"
  44. :required="requiredList.prepayEarnest">
  45. <u-input v-model="dataForm.prepayEarnest" type="number" placeholder="请输入预付定金"
  46. :disabled="judgeWrite('prepayEarnest')" input-align="right"></u-input>
  47. </u-form-item>
  48. <u-form-item label="运输方式" prop="transportMode" v-if="judgeShow('transportMode')"
  49. :required="requiredList.transportMode">
  50. <JnpfSelect v-model="dataForm.transportMode" placeholder="请选择运输方式" :options="transportOptions"
  51. :disabled="judgeWrite('transportMode')" />
  52. </u-form-item>
  53. <u-form-item label="发货日期" prop="deliveryDate" v-if="judgeShow('deliveryDate')"
  54. :required="requiredList.deliveryDate">
  55. <JnpfDatePicker format="yyyy-MM-dd" placeholder="请选择发货日期" v-model="dataForm.deliveryDate"
  56. :disabled="judgeWrite('deliveryDate')" />
  57. </u-form-item>
  58. <u-form-item label="发货地址" prop="deliveryAddress" v-if="judgeShow('deliveryAddress')"
  59. :required="requiredList.deliveryAddress">
  60. <u-input v-model="dataForm.deliveryAddress" type="textarea" placeholder="请输入发货地址"
  61. :disabled="judgeWrite('deliveryAddress')" input-align="right"></u-input>
  62. </u-form-item>
  63. <u-form-item label="订单备注" prop="description" v-if="judgeShow('description')"
  64. :required="requiredList.description">
  65. <u-input v-model="dataForm.description" type="textarea" placeholder="请输入订单备注"
  66. :disabled="judgeWrite('description')" input-align="right"></u-input>
  67. </u-form-item>
  68. <!-- #ifndef APP-HARMONY -->
  69. <u-form-item label="相关附件" prop="fileJson" :required="requiredList.fileJson">
  70. <JnpfUploadFile v-model="fileList" :disabled="judgeWrite('fileJson')" />
  71. </u-form-item>
  72. <!-- #endif -->
  73. </view>
  74. </view>
  75. <view class="jnpf-table" v-if="judgeShow('goodsList')">
  76. <view class="jnpf-table-item-title u-flex u-row-between">
  77. <text class="jnpf-table-item-title-num">商品添购</text>
  78. </view>
  79. <view class="jnpf-table-item" v-for="(item,i) in dataForm.goodsList" :key="i">
  80. <view class="jnpf-table-item-title u-flex u-row-between">
  81. <text class="jnpf-table-item-title-num">({{i+1}})</text>
  82. <view class="jnpf-table-delete-btn" v-if="!judgeWrite('goodsList')" @click="delGoods(i)">
  83. 删除
  84. </view>
  85. </view>
  86. <view class="u-p-l-20 u-p-r-20 form-item-box">
  87. <u-form-item label="商品名称" prop="dataForm.goodsList[i].goodsId"
  88. :required="requiredList['goodsList-goodsId']">
  89. <JnpfTreeSelect v-model="dataForm.goodsList[i].goodsId" placeholder="请选择商品名称"
  90. :options="goodsOptions" @change="onGoodsChange($event,i)" :props="props"
  91. :disabled="judgeWrite('goodsList')" />
  92. </u-form-item>
  93. <u-form-item label="规格型号" prop="dataForm.goodsList[i].specifications"
  94. :required="requiredList['goodsList-specifications']">
  95. <u-input v-model="dataForm.goodsList[i].specifications" placeholder="规格型号"
  96. :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
  97. </u-form-item>
  98. <u-form-item label="单位" prop="dataForm.goodsList[i].unit"
  99. :required="requiredList['goodsList-unit']">
  100. <u-input v-model="dataForm.goodsList[i].unit" placeholder="单位"
  101. :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
  102. </u-form-item>
  103. <u-form-item label="数量" prop="dataForm.goodsList[i].qty"
  104. :required="requiredList['goodsList-qty']">
  105. <u-input v-model="dataForm.goodsList[i].qty" placeholder="数量" type="number"
  106. @input="count(i)" :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
  107. </u-form-item>
  108. <u-form-item label="单价" prop="dataForm.goodsList[i].price"
  109. :required="requiredList['goodsList-price']">
  110. <u-input v-model="dataForm.goodsList[i].price" placeholder="单价" type="number"
  111. @input="count(i)" :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
  112. </u-form-item>
  113. <u-form-item label="金额" prop="dataForm.goodsList[i].amount"
  114. :required="requiredList['goodsList-amount']">
  115. <u-input v-model="dataForm.goodsList[i].amount" type="number" placeholder="金额" disabled
  116. input-align="right"></u-input>
  117. </u-form-item>
  118. <u-form-item label="折扣%" prop="dataForm.goodsList[i].discount"
  119. :required="requiredList['goodsList-discount']">
  120. <u-input v-model="dataForm.goodsList[i].discount" placeholder="折扣" type="number"
  121. @input="count(i)" :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
  122. </u-form-item>
  123. <u-form-item label="税率%" prop="dataForm.goodsList[i].cess"
  124. :required="requiredList['goodsList-cess']">
  125. <u-input v-model="dataForm.goodsList[i].cess" placeholder="税率" type="number"
  126. @input="count(i)" :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
  127. </u-form-item>
  128. <u-form-item label="实际单价" prop="dataForm.goodsList[i].actualPrice"
  129. :required="requiredList['goodsList-actualPrice']">
  130. <u-input v-model="dataForm.goodsList[i].actualPrice" placeholder="实际单价" type="number"
  131. disabled input-align="right"></u-input>
  132. </u-form-item>
  133. <u-form-item label="实际金额" prop="dataForm.goodsList[i].actualAmount"
  134. :required="requiredList['goodsList-actualAmount']">
  135. <u-input v-model="dataForm.goodsList[i].actualAmount" type="number" placeholder="实际金额"
  136. disabled input-align="right"></u-input>
  137. </u-form-item>
  138. <u-form-item label="备注" prop="dataForm.goodsList[i].description"
  139. :required="requiredList['goodsList-description']">
  140. <u-input v-model="dataForm.goodsList[i].description" placeholder="备注" type="textarea"
  141. :disabled="judgeWrite('goodsList')" input-align="right"></u-input>
  142. </u-form-item>
  143. </view>
  144. </view>
  145. <view class="jnpf-table-addBtn" @click="addGoods" v-if="!judgeWrite('goodsList')">
  146. <u-icon name="plus" color="#2979ff"></u-icon>商品添购
  147. </view>
  148. </view>
  149. <view class="jnpf-table" v-if="judgeShow('collectionPlanList')">
  150. <view class="jnpf-table-item-title u-flex u-row-between">
  151. <text class="jnpf-table-item-title-num">收款计划</text>
  152. </view>
  153. <view class="jnpf-table-item" v-for="(item,i) in dataForm.collectionPlanList" :key="i">
  154. <view class="jnpf-table-item-title u-flex u-row-between">
  155. <text class="jnpf-table-item-title-num">({{i+1}})</text>
  156. <view class="jnpf-table-delete-btn" v-if="!judgeWrite('collectionPlanList')"
  157. @click="delPlan(i)">删除
  158. </view>
  159. </view>
  160. <view class="u-p-l-20 u-p-r-20 form-item-box">
  161. <u-form-item label="收款日期" prop="dataForm.collectionPlanList[i].receivableDate"
  162. :required="requiredList['collectionPlanList-receivableDate']">
  163. <JnpfDatePicker format="yyyy-MM-dd HH:mm:ss" placeholder="请选择收款日期"
  164. v-model="dataForm.collectionPlanList[i].receivableDate"
  165. :disabled="judgeWrite('collectionPlanList')" />
  166. </u-form-item>
  167. <u-form-item label="收款比率%" prop="dataForm.collectionPlanList[i].receivableRate"
  168. :required="requiredList['collectionPlanList-receivableRate']">
  169. <u-input v-model="dataForm.collectionPlanList[i].receivableRate" placeholder="收款比率"
  170. type="number" :disabled="judgeWrite('collectionPlanList')"
  171. input-align="right"></u-input>
  172. </u-form-item>
  173. <u-form-item label="收款金额" prop="dataForm.collectionPlanList[i].receivableMoney"
  174. :required="requiredList['collectionPlanList-receivableMoney']">
  175. <u-input v-model="dataForm.collectionPlanList[i].receivableMoney" placeholder="收款金额"
  176. type="number" :disabled="judgeWrite('collectionPlanList')"
  177. input-align="right"></u-input>
  178. </u-form-item>
  179. <u-form-item label="收款方式" prop="dataForm.collectionPlanList[i].receivableMode"
  180. :required="requiredList['collectionPlanList-receivableMode']">
  181. <JnpfSelect v-model="dataForm.collectionPlanList[i].receivableMode" placeholder="请选择收款方式"
  182. :options="options" :disabled="judgeWrite('collectionPlanList')" />
  183. </u-form-item>
  184. <u-form-item label="收款摘要" prop="dataForm.collectionPlanList[i].abstract"
  185. :required="requiredList['collectionPlanList-abstract']">
  186. <u-input v-model="dataForm.collectionPlanList[i].abstract" placeholder="收款摘要"
  187. type="textarea" :disabled="judgeWrite('collectionPlanList')" input-align="right">
  188. </u-input>
  189. </u-form-item>
  190. </view>
  191. </view>
  192. <view class="jnpf-table-addBtn" @click="addPlan" v-if="!judgeWrite('collectionPlanList')">
  193. <u-icon name="plus" color="#2979ff"></u-icon>收款计划
  194. </view>
  195. </view>
  196. </u-form>
  197. </view>
  198. </template>
  199. <script>
  200. import comMixin from '../mixin'
  201. import {
  202. getGoodsList,
  203. getCustomerList,
  204. } from '@/api/apply/order'
  205. export default {
  206. name: 'crmOrder',
  207. mixins: [comMixin],
  208. data() {
  209. return {
  210. hide: false,
  211. billEnCode: 'OrderNumber',
  212. dataForm: {
  213. id: '',
  214. customerName: '',
  215. salesmanId: '',
  216. orderDate: undefined,
  217. orderCode: '',
  218. paymentMode: '',
  219. receivableMoney: undefined,
  220. earnestRate: undefined,
  221. prepayEarnest: undefined,
  222. transportMode: '',
  223. deliveryDate: undefined,
  224. deliveryAddress: '',
  225. description: '',
  226. customerId: '',
  227. salesmanName: '',
  228. goodsList: [],
  229. collectionPlanList: [],
  230. fileJson: ''
  231. },
  232. rules: {
  233. customerId: [{
  234. required: true,
  235. message: '客户名称不能为空',
  236. trigger: 'input'
  237. }],
  238. salesmanId: [{
  239. required: true,
  240. message: '业务人员不能为空',
  241. trigger: 'input'
  242. }],
  243. orderDate: [{
  244. required: true,
  245. message: '订单日期不能为空',
  246. trigger: 'change',
  247. type: 'number'
  248. }],
  249. paymentMode: [{
  250. required: true,
  251. message: '付款方式不能为空',
  252. trigger: 'input'
  253. }]
  254. },
  255. options: [{
  256. id: '现金',
  257. fullName: '现金'
  258. }, {
  259. id: '转帐',
  260. fullName: '转帐'
  261. }, {
  262. id: '汇票',
  263. fullName: '汇票'
  264. }],
  265. transportOptions: [{
  266. id: '快递',
  267. fullName: '快递'
  268. }, {
  269. id: '物流',
  270. fullName: '物流'
  271. }, {
  272. id: '配送',
  273. fullName: '配送'
  274. }, {
  275. id: '自提',
  276. fullName: '自提'
  277. }],
  278. props: {
  279. label: 'text',
  280. value: 'id',
  281. children: 'children'
  282. },
  283. goodsOptions: [],
  284. customerOptions: []
  285. }
  286. },
  287. created() {
  288. uni.showLoading({
  289. title: '正在加载.....',
  290. mask: true
  291. });
  292. setTimeout(() => {
  293. this.hide = true
  294. this.initData()
  295. uni.hideLoading()
  296. }, 800)
  297. },
  298. methods: {
  299. initData() {
  300. getGoodsList().then(res => {
  301. this.goodsOptions = res.data.list
  302. })
  303. getCustomerList().then(res => {
  304. this.customerOptions = res.data.list
  305. })
  306. },
  307. onChange(val, e) {
  308. this.dataForm.salesmanName = e.fullName
  309. },
  310. addGoods() {
  311. const item = {
  312. goodsId: '',
  313. goodsCode: '',
  314. goodsName: '',
  315. specifications: '',
  316. unit: '',
  317. qty: undefined,
  318. price: undefined,
  319. amount: '',
  320. discount: undefined,
  321. cess: undefined,
  322. actualPrice: undefined,
  323. actualAmount: undefined,
  324. description: ''
  325. }
  326. this.dataForm.goodsList.push(item)
  327. },
  328. delGoods(index) {
  329. this.dataForm.goodsList.splice(index, 1)
  330. },
  331. addPlan() {
  332. const item = {
  333. receivableDate: undefined,
  334. receivableRate: undefined,
  335. receivableMoney: undefined,
  336. receivableMode: '',
  337. abstract: ''
  338. }
  339. this.dataForm.collectionPlanList.push(item)
  340. },
  341. delPlan(index) {
  342. this.dataForm.collectionPlanList.splice(index, 1)
  343. },
  344. onGoodsChange(e, i) {
  345. const goods = e[0]
  346. this.dataForm.goodsList[i] = {
  347. goodsId: goods.id,
  348. goodsCode: goods.code,
  349. goodsName: goods.text,
  350. specifications: goods.specifications,
  351. unit: goods.unit,
  352. qty: 1,
  353. price: goods.price,
  354. amount: goods.price,
  355. discount: 100,
  356. cess: 0,
  357. actualPrice: goods.price,
  358. actualAmount: goods.price,
  359. description: ''
  360. }
  361. this.$forceUpdate()
  362. },
  363. onCustomerChange(val, e) {
  364. this.dataForm.customerName = e.text
  365. },
  366. count(i) {
  367. this.$nextTick(() => {
  368. const row = this.dataForm.goodsList[i]
  369. //金额 = 数量*单价
  370. row.amount = this.jnpf.toDecimal(parseFloat(row.price) * parseFloat(row.qty))
  371. //折扣价 = (单价*折扣)
  372. var discountPrice = row.price * (row.discount / 100);
  373. //实际单价 = 折扣价 * (1 + (税率 / 100))
  374. row.actualPrice = this.jnpf.toDecimal(discountPrice * (1 + (row.cess / 100)));
  375. //实际金额
  376. row.actualAmount = this.jnpf.toDecimal(parseFloat(row.actualPrice) * parseFloat(row
  377. .qty))
  378. this.$forceUpdate()
  379. })
  380. }
  381. }
  382. }
  383. </script>