detailDialog.vue 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334
  1. <template>
  2. <div>
  3. <div class="switch">
  4. <div class="switch_left">
  5. <ul>
  6. <li
  7. v-for="item in tabOptions"
  8. :key="item.key"
  9. :class="{ active: activeComp == item.key }"
  10. @click="activeComp = item.key"
  11. >
  12. {{ item.name }}
  13. </li>
  14. </ul>
  15. </div>
  16. </div>
  17. <div v-show="activeComp == 'main'">
  18. <el-form ref="form" :model="form" :rules="rules" label-width="120px">
  19. <headerTitle title="订单信息"> </headerTitle>
  20. <el-row>
  21. <el-col :span="8">
  22. <el-form-item label="订单编号:" prop="orderNo">
  23. {{ form.orderNo }}
  24. </el-form-item>
  25. <el-form-item label="订单类型:" prop="totalAmount">
  26. {{
  27. form.needProduce == 1
  28. ? '有客户生产性订单'
  29. : form.needProduce == 2
  30. ? '无客户生产性订单'
  31. : form.needProduce == 4
  32. ? '不定向订单'
  33. : '库存式订单'
  34. }}
  35. </el-form-item>
  36. <el-form-item label="结算方式:" prop="settlementModeName">
  37. {{ detailData.settlementModeName }}
  38. </el-form-item>
  39. <el-form-item label="客户收货地址:" prop="receiveAddress">
  40. {{ form.receiveAddress }}
  41. </el-form-item>
  42. <el-form-item label="生产要求:" prop="productionRequirements">
  43. {{ form.productionRequirements }}
  44. </el-form-item>
  45. </el-col>
  46. <el-col :span="8">
  47. <el-form-item
  48. v-if="form.relationType == 1"
  49. label="商机名称:"
  50. prop="relationName"
  51. >
  52. {{ form.relationName }}
  53. </el-form-item>
  54. <el-form-item
  55. v-if="form.relationType == 2"
  56. label="报价单:"
  57. prop="relationCode"
  58. >
  59. {{ form.relationName }}
  60. </el-form-item>
  61. <el-form-item
  62. v-if="form.relationType == 4"
  63. label="项目名称:"
  64. prop="projectName"
  65. >
  66. {{ form.relationName }}
  67. </el-form-item>
  68. <el-form-item
  69. v-if="form.relationType == 3"
  70. label="合同名称:"
  71. prop="relationName"
  72. >
  73. {{ form.relationName }}
  74. </el-form-item>
  75. <el-form-item label="销售部门:" prop="salesDeptName">
  76. {{ form.salesDeptName }}
  77. </el-form-item>
  78. <el-form-item label="订单总金额:" prop="totalAmount">
  79. {{ form.totalAmount }}元
  80. </el-form-item>
  81. <el-form-item prop="orderFiles" label="订单附件:">
  82. <fileMain v-model="detailData.orderFiles" type="view"></fileMain>
  83. </el-form-item>
  84. </el-col>
  85. <el-col :span="8">
  86. <el-form-item
  87. label="合同编号:"
  88. prop="contractNumber"
  89. v-if="form.relationType == 3"
  90. >
  91. {{ form.contractNumber }}
  92. </el-form-item>
  93. <el-form-item label="销售类型:" prop="saleTypeName">
  94. {{ form.saleTypeName }}
  95. </el-form-item>
  96. <el-form-item label="应付金额:" prop="payAmount">
  97. {{ form.payAmount }}元
  98. </el-form-item>
  99. <el-form-item label="订单备注:" prop="remark">
  100. {{ form.remark }}
  101. </el-form-item>
  102. <el-form-item
  103. label="总数"
  104. prop="totalPlanNum"
  105. v-if="form.needProduce == 4"
  106. >
  107. {{ form.totalPlanNum }}
  108. {{ form.planNumUnit }}
  109. </el-form-item>
  110. </el-col>
  111. </el-row>
  112. <headerTitle title="基本信息"></headerTitle>
  113. <el-row>
  114. <el-col :span="12">
  115. <el-form-item label="客户名称:" prop="partaName">
  116. {{ form.partaName }}
  117. </el-form-item>
  118. <el-form-item
  119. label="客户统一社会信用代码"
  120. prop="partaUnifiedSocialCreditCode"
  121. label-width="160px"
  122. >
  123. {{ form.partaUnifiedSocialCreditCode }}
  124. </el-form-item>
  125. <el-form-item label="客户联系人:" prop="partaLinkName">
  126. {{ form.partaLinkName }}
  127. </el-form-item>
  128. <el-form-item label="客户电话:" prop="partaTel">
  129. {{ form.partaTel }}
  130. </el-form-item>
  131. <el-form-item label="客户传真:" prop="partaFax">
  132. {{ form.partaFax }}
  133. </el-form-item>
  134. <el-form-item label=" 客户Email:" prop="partaEmail">
  135. {{ form.partaEmail }}
  136. </el-form-item>
  137. <el-form-item label="客户地址:" prop="partaAddress">
  138. {{ form.partaAddress }}
  139. </el-form-item>
  140. <!-- <el-form-item
  141. label="客户税号"
  142. prop="contactAddress"
  143. >
  144. <el-input
  145. clearable
  146. v-model="form.contactAddress"
  147. placeholder="请输入"
  148. />
  149. </el-form-item> -->
  150. </el-col>
  151. <el-col :span="12">
  152. <el-form-item label="售出方名称:" prop="partbName">
  153. {{ form.partbName }}
  154. </el-form-item>
  155. <el-form-item
  156. label="售出方统一社会信用代码"
  157. prop="partbUnifiedSocialCreditCode"
  158. label-width="180px"
  159. >
  160. {{ form.partbUnifiedSocialCreditCode }}
  161. </el-form-item>
  162. <el-form-item label="售出方联系人:" prop="partbLinkName">
  163. {{ form.partbLinkName }}
  164. </el-form-item>
  165. <el-form-item
  166. prop="partbTel"
  167. label="售出方联系电话:"
  168. label-width="140px"
  169. >
  170. {{ form.partbTel }}
  171. </el-form-item>
  172. <el-form-item prop="partbFax" label="售出方传真:">
  173. {{ form.partbFax }}
  174. </el-form-item>
  175. <el-form-item label="售出方Email:" prop="partbEmail">
  176. {{ form.partbEmail }}
  177. </el-form-item>
  178. <el-form-item label="售出方地址:" prop="partbAddress">
  179. {{ form.partbAddress }}
  180. </el-form-item>
  181. <!-- <el-form-item
  182. label="售出方税号"
  183. prop="contactAddress"
  184. >
  185. <el-input
  186. clearable
  187. v-model="form.contactAddress"
  188. placeholder="请输入"
  189. />
  190. </el-form-item> -->
  191. </el-col>
  192. </el-row>
  193. </el-form>
  194. <headerTitle title="物品清单" v-if="form.needProduce != 4"></headerTitle>
  195. <inventoryTabledetail
  196. v-if="form.needProduce != 4"
  197. ref="inventoryTabledetailRef"
  198. :isCustomerMark="true"
  199. :isDiscountTotalPrice="true"
  200. :isArrivalWay="true"
  201. ></inventoryTabledetail>
  202. <headerTitle title="类型清单" v-if="form.needProduce == 4"></headerTitle>
  203. <typeList
  204. v-if="form.needProduce == 4"
  205. ref="typeListRef"
  206. type="view"
  207. ></typeList>
  208. </div>
  209. <div v-show="activeComp == '1'">
  210. <bomList :tableList="orderBomList2"></bomList>
  211. </div>
  212. <div v-show="activeComp == '2'">
  213. <bomList :tableList="orderBomList1"></bomList>
  214. </div>
  215. <div v-show="activeComp == '3'">
  216. <bomList :tableList="orderBomList3"></bomList>
  217. </div>
  218. </div>
  219. </template>
  220. <script>
  221. import { getSaleOrderDetail } from '@/api/bpm/components/saleManage/saleorder';
  222. import dictMixins from '@/mixins/dictMixins';
  223. import inventoryTabledetail from '@/BIZComponents/inventoryTableDetails.vue';
  224. import typeList from './typeList.vue';
  225. import bomList from './bomList.vue';
  226. export default {
  227. mixins: [dictMixins],
  228. components: {
  229. inventoryTabledetail,
  230. typeList,
  231. bomList
  232. },
  233. props: {
  234. businessId: {
  235. default: ''
  236. }
  237. },
  238. data() {
  239. return {
  240. activeComp: 'main',
  241. tabOptions: [{ key: 'main', name: '订单信息' }],
  242. visible: false,
  243. detailId: '',
  244. title: '详情',
  245. row: {},
  246. activeName: 'base',
  247. form: {},
  248. rules: {},
  249. detailData: {},
  250. orderBomList1: [], //生产计划
  251. orderBomList2: [], //生产性物资采购
  252. orderBomList3: [] //客供料外协采购
  253. };
  254. },
  255. created() {
  256. this.getDetailData(this.businessId);
  257. },
  258. methods: {
  259. async getDetailData(id) {
  260. this.loading = true;
  261. const data = await getSaleOrderDetail(id);
  262. this.loading = false;
  263. if (data) {
  264. this.form = data;
  265. this.detailData = data;
  266. this.orderBomList1 = data.orderBomList.filter(
  267. (item) => item.disposeType === 1
  268. );
  269. this.orderBomList2 = data.orderBomList.filter(
  270. (item) => item.disposeType === 2
  271. );
  272. this.orderBomList3 = data.orderBomList.filter(
  273. (item) => item.disposeType === 3
  274. );
  275. if (this.orderBomList1?.length) {
  276. this.tabOptions.push({ key: '2', name: '生产计划物品清单' });
  277. }
  278. if (this.orderBomList2?.length) {
  279. this.tabOptions.push({ key: '1', name: '生产性物资采购清单' });
  280. }
  281. if (this.orderBomList3?.length) {
  282. this.tabOptions.push({ key: '3', name: '客供料外协采购清单' });
  283. }
  284. this.$nextTick(() => {
  285. this.$refs.inventoryTabledetailRef &&
  286. this.$refs.inventoryTabledetailRef.putTableValue(data);
  287. this.$refs.typeListRef &&
  288. this.$refs.typeListRef.putTableValue(data.typedetailList);
  289. });
  290. }
  291. }
  292. }
  293. };
  294. </script>
  295. <style scoped lang="scss">
  296. :deep(.el-form-item) {
  297. margin-bottom: 4px !important;
  298. }
  299. .headbox {
  300. display: flex;
  301. justify-content: flex-start;
  302. align-items: center;
  303. .amount {
  304. font-size: 14px;
  305. font-weight: bold;
  306. margin-right: 20px;
  307. }
  308. }
  309. .switch_left ul .active {
  310. border-top: 4px solid var(--color-primary);
  311. color: var(--color-primary-5);
  312. }
  313. .switch {
  314. padding-bottom: 20px;
  315. }
  316. :deep .divider .content {
  317. justify-content: flex-start;
  318. }
  319. </style>