orderDetailPart.vue 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331
  1. <template>
  2. <div class="com-main com-margin-auto">
  3. <div v-if="isLoading" v-loading="true" class="com-loading"></div>
  4. <template v-else>
  5. <section class="main-header">
  6. <div class="main-header-mid flex between">
  7. <h1>Job Name:{{ orderDetail.Sales_Order_Title_Job_Name }}</h1>
  8. <img :src="orderDetail.user_logo" class="user_logo">
  9. </div>
  10. <div class="main-header-mid flex between">
  11. <ul class="left">
  12. <li class="left-i" @click="shareDialogVisible=true" v-if="isShow"><i class="el-icon-share"></i> <span>Client Tracking Share</span></li>
  13. <li class="left-i" v-if="orderDetail.crm_pr_res?.length">
  14. <image-list :data="orderDetail.crm_pr_res"/>
  15. </li>
  16. </ul>
  17. <ul class="right">
  18. <li v-if="orderDetail.Job_Group && isShow">Order Type: {{ orderDetail.Job_Group }}</li>
  19. <li>Order No: {{ orderDetail.Reference }}</li>
  20. <li>Order Date: {{ formatStepDesc(orderDetail.Sales_Order_Created) }}</li>
  21. <li v-if="orderDetail.Expected_Delivery_Date">ETA: {{ formatStepDesc(orderDetail.Expected_Delivery_Date) }}</li>
  22. <li v-if="isShow">Payment Status: {{ orderDetail.Payment_Status1 }}</li>
  23. </ul>
  24. </div>
  25. <div class="steps">
  26. <el-steps :active="comOrderState" align-center finish-status="success" process-status="wait">
  27. <el-step title="Confirmed" :description="formatStepDesc(orderDetail.Order_Confirm)">
  28. </el-step>
  29. <el-step title="In Production" :description="formatStepDesc(orderDetail.Sampling_Factory_Confirm)"></el-step>
  30. <el-step title="QC Inspection" :description="formatStepDesc(orderDetail.GZ_WH)"></el-step>
  31. <el-step title="International Shipment" :description="formatStepDesc(orderDetail.International_transshipment)"></el-step>
  32. <el-step title="AU Warehouse" :description="formatStepDesc(orderDetail.AU_WH)"></el-step>
  33. <el-step :title="packageQty<productQty?'Shipped':'Domestic Delivery'" :description="formatStepDesc(orderDetail.AU_WH_Client)"></el-step>
  34. <el-step title="Delivered" :description="formatStepDesc(orderDetail.Delivered_time)"></el-step>
  35. </el-steps>
  36. </div>
  37. </section>
  38. <section class="main-custom">
  39. <p class="sharing-title">Customer information</p>
  40. <div>
  41. <p class="sharing-subtitle">{{isShow?'Billing':'Supplier'}} Address</p>
  42. <div class="sharing-address">
  43. <p>{{ orderDetail.Account_Name_name }}</p>
  44. <p>{{ orderDetail.Billing_Unit_Building_Name }}</p>
  45. <p>{{ orderDetail.Billing_Street }}</p>
  46. <p>{{ orderDetail.Billing_City }}</p>
  47. <p>{{ orderDetail.Billing_State }}</p>
  48. <p>{{ orderDetail.Billing_Code }}</p>
  49. <p>{{ orderDetail.Billing_Country }}</p>
  50. </div>
  51. </div>
  52. <div>
  53. <p class="sharing-subtitle">Shipping Address</p>
  54. <div class="sharing-address">
  55. <p>{{ orderDetail.Shipping_Unit_Building_Name }}</p>
  56. <p>{{ orderDetail.Shipping_Street }}</p>
  57. <p>{{ orderDetail.Shipping_City }}</p>
  58. <p>{{ orderDetail.Shipping_State }}</p>
  59. <p>{{ orderDetail.Shipping_Code }}</p>
  60. <p>{{ orderDetail.Shipping_Country }}</p>
  61. </div>
  62. </div>
  63. </section>
  64. <section>
  65. <p class="sharing-title">Shipping information</p>
  66. <el-table
  67. :data="orderDetail.shipping_tracking"
  68. style="width: 100%"
  69. :header-cell-style="{
  70. background: '#F7F8FC',
  71. color: '#101010',
  72. fontWeight: 'normal'
  73. }">
  74. <el-table-column type="expand" style="padding: 0;">
  75. <template slot-scope="props">
  76. <el-table
  77. :data="props.row.test_pkg_details"
  78. style="margin-left: 50px; width: calc(100% - 50px);"
  79. :header-cell-style="{
  80. background: '#F7F8FC',
  81. color: '#101010',
  82. fontWeight: 'normal'
  83. }">
  84. <el-table-column prop="Product_name" label="Item & Description"></el-table-column>
  85. <el-table-column prop="Quantity_to_pack" label="QTY" width="450"></el-table-column>
  86. </el-table>
  87. </template>
  88. </el-table-column>
  89. <el-table-column prop="Title" label="Job Name"> </el-table-column>
  90. <el-table-column prop="Courier" label="Carrier"></el-table-column>
  91. <el-table-column prop="Tracking_No" label="Tracking#"></el-table-column>
  92. <el-table-column prop="Package_Status" label="Shipment Status"></el-table-column>
  93. <el-table-column label="Delivery Address" width="250">
  94. <template slot-scope="scope">
  95. <span>
  96. {{ scope.row.Shipping_Unit_Building_Name }}<br>
  97. {{ scope.row.Shipping_Street }}<br>
  98. {{ scope.row.Shipping_City }}<br>
  99. {{ scope.row.Shipping_State }}
  100. </span>
  101. </template>
  102. </el-table-column>
  103. <el-table-column prop="Tracking_URL" label="" width="200">
  104. <template slot-scope="scope" v-if="scope.row.Tracking_URL">
  105. <el-button
  106. size="mini" @click.native="openTracking_URL(scope.row.Tracking_URL)"
  107. style="background-color: rgb(0, 33, 59); color: #fff" plain>TRACK SHIPMENT</el-button></template>
  108. </el-table-column>
  109. </el-table>
  110. </section>
  111. <section class="orderTable">
  112. <p class="sharing-title">Products Information</p>
  113. <el-table
  114. :data="orderDetail.sales_orders_details"
  115. style="width: 100%"
  116. :header-cell-style="{
  117. background: '#fff',
  118. color: '#101010',
  119. fontWeight: 'normal'
  120. }">
  121. <el-table-column type="index" label="S.NO" width="70"> </el-table-column>
  122. <el-table-column label="Product Name" min-width="300">
  123. <template slot-scope="scope">
  124. <p class="colorBlue" >{{ scope.row.product_name }}</p>
  125. <p v-html="scope.row.product_description"></p>
  126. <!-- <p :class="scope.row.showMore?'ellipsis':''" v-html="scope.row.product_description"></p>
  127. <p class="colorBlue cursor" @click="toggleShow(scope.row)" v-if="scope.row.product_description">{{scope.row.showMore?'Show More':'Conceal'}}<i :class="scope.row.showMore?'el-icon-caret-bottom':'el-icon-caret-top'"></i></p> -->
  128. </template>
  129. </el-table-column>
  130. <el-table-column prop="quantity" label="Quantity" align="left" :width="isShow?125:200">
  131. </el-table-column>
  132. <template v-if="isShow">
  133. <el-table-column prop="list_price" :label="`List Price(${comCurrency})`" width="125">
  134. <template slot-scope="scope">
  135. {{ transformNumber(scope.row.list_price) }}
  136. </template>
  137. </el-table-column>
  138. <el-table-column prop="amount" :label="`Amount(${comCurrency})`" width="125">
  139. <template slot-scope="scope">
  140. {{ transformNumber(scope.row.amount) }}
  141. </template>
  142. </el-table-column>
  143. <el-table-column prop="Tax" :label="`Tax(${comCurrency})`" width="125">
  144. <template slot-scope="scope">
  145. {{ transformNumber(scope.row.Tax) }}
  146. </template>
  147. </el-table-column>
  148. <el-table-column prop="Discount" :label="`Discount(${comCurrency})`" width="125">
  149. <template slot-scope="scope">
  150. {{ transformNumber(scope.row.Discount) }}
  151. </template>
  152. </el-table-column>
  153. <el-table-column prop="net_total" :label="`Total(${comCurrency})`" width="125">
  154. <template slot-scope="scope">
  155. {{ transformNumber(scope.row.net_total) }}
  156. </template>
  157. </el-table-column>
  158. </template>
  159. </el-table>
  160. <div class="table-wrap" v-if="isShow">
  161. <table class="total">
  162. <tr><td>Sub Total</td><td>{{comCurrency}} {{ transformNumber(orderDetail.Sub_Total) }}</td></tr>
  163. <tr><td>Total Taxes</td><td>{{comCurrency}} {{ transformNumber(orderDetail.Tax_Total) }}</td></tr>
  164. <tr><td>Total Discount</td><td>{{comCurrency}} {{ transformNumber(orderDetail.Total_Including_Discount) }}</td></tr>
  165. <tr><td>Adjustment</td><td>{{comCurrency}} {{ transformNumber(orderDetail.Total_Adjustment) }}</td></tr>
  166. <tr><td>Grand Total</td><td>{{comCurrency}} {{ transformNumber(orderDetail.Grand_Total) }}</td></tr>
  167. </table>
  168. </div>
  169. <template v-if="isShow">
  170. <p class="notes-1">Notes</p>
  171. <p class="notes-2">Terms & conditions</p>
  172. <p class="notes-2">Artwork Approval</p>
  173. <p class="notes-3">{{ orderDetail.Subject }}</p>
  174. </template>
  175. </section>
  176. </template>
  177. <el-dialog
  178. :lock-scroll=false
  179. :visible.sync="urlDialogShow"
  180. center width="850px"
  181. top="20vh">
  182. <iframe
  183. :src="Tracking_URL"
  184. style="width:100%;height:500px;"
  185. frameborder="0"></iframe>
  186. </el-dialog>
  187. <export-dialog :emailForm="shareForm" :visible.sync="shareDialogVisible" :title="'Client Tracking Share (no pricing displayed)'" :labelShow=false></export-dialog>
  188. </div>
  189. </template>
  190. <script>
  191. import { round } from '@/utils/price.js'
  192. export default {
  193. name: "OrderDetailPart",
  194. props:{
  195. isShow:{ // 订单分享页面隐藏元素
  196. type:Boolean,
  197. default: true
  198. },
  199. },
  200. data() {
  201. return {
  202. orderDetail:{},
  203. isLoading: true,
  204. packageTable: [],
  205. urlDialogShow: false,
  206. shareDialogVisible: false,
  207. shareForm:{
  208. Link:''
  209. },
  210. Tracking_URL: '',
  211. stepConfig:{
  212. 'Order Confirmed':1,
  213. 'Factory Confirmed':2,
  214. 'GZ WH':3,
  215. 'Transshipment':4,
  216. 'AU WH':5,
  217. 'AUWH - Client':6,
  218. 'Completed Sales Order':7
  219. },
  220. packageQty:0,
  221. productQty:0,
  222. };
  223. },
  224. computed:{
  225. comCurrency(){
  226. return this.orderDetail.Currency
  227. },
  228. comOrderState(){
  229. if(this.orderDetail.Order_Stage ==='Cancelled'){
  230. return 0;
  231. }
  232. if(this.orderDetail.Order_Stage !=='Completed Sales Order'){
  233. return this.stepConfig[this.orderDetail.Order_Stage]
  234. }else{
  235. return this.orderDetail.shipping_isDelivered?7:6;
  236. }
  237. }
  238. },
  239. mounted() {
  240. this.getOrderDetail();
  241. },
  242. methods: {
  243. getOrderDetail() {
  244. let path = ''
  245. let data = {}
  246. if (this.isShow) {
  247. const { id } = this.$store.state.userInfo;
  248. const { crm, id: queryId } = this.$route.query;
  249. path = '/crmdata/orders_detail';
  250. this.shareForm.Link = `https://www.trackship.com.au/orderShare/${id}/${crm}/${queryId}`;
  251. data = { accounts_id: crm, id: queryId };
  252. }else{
  253. const { uid, aid, id } = this.$route.params;
  254. path = '/crmdata/showOrdersDetail';
  255. data = { user_id: uid, accounts_id: aid, id };
  256. }
  257. this.$axios
  258. .post(path,data)
  259. .then((res) => {
  260. if (res.result === null) {
  261. this.$router.replace('/')
  262. return
  263. }
  264. this.orderDetail = res.result;
  265. if(this.orderDetail.shipping_tracking?.length){
  266. this.orderDetail.shipping_tracking.forEach(items=>{
  267. // 取包裹的到达时间
  268. if(items.Package_Status === 'Delivered' ){
  269. !this.orderDetail.Delivered_time && this.$set(this.orderDetail,'Delivered_time',items['Delivered_Date'])
  270. if(items['Delivered_Date'] > this.orderDetail['Delivered_time'] ){
  271. this.$set(this.orderDetail,'Delivered_time',items['Delivered_Date'])
  272. }
  273. this.$set(this.orderDetail,'shipping_isDelivered',true)
  274. }else{
  275. this.$set(this.orderDetail,'shipping_isDelivered',false)
  276. }
  277. if(items.test_pkg_details?.length){
  278. items.test_pkg_details.forEach(item=>{
  279. this.$set(item,'Courier',items.Courier)
  280. this.$set(item,'Tracking_No',items['Tracking_No'])
  281. this.$set(item,'Package_Status',items['Package_Status'])
  282. this.$set(item,'Tracking_URL',items['Tracking_URL'])
  283. this.packageQty += +item.Quantity_to_pack
  284. })
  285. }
  286. })
  287. }
  288. if(this.orderDetail.sales_orders_details?.length){
  289. if (this.isShow) {
  290. this.orderDetail.sales_orders_details.forEach(items => {
  291. this.$set(items, 'showMore', true);
  292. this.productQty += +items.quantity;
  293. });
  294. } else {
  295. this.orderDetail.sales_orders_details = this.orderDetail.sales_orders_details.filter(item => {
  296. return item.product_Product_Code !== "PC Setup Service" && item.product_Product_Code !== "PC Freight";
  297. }).map(item => {
  298. this.$set(item, 'showMore', true);
  299. this.productQty += +item.quantity;
  300. return item;
  301. });
  302. }
  303. }
  304. this.isLoading=false
  305. });
  306. },
  307. transformNumber(value) {
  308. return round(Number(value)).toFixed(2)
  309. },
  310. formatStepDesc(date, isUnix = false) {
  311. return this.$utils.formatTime(date, 'DD/MM/YYYY',isUnix)
  312. },
  313. toggleShow(row){
  314. row.showMore = !row.showMore
  315. },
  316. openTracking_URL(url){
  317. this.Tracking_URL= url
  318. this.urlDialogShow= true
  319. }
  320. }
  321. };
  322. </script>
  323. <style lang="scss" scoped>
  324. @import '../detail.scss';
  325. </style>