edit.vue 21 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544
  1. <template>
  2. <div>
  3. <!-- <el-button :disabled="data.status !=='新建'" type="primary" size="mini" @click="onShow(drawer = true)">编 辑</el-button> -->
  4. <el-button type="primary" :disabled="data.type === '特殊订单'" size="mini" @click="onShow(drawer = true)">编 辑</el-button>
  5. <el-drawer
  6. :visible.sync="drawer"
  7. direction="rtl"
  8. append-to-body
  9. size="80%">
  10. <div slot="title">
  11. <div class="flex-align-center">
  12. <p><span style="font-size:14px">订单合计:</span><span style="color:red;font-size:16px;"><b>¥&nbsp;{{tool.formatAmount(data.defaultamount,2)}}</b></span></p>
  13. </div>
  14. <div class="flex-align-center">
  15. <p v-if="freefreightamount" style="font-size: 13px !important;color: #8888;font-weight: normal">{{checkFreefreightamount}}</p>
  16. </div>
  17. </div>
  18. <div class="drawer__panel">
  19. <!-- 项目订单显示信息 -->
  20. <div v-if="data.type === '项目订单'" class="reveive__panel normal-margin flex-align-center">
  21. <p class="inline-16"><small>项目信息:</small>{{data.projectname}}</p>
  22. <p class="inline-16"><small>合同信息:</small>{{data.contract_title}}</p>
  23. <p class="inline-16"><small>领域:</small>{{data.tradefield}}</p>
  24. <p class="inline-16"><small>品牌:</small>{{data.brandname}}</p>
  25. </div>
  26. <div>
  27. <div class="mt-10">
  28. <p class="normal-title inline-16">支付信息</p>
  29. </div>
  30. <div class="reveive__panel normal-margin">
  31. <p class="flex-align-center"><small>结算企业:&nbsp;</small><b>{{defaultData.finance.enterprisename}}</b>&nbsp;<financeEnterprise v-if="data.type !== '项目订单'" @select="onSelect"></financeEnterprise></p>
  32. <div class="flex-align-center">
  33. <p class="inline-16"><small>账户余额:&nbsp;</small><b>¥{{tool.formatAmount(defaultData.accountclass.balance?defaultData.accountclass.balance:0,2)}}</b></p>
  34. <p class="inline-16"><small>账户名称:&nbsp;</small>{{defaultData.accountclass.accountname?defaultData.accountclass.accountname:'未选择账户'}}</p>
  35. <p><small>本单金额:&nbsp;</small>{{data.rebate_used ? tool.formatAmount(data.defaultamount - rebateamount,2) : data.defaultamount}}</p>
  36. </div>
  37. <div v-if="(data.type === '标准订单' || data.type === '特殊订单') && isusedrebate === 1">
  38. <el-checkbox v-model="checked" :true-label="1" :false-label="0" @change="rebateUsedChange">使用返利金</el-checkbox>
  39. <div v-if="checked" class="flex-align-center">
  40. <p class="inline-16"><b>返利金余额:{{tool.formatAmount(defaultData.rebatebalance,2)}}</b></p>
  41. <el-input class="inline-16" size="mini" style="width:150px" v-model="data.rebateamount" @blur="useRebate(data.rebateamount)" placeholder="输入使用金额"></el-input>
  42. <small>(返利金最高使用比例{{data.order_rebate_userate}})</small>
  43. </div>
  44. </div>
  45. </div>
  46. </div>
  47. <div class="flex-align-center normal-margin">
  48. <div style="flex:1; margin-right:10px">
  49. <div class="mt-10">
  50. <p class="normal-title inline-16">选择财务信息</p>
  51. <el-popover
  52. placement="bottom"
  53. title="选择财务信息"
  54. trigger="click"
  55. v-model="visible2">
  56. <addAmountInfo style="text-align:right" :data="{sys_enterpriseid:data.sys_enterpriseid}" @onSuccess="thisDetail().queryMainData().then(() => {setDefaultData()})"/>
  57. <el-table
  58. :data="financiallist"
  59. style="width: 100%"
  60. size="mini">
  61. <el-table-column
  62. prop="enterprisename"
  63. label="公司抬头"
  64. width="120">
  65. </el-table-column>
  66. <el-table-column
  67. prop="address"
  68. label="开票地址"
  69. width="120">
  70. </el-table-column>
  71. <el-table-column
  72. prop="bank"
  73. label="开户行"
  74. width="120">
  75. </el-table-column>
  76. <el-table-column
  77. prop="bankcardno"
  78. label="开户账号"
  79. width="120">
  80. </el-table-column>
  81. <el-table-column
  82. label="操作"
  83. width="120">
  84. <template slot-scope="scope">
  85. <el-button class="inline-16" type="text" @click="(defaultData.fin_info = scope.row,visible2 = false)" size="mini">选 择</el-button>
  86. <delete-btn
  87. message="确定删除当前信息吗?"
  88. nameId="20221013160502"
  89. nameKey="sys_enterprise_financeids"
  90. :id="scope.row.sys_enterprise_financeid"
  91. @deleteSuccess="thisDetail().queryMainData().then(() => {setDefaultData()})"
  92. ></delete-btn>
  93. </template>
  94. </el-table-column>
  95. </el-table>
  96. <el-button slot="reference" type="text" size="mini">选择其他</el-button>
  97. </el-popover>
  98. </div>
  99. <div class="reveive__panel normal-margin">
  100. <p><small>抬头:&nbsp;</small><span class="inline-16"><b>{{defaultData.fin_info.enterprisename}}</b></span></p>
  101. <div class="flex-align-center">
  102. <p class="inline-16"><small>开票地址:&nbsp;</small>{{defaultData.fin_info.address?defaultData.fin_info.address:'--'}}</p>
  103. <p><small>开户行:&nbsp;</small> {{defaultData.fin_info.bank}} &emsp;<small>开户账号:&nbsp;</small> {{defaultData.fin_info.bankcardno}}</p>
  104. </div>
  105. </div>
  106. </div>
  107. <div style="flex:1;">
  108. <div class="mt-10">
  109. <p class="normal-title inline-16">收货信息</p>
  110. <el-popover
  111. placement="bottom"
  112. title="选择地址"
  113. trigger="click"
  114. v-model="visible">
  115. <div class="flex-align-center" style="justify-content:space-between;margin-bottom:10px">
  116. <el-input
  117. size="small"
  118. v-model="addressparam.content.where.condition"
  119. placeholder="请输入搜索内容"
  120. style="width:150px"
  121. @keyup.enter.native="receiveAddress(addressparam.content.pageNumber = 1)" @clear="receiveAddress(addressparam.content.pageNumber = 1)" clearable></el-input>&nbsp;
  122. <addAddressInfo style="text-align:right" @onAddSuccess="receiveAddress()" :mainData="{sys_enterpriseid:data.sys_enterpriseid}"/>
  123. </div>
  124. <el-table
  125. :data="receiveAddresslist"
  126. style="width: 100%"
  127. size="mini">
  128. <el-table-column
  129. prop="name"
  130. label="联系人"
  131. width="90">
  132. </el-table-column>
  133. <el-table-column
  134. prop="phonenumber"
  135. label="电话"
  136. width="120">
  137. </el-table-column>
  138. <el-table-column
  139. label="地址"
  140. width="360">
  141. <template slot-scope="scope">
  142. {{scope.row.province}}{{scope.row.city}}{{scope.row.county}}{{scope.row.address}}
  143. </template>
  144. </el-table-column>
  145. <el-table-column
  146. label="操作"
  147. width="120">
  148. <template slot-scope="scope">
  149. <el-button class="inline-16" type="text" @click="(defaultData.re_info = scope.row,visible = false)" size="mini">选 择</el-button>
  150. <delete-btn
  151. message="确定删除当前地址吗?"
  152. nameId="20221009155903"
  153. nameKey="contactsid"
  154. :id="scope.row.contactsid"
  155. :isNumber="true"
  156. @deleteSuccess="receiveAddress"
  157. ></delete-btn>
  158. </template>
  159. </el-table-column>
  160. </el-table>
  161. <div class="container" style="text-align:right">
  162. <el-pagination
  163. background
  164. small
  165. :current-page="addressparam.content.pageNumber"
  166. @current-change="addresPageChange"
  167. layout="total,prev, pager, next"
  168. :total="addresstotal">
  169. </el-pagination>
  170. </div>
  171. <el-button slot="reference" type="text" size="mini">选择其他地址</el-button>
  172. </el-popover>
  173. </div>
  174. <div class="reveive__panel normal-margin">
  175. <p><span class="inline-16"><b>{{defaultData.re_info.name}}</b></span><small>{{defaultData.re_info.phonenumber}}</small></p>
  176. <small>{{defaultData.re_info.province?defaultData.re_info.province:'--'}}{{defaultData.re_info.city}}{{defaultData.re_info.county}}{{defaultData.re_info.address?defaultData.re_info.address:''}}</small>
  177. </div>
  178. </div>
  179. </div>
  180. <div class="normal-margin flex-align-center">
  181. <div class="inline-16">
  182. <small><b>回签单</b>&nbsp;</small>
  183. <el-radio-group v-model="signbackstatus">
  184. <el-radio label="不需要">不需要</el-radio>
  185. <el-radio label="纸质件">纸质件</el-radio>
  186. <el-radio label="扫描件">扫描件</el-radio>
  187. </el-radio-group>
  188. </div>
  189. <div style="margin-left:20px">
  190. <small><b>销售类别:</b>&nbsp;</small>
  191. <el-select v-model="saletype" size="small" placeholder="请选择">
  192. <el-option
  193. v-for="item in saleroptions"
  194. :key="item.value"
  195. :label="item.remarks"
  196. :value="item.value">
  197. </el-option>
  198. </el-select>
  199. </div>
  200. </div>
  201. <div class="normal-margin">
  202. <p class="normal-title mt-10 inline-16">订单备注</p>
  203. <el-input size="mini" class="order__note__input" type="textarea" v-model="defaultData.remarks" :autosize="{minRows:5}" placeholder="请输入订单备注"></el-input>
  204. </div>
  205. <div class="normal-margin" v-if="data.type === '标准订单' || data.type === '特殊订单'">
  206. <p class="normal-title mt-10 inline-16">项目备注</p>
  207. <el-input size="mini" class="order__note__input" type="textarea" v-model="data.projectnote" :autosize="{minRows:5}" placeholder="请输入项目备注"></el-input>
  208. </div>
  209. <div class="mt-10">
  210. <div>
  211. <p class="normal-title inline-16">订单产品</p>
  212. <!-- <el-button type="text" size="mini" @click="addMoreProduct">{{setcol === 12?'关闭选择':'添加产品'}}</el-button> -->
  213. </div>
  214. <el-row :gutter="10">
  215. <el-col :span="setcol">
  216. <product-list ref="prolist" :data="data" :type="'edit'" @onSuccess="onEditSuccess"></product-list>
  217. </el-col>
  218. <!-- <el-col :span="24 - setcol">
  219. <add-product ref="addpro" :data="data" @onConfirm="onConfirm"></add-product>
  220. </el-col> -->
  221. </el-row>
  222. </div>
  223. </div>
  224. <div class="fixed__btn__panel">
  225. <el-button size="small" @click="drawer = false" class="normal-btn-width">取 消</el-button>
  226. <el-button size="small" type="primary" @click="onSubmit" class="normal-btn-width">保存修改</el-button>
  227. </div>
  228. </el-drawer>
  229. </div>
  230. </template>
  231. <script>
  232. import previewImage from '@/components/previewImage/index.vue'
  233. import productList from './productlist.vue'
  234. import addProduct from '@/template/orderCanUseProduct/index.vue'
  235. import financeEnterprise from '@/template/orderCanUseFinance/index.vue'
  236. import addAmountInfo from '@/components/financialInfo/modules/add'
  237. import addAddressInfo from '@/HManagement/marketing2/agent/details/modules/address/add'
  238. export default {
  239. props:['data'],
  240. components:{
  241. previewImage,
  242. productList,
  243. addProduct,
  244. financeEnterprise,
  245. addAmountInfo,
  246. addAddressInfo
  247. },
  248. inject:['thisDetail'],
  249. computed:{
  250. checkFreefreightamount () {
  251. let result = ''
  252. switch (this.freefreightamount) {
  253. case -1:
  254. result = '不免运费'
  255. break;
  256. case 0:
  257. result = '免运费'
  258. break;
  259. default:
  260. result = this.data.amount >= this.freefreightamount?'当前订单免运费':`订单满${this.tool.formatAmount(this.freefreightamount,2)}元免运费,当前还差${this.tool.formatAmount(this.freefreightamount - this.data.amount,2)}元`
  261. break;
  262. }
  263. return result
  264. },
  265. },
  266. data () {
  267. return {
  268. freefreightamount:'',
  269. checked:0,
  270. visible:false,
  271. visible1:false,
  272. visible2:false,
  273. visible3:false,
  274. drawer:false,
  275. receiveAddresslist:[],
  276. accountlist:[],
  277. rebateAccount:[],
  278. logisticcomlist:[],
  279. financiallist:[],
  280. saleroptions:[],
  281. defaultData:{
  282. re_info:{},
  283. logist_info:{},
  284. fin_info:{},
  285. finance:{},
  286. accountclass:{},
  287. account_index:0,
  288. remarks:this.data.remarks
  289. },
  290. total:0,
  291. setcol:24,
  292. rebateamount:null,
  293. isusedrebate:0,
  294. signbackstatus:'不需要',
  295. saletype:"",
  296. freefreightamount:'',
  297. addressparam: {
  298. "id": "20230220002602",
  299. "content": {
  300. "nocache":true,
  301. "pageNumber":1,
  302. "pageSize":10,
  303. "sys_enterpriseid":'',
  304. "where":{
  305. "condition":"",
  306. "workaddress":1
  307. }
  308. }
  309. },
  310. addresstotal:0
  311. }
  312. },
  313. created () {
  314. this.queryBasicInfo()
  315. },
  316. methods:{
  317. addresPageChange (n) {
  318. this.addressparam.content.pageNumber = n
  319. this.receiveAddress()
  320. },
  321. async queryBasicInfo () {
  322. const res = await this.$api.requested({
  323. "id":20220920084001,"content":{
  324. sys_enterpriseid:this.data.sys_enterpriseid
  325. },
  326. })
  327. this.freefreightamount = res.data.freefreightamount
  328. },
  329. async rebateUsedChange(){
  330. console.log(this.data)
  331. if(this.data.status != '新建') return false
  332. let amount = this.data.order_rebate_userate * this.data.defaultamount; //最大可用金额
  333. let rebatebalance = this.data.rebatebalance; //返利金账户余额
  334. const res = await this.$api.requested({
  335. "id": 20230218225002,
  336. "content": {
  337. "sa_orderid": this.data.sa_orderid, //订单金额
  338. "isused": this.checked, //是否使用
  339. "rebateamount": rebatebalance > amount ? amount : rebatebalance //返利金使用金额
  340. }
  341. })
  342. this.$emit('onSuccess')
  343. // this.data.rebate_used = res.msg !== '成功' ? this.data.rebate_used == 0?1:0:this.data.rebate_used
  344. },
  345. onShow () {
  346. this.initPage()
  347. },
  348. async initPage () {
  349. this.setDefaultData()
  350. this.receiveAddress()
  351. this.queryUsedrebate()
  352. this.selectOptions()
  353. this.checked = this.data.rebate_used
  354. if (this.data.rebateamount > this.data.defaultamount) {
  355. this.rebateamount = this.tool.formatAmount(+this.data.defaultamount / 2)
  356. } else {
  357. this.rebateamount = this.data.rebateamount
  358. }
  359. },
  360. // 收货信息:合作企业联系人
  361. async receiveAddress (fn) {
  362. this.addressparam.content.sys_enterpriseid = this.data.sys_enterpriseid
  363. const res = await this.$api.requested(this.addressparam)
  364. this.addresstotal = res.total
  365. this.receiveAddresslist = res.data
  366. },
  367. // 设置默认信息
  368. async setDefaultData () {
  369. this.defaultData.rebatebalance = this.data.rebatebalance
  370. this.defaultData.finance = this.data.finance
  371. this.defaultData.fin_info = this.data.finance
  372. this.defaultData.accountclass = this.data.accountclass
  373. this.defaultData.re_info = this.data.contacts
  374. this.financiallist = this.data.pay_finance
  375. this.saletype = this.data.saletype
  376. this.signbackstatus = this.data.signbackstatus
  377. },
  378. async onSubmit() {
  379. const res = await this.$api.requested({
  380. "id": 20221108111402,
  381. "content": {
  382. "sa_orderid": this.$route.query.id,
  383. "sys_enterpriseid": this.data.sys_enterpriseid, //订货企业id
  384. "sa_accountclassid": this.defaultData.accountclass.sa_accountclassid, //营销账户类型ID
  385. "sa_brandid": this.data.sa_brandid, //品牌ID
  386. "sa_contractid":this.data.sa_contractid, //合同ID,标准订单不传
  387. "sa_projectid": this.data.sa_projectid, //工程项目表ID,标准订单不传
  388. "sys_enterprise_financeid": this.defaultData.fin_info.sys_enterprise_financeid, //合作企业财务信息ID(开票信息)
  389. "sa_logiscompid": this.defaultData.logist_info.sa_logiscompid, //物流公司档案ID
  390. "rec_contactsid": this.defaultData.re_info.contactsid, //合作企业联系人表ID(收货信息)
  391. "type": this.data.type, //订单类型
  392. "typemx":this.data.typemx, //明细分类,可选
  393. "remarks": this.defaultData.remarks, //可选
  394. "saler_hrid":this.data.saler_hrid,//销售人员hrid,业务员hrid
  395. "signbackstatus":this.signbackstatus,
  396. "tradefieldmx":this.data.tradefieldmx,
  397. "pay_enterpriseid":this.data.pay_enterpriseid,
  398. "tradefield":this.data.tradefield,
  399. "saletype":this.saletype,
  400. "rebate_used":this.checked,//默认0,是否使用返利金
  401. "signbacknum":'',
  402. "sa_promotionid":this.data.sa_promotionid,
  403. "billdate":this.data.billdate,
  404. "projectnote":this.data.projectnote
  405. },
  406. })
  407. this.tool.showMessage(res,()=>{
  408. this.$emit('onSuccess')
  409. /*if (this.data.type === '标准订单' || this.data.type === '特殊订单') {
  410. this.isusedrebate === 1?this.useRebate(this.data.rebateamount):""
  411. }*/
  412. })
  413. },
  414. onEditSuccess () {
  415. this.$refs.prolist.listData()
  416. this.$emit('onSuccess')
  417. },
  418. addMoreProduct () {
  419. this.setcol === 12?this.setcol = 24 : this.setcol = 12
  420. },
  421. // 订单添加商品
  422. async onConfirm (data) {
  423. const res = await this.$api.requested({
  424. "id": 20221109093602,
  425. "content": {
  426. "sa_orderid": this.$route.query.id, //订单ID
  427. "sys_enterpriseid": this.data.sys_enterpriseid, //企业ID
  428. "type": "标准订单", //订单类型
  429. "items": data.map(e=>{
  430. return {
  431. sa_orderitemsid:0,
  432. itemid:e.itemid,
  433. qty:e.orderminqty,
  434. needdate:e.deliverydate
  435. }
  436. })
  437. },
  438. })
  439. this.tool.showMessage(res,()=>{
  440. this.setcol = 24
  441. this.$refs['prolist'].listData()
  442. this.$emit('onSuccess')
  443. })
  444. },
  445. async useRebate (e) {
  446. let that = this
  447. /* 修改返利金 */
  448. let rebateamount = e;
  449. let amount = this.data.order_rebate_userate * this.data.defaultamount;//最大可用金额
  450. const res = await this.$api.requested({
  451. "id":20230218225002,
  452. "content":{
  453. "sa_orderid":this.data.sa_orderid,//订单金额
  454. "isused":1,//是否使用
  455. "rebateamount":rebateamount>amount?amount:rebateamount
  456. }
  457. })
  458. if(res.data=='成功'){
  459. this.$emit('onSuccess')
  460. this.initPage()
  461. if(rebateamount>amount){
  462. this.data.rebateamount=amount
  463. this.$message({
  464. message: '返利金最大可用值'+ amount,
  465. type: 'warning'
  466. });
  467. }
  468. }else{
  469. this.$message.error(res.msg);
  470. }
  471. },
  472. // 查询站点是否使用返利金
  473. async queryUsedrebate () {
  474. const res = await this.$api.requested({
  475. "classname": "webmanage.site.site",
  476. "method": "querySite_Parameter",
  477. "content": {
  478. }
  479. })
  480. this.isusedrebate = res.data.order_rebate_used
  481. },
  482. // 选择结算企业
  483. onSelect (data) {
  484. this.defaultData.finance = data
  485. this.financiallist = data.finance
  486. data.finance.forEach(e => {
  487. if (e.isdefault === 1) {
  488. this.defaultData.fin_info = e
  489. } else {
  490. this.defaultData.fin_info = data.finance.length > 0 ?data.finance[0]:{}
  491. }
  492. });
  493. },
  494. async selectOptions () {
  495. const res = await this.$store.dispatch('optiontypeselect','saletype')
  496. this.saleroptions = res.data
  497. }
  498. },
  499. }
  500. </script>
  501. <style>
  502. </style>
  503. <style scoped>
  504. .reveive__panel{
  505. font-size: 16px;
  506. line-height: 30px;
  507. padding: 10px;
  508. background: #d9ecff;
  509. border: 1px dashed #0676e7;
  510. }
  511. .account__panel small,.reveive__panel small{
  512. color:#888
  513. }
  514. .account__panel{
  515. width: calc(25% - 26px);
  516. padding: 10px;
  517. margin-bottom:10px;
  518. border: 1px dashed #666;
  519. }
  520. .act{
  521. background: #d9ecff;
  522. border: 1px dashed #0676e7;
  523. }
  524. .image {
  525. width:40px;height:40px;margin:0px auto;
  526. }
  527. .order__note__input{
  528. border: none;
  529. outline: none;
  530. /* margin-left: 10px; */
  531. /* border-bottom: 1px solid #f1f2f3; */
  532. flex:1
  533. }
  534. </style>