tb-business-car-info.html 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>-详情</title>
  5. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  6. <meta name="viewport"
  7. content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
  8. <!-- 所有的 css js 资源 -->
  9. <link rel="stylesheet" href="../../static/kj/element-ui/theme-chalk/index.css">
  10. <link rel="stylesheet" href="../../static/sa.css">
  11. <script src="../../static/kj/vue.min.js"></script>
  12. <script src="../../static/kj/element-ui/index.js"></script>
  13. <script src="../../static/kj/httpVueLoader.js"></script>
  14. <script src="../../static/print/jquery-2.0.3.js" type="text/javascript"></script>
  15. <script src="../../static/kj/layer/layer.js"></script>
  16. <script src="../../static/sa.js"></script>
  17. <style type="text/css">
  18. .s-body {
  19. margin: 0;
  20. }
  21. .c-panel .c-label {
  22. width: 8em;
  23. }
  24. .title {
  25. text-align: center;
  26. font-size: 20px;
  27. font-weight: bold;
  28. padding: 0 0 20px 0px;
  29. }
  30. </style>
  31. </head>
  32. <body>
  33. <div class="vue-box sbot" style="display: none;" :style="'display: block;'">
  34. <!-- ------- 内容部分 ------- -->
  35. <div class="s-body">
  36. <div class="c-panel">
  37. <el-form v-if="m">
  38. <el-row>
  39. <el-col :span="m.businessType==1?8:12">
  40. <sa-info name="车牌号" br>{{m.carNo}}</sa-info>
  41. <sa-info name="车牌颜色" br>{{m.color}}</sa-info>
  42. <sa-info name="车牌规格(米)" br>{{m.carSize}}</sa-info>
  43. <sa-info name="入场时间" br>{{m.realInTime}}<label v-if="m.inTimeSupplement===1">(补)</label>
  44. </sa-info>
  45. <sa-info name="补录时间" br v-if="m.inTimeSupplementTime">{{m.inTimeSupplementTime}}
  46. </sa-info>
  47. <sa-info name="入场通道" br>{{m.inChannel}}</sa-info>
  48. <sa-info name="备注" br v-if="m.remark">{{m.remark}}</sa-info>
  49. <sa-info type="img" name="入场图片" :value="m.inImage" br></sa-info>
  50. </el-col>
  51. <el-col :span="m.businessType==1?8:12">
  52. <sa-info name="离场时间" br>{{m.realOutTime}}<label
  53. v-if="m.outTimeSupplement===1">(补)</label></sa-info>
  54. <sa-info name="补录时间" br v-if="m.outTimeSupplementTime">{{m.outTimeSupplementTime}}
  55. </sa-info>
  56. <sa-info name="离场通道" br>{{m.outChannel}}</sa-info>
  57. <sa-info name="停车费" br>{{m.money}}元</sa-info>
  58. <sa-info name="支付状态" br>{{m.payType}}</sa-info>
  59. <sa-info name="出场确认说明" br v-if="m.outRemark">{{m.outRemark}}</sa-info>
  60. <sa-info type="img" name="离场图片" :value="m.outImage" br></sa-info>
  61. </el-col>
  62. <el-col span=8 v-if="m.businessType==1">
  63. <sa-info style="margin-top: 0;" type="enum" name="审核状态"
  64. :value="m.confirmJudge" :jv="{0: '未审核', 1: '审核通过', 2: '审核驳回'}" br>
  65. </sa-info>
  66. <sa-info style="margin-top: 0;" name="审核人" br>
  67. {{m.confirmJudgeBy}}</sa-info>
  68. <sa-info name="审核时间" br>{{m.confirmJudgeTime}}</sa-info>
  69. <sa-info name="审核意见" br v-if="m.confirmJudgeContent">
  70. {{m.confirmJudgeContent}}
  71. </sa-info>
  72. </el-col>
  73. </el-row>
  74. <el-row v-if="businessList.length>0">
  75. <el-collapse value='1'>
  76. <el-collapse-item name="1">
  77. <div slot="title">
  78. 业务列表
  79. </div>
  80. <el-table :data="businessList" style="width: 100%">
  81. <sa-td name="业务单号" prop="no" width="180"></sa-td>
  82. <sa-td name="客户名称" prop="customerName" width="200"></sa-td>
  83. <sa-td name="货主" prop="owner" width="170"></sa-td>
  84. <sa-td name="业务项" prop="goodsName" width="160"></sa-td>
  85. <sa-td name="作业时间" prop="operateTime" width="160"></sa-td>
  86. <sa-td name="业务费用(元)" prop="itemPrice" width="120"></sa-td>
  87. <sa-td name="确认" prop="adminConfirmInput" type="enum" :jv="{1: '已确认', 0: '未确认'}"
  88. width="130"></sa-td>
  89. <sa-td name="已支付(元)" prop="payMoney" width="140"></sa-td>
  90. <sa-td width="160" name="创建时间" prop="createTime" width="140"></sa-td>
  91. </el-table>
  92. </el-collapse-item>
  93. </el-collapse>
  94. </el-row>
  95. <el-row v-if="tableData.length>0">
  96. <el-collapse value='2'>
  97. <el-collapse-item name="2">
  98. <div slot="title">
  99. 具体业务项(<span style="color: red;">总费用{{totalMoney}}元</span>)
  100. </div>
  101. <el-table :data="tableData" style="width: 100%">
  102. <el-table-column prop="itemTypeName" label="收费项" width="180">
  103. </el-table-column>
  104. <el-table-column prop="itemName" label="收费明细" width="200">
  105. </el-table-column>
  106. <el-table-column prop="itemPrice" label="单价" width="170">
  107. </el-table-column>
  108. <el-table-column prop="unit" label="计费标准" width="160">
  109. </el-table-column>
  110. <el-table-column prop="num" label="数量" width="160">
  111. </el-table-column>
  112. <el-table-column prop="total" label="合计" width="120">
  113. </el-table-column>
  114. <sa-td width="120" name="支付状态" prop="payStatus" type="enum"
  115. :jv="{0: '未支付[#ff0000]', 1: '已支付[#005500]'}" width="130">
  116. </sa-td>
  117. <el-table-column prop="payTime" label="支付时间" width="140">
  118. </el-table-column>
  119. <el-table-column prop="remark" label="备注" width="140">
  120. </el-table-column>
  121. </el-table>
  122. </el-collapse-item>
  123. </el-collapse>
  124. </el-row>
  125. </el-form>
  126. </div>
  127. </div>
  128. <!-- ------- 底部按钮 ------- -->
  129. <div class="s-foot">
  130. <el-button v-if="sa.isAuth('tb-business-car-judge')&&m.businessType===1&&m.confirmJudge!=1" class="c-btn"
  131. type="success" icon="el-icon" @click="pass()">审核通过</el-button>
  132. <el-button v-if="sa.isAuth('tb-business-car-judge')&&m.businessType===1&&m.confirmJudge==1" class="c-btn"
  133. type="warning" icon="el-icon" @click="callback()">审核驳回</el-button>
  134. <el-button v-if="sa.isAuth('tb-business-car-print')&&m.pay===1&&m.businessType===1" type="success" @click="printFn()">打印</el-button>
  135. <el-button type="success" @click="sa.closeCurrIframe()">关闭</el-button>
  136. </div>
  137. </div>
  138. <script>
  139. var app = new Vue({
  140. components: {
  141. "sa-info": httpVueLoader('../../sa-frame/com/sa-info.vue'),
  142. "sa-td": httpVueLoader('../../sa-frame/com/sa-td.vue'),
  143. },
  144. el: '.vue-box',
  145. data: {
  146. businessList: [],
  147. tableData: [],
  148. id: sa.p('id', 0), // 获取数据ID
  149. m: {}
  150. },
  151. computed:{
  152. totalMoney(){
  153. let businessList=this.businessList;
  154. let money=0;
  155. for(let i in businessList){
  156. money+=parseFloat(businessList[i].itemPrice);
  157. }
  158. return money;
  159. }
  160. },
  161. methods: {
  162. pass() {
  163. sa.ajax('/TbBusinessCar/confirmJudgePass', {
  164. id: this.id
  165. }, function(res) {
  166. sa.alert('审核通过', this.clean);
  167. }.bind(this))
  168. },
  169. callback() {
  170. let that = this;
  171. layer.prompt({
  172. title: '填写审核意见'
  173. }, function(content, index) {
  174. layer.close(index);
  175. sa.ajax('/TbBusinessCar/callback', {
  176. id: that.id,
  177. judgeContent: content
  178. }, function(res) {
  179. sa.alert('已驳回', that.clean);
  180. })
  181. });
  182. },
  183. clean() {
  184. parent.app.f5();
  185. sa.closeCurrIframe();
  186. },
  187. printFn() {
  188. sa.showIframe('凭据打印', 'tb-business-car-print.html?businessCarId=' + this.id, '800px', '100%');
  189. },
  190. getItemsByCarId() {
  191. sa.ajax('/TbBusinessItem/getByBusinessCarId', {
  192. businessCarId: this.id
  193. }, function(resp) {
  194. this.tableData = resp.data;
  195. }.bind(this))
  196. },
  197. getByBusinessCarId() {
  198. sa.ajax('/TbBusiness/getByBusinessCarId', {
  199. businessCarId: this.id
  200. }, function(resp) {
  201. this.businessList = resp.data;
  202. }.bind(this))
  203. },
  204. getById() {
  205. sa.ajax('/TbBusinessCar/getById?id=' + this.id, function(res) {
  206. this.m = res.data;
  207. if (res.data == null) {
  208. sa.alert('未能查找到 id=' + this.id + " 详细数据");
  209. }
  210. }.bind(this))
  211. }
  212. },
  213. mounted: function() {
  214. this.getById();
  215. this.getItemsByCarId();
  216. this.getByBusinessCarId();
  217. }
  218. })
  219. </script>
  220. </body>
  221. </html>