tb-fee-details-list.html 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <title>收费明细表-列表</title>
  5. <meta charset="utf-8">
  6. <meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
  7. <!-- 所有的 css & js 资源 -->
  8. <link rel="stylesheet" href="https://unpkg.com/element-ui@2.13.0/lib/theme-chalk/index.css">
  9. <link rel="stylesheet" href="../../static/sa.css">
  10. <script src="https://unpkg.com/vue@2.6.10/dist/vue.js"></script>
  11. <script src="https://unpkg.com/element-ui@2.13.0/lib/index.js"></script>
  12. <script src="https://unpkg.com/http-vue-loader@1.4.2/src/httpVueLoader.js"></script>
  13. <script src="https://unpkg.com/jquery@3.4.1/dist/jquery.js"></script>
  14. <script src="https://www.layuicdn.com/layer-v3.1.1/layer.js"></script>
  15. <script src="../../static/sa.js"></script>
  16. </head>
  17. <body>
  18. <div class="vue-box" style="display: none;" :style="'display: block;'">
  19. <div class="c-panel">
  20. <!-- ------------- 检索参数 ------------- -->
  21. <div class="c-title">检索参数</div>
  22. <el-form ref="form" :model='p' @submit.native.prevent>
  23. <div class="c-item">
  24. <label class="c-label">业务类型:</label>
  25. <el-select v-model="p.itemTypeName" placeholder="请选择" filterable>
  26. <el-option v-for="item in itemTypeList" :key="item.id"
  27. :label="item.name" :value="item.name">
  28. </el-option>
  29. </el-select>
  30. </div>
  31. <div class="c-item">
  32. <label class="c-label">日期:</label>
  33. <el-date-picker type="date" value-format="yyyy-MM-dd" v-model="p.payDay"></el-date-picker>
  34. </div>
  35. <el-button type="primary" icon="el-icon-search" @click="p.pageNo = 1; f5()">查询</el-button>
  36. <br />
  37. </el-form>
  38. <!-- ------------- 快捷按钮 ------------- -->
  39. <div class="fast-btn">
  40. <el-button type="warning" icon="el-icon-download" @click="exportFn()">导出</el-button>
  41. <el-button type="info" icon="el-icon-refresh" @click="sa.f5()">刷新</el-button>
  42. <slot></slot>
  43. </div>
  44. <!-- ------------- 数据列表 ------------- -->
  45. <el-table class="data-table" ref="data-table" :data="dataList" >
  46. <sa-td type="selection"></sa-td>
  47. <sa-td name="业务单号" prop="businessNo" ></sa-td>
  48. <sa-td name="车牌号" prop="carNo" ></sa-td>
  49. <sa-td name="收费类型" prop="feeType" type="enum"
  50. :jv="{1: '核酸检测',2: '消杀作业', 3: '装卸作业', 4: '停车费', 5: '过磅费', 6: '入场管理费', 7: '充电打冷作业'}"></sa-td>
  51. <sa-td name="业务类型" prop="itemTypeName" ></sa-td>
  52. <sa-td name="业务项" prop="itemName" ></sa-td>
  53. <sa-td name="作业单位" prop="pickCustomerName" ></sa-td>
  54. <sa-td name="项目金额" prop="itemPrice" ></sa-td>
  55. <sa-td name="税率" prop="taxRate" ></sa-td>
  56. <sa-td name="不含税金额" prop="noTaxPrice" ></sa-td>
  57. <sa-td name="支付日期" prop="payDay" ></sa-td>
  58. <sa-td name="支付方式" prop="payType" type="enum" :jv="{3: '微信支付'}"></sa-td>
  59. <!-- <el-table-column label="操作" fixed="right" width="240px">-->
  60. <!-- <template slot-scope="s">-->
  61. <!-- <el-button class="c-btn" type="success" icon="el-icon-view" @click="get(s.row)">查看</el-button>-->
  62. <!-- <el-button class="c-btn" type="primary" icon="el-icon-edit" @click="update(s.row)">修改</el-button>-->
  63. <!-- <el-button class="c-btn" type="danger" icon="el-icon-delete" @click="del(s.row)">删除</el-button>-->
  64. <!-- </template>-->
  65. <!-- </el-table-column>-->
  66. </el-table>
  67. <!-- ------------- 分页 ------------- -->
  68. <sa-item type="page" :curr.sync="p.pageNo" :size.sync="p.pageSize" :total="dataCount" @change="f5()"></sa-item>
  69. </div>
  70. <el-dialog title="提示" :visible.sync="emodel.visible" width="30%">
  71. <el-form size="mini">
  72. <div class="c-item">
  73. <label class="c-label">日期:</label>
  74. <el-date-picker type="date" value-format="yyyy-MM-dd" v-model="emodel.form.payDay"></el-date-picker>
  75. </div>
  76. </el-form>
  77. <span slot="footer" class="dialog-footer">
  78. <el-button @click="emodel.visible = false">取 消</el-button>
  79. <el-button type="primary" @click="sureExport">确 定</el-button>
  80. </span>
  81. </el-dialog>
  82. </div>
  83. <script>
  84. var app = new Vue({
  85. components: {
  86. "sa-item": httpVueLoader('../../sa-frame/com/sa-item.vue'),
  87. "sa-td": httpVueLoader('../../sa-frame/com/sa-td.vue'),
  88. },
  89. el: '.vue-box',
  90. data: {
  91. p: { // 查询参数
  92. id: '', // 主键
  93. businessNo: '', // 业务单号
  94. carNo: '', // 车牌号
  95. itemTypeId: '', // 业务类型id
  96. itemTypeName: '', // 业务类型
  97. itemId: '', //
  98. itemName: '', // 业务项
  99. itemPrice: '', // 项目金额(元)
  100. payDay: '', // 支付日期
  101. payType: '', // 支付方式(3=微信支付)
  102. createTime: '', // 创建时间
  103. pageNo: 1, // 当前页
  104. pageSize: 10, // 页大小
  105. sortType: 9 // 排序方式
  106. },
  107. dataCount: 0,
  108. dataList: [], // 数据集合
  109. itemTypeList: [],
  110. emodel: {
  111. visible: false,
  112. form: {
  113. payDay: ''
  114. }
  115. },
  116. },
  117. methods: {
  118. exportFn() {
  119. Object.assign(this.emodel, {
  120. visible: true,
  121. })
  122. },
  123. sureExport() {
  124. if (this.emodel.form.payDay == '') {
  125. sa.msg("请选择日期");
  126. return;
  127. }
  128. sa.ajax('/TbFeeDetails/export/details', this.emodel.form, function(resp) {
  129. window.open(resp.data);
  130. this.emodel.visible = false;
  131. }.bind(this));
  132. },
  133. // 刷新
  134. f5: function() {
  135. sa.ajax('/TbFeeDetails/getList', sa.removeNull(this.p), function(res) {
  136. this.dataList = res.data; // 数据
  137. this.dataCount = res.dataCount; // 数据总数
  138. sa.f5TableHeight(); // 刷新表格高度
  139. }.bind(this));
  140. },
  141. // 查看
  142. get: function(data) {
  143. sa.showIframe('数据详情', 'tb-fee-details-info.html?id=' + data.id, '1050px', '90%');
  144. },
  145. // 查看 - 根据选中的
  146. getBySelect: function(data) {
  147. var selection = this.$refs['data-table'].selection;
  148. if(selection.length == 0) {
  149. return sa.msg('请选择一条数据')
  150. }
  151. this.get(selection[0]);
  152. },
  153. getItemTypeList() {
  154. sa.ajax('/TbItemType/getList', {
  155. pageNo: 1,
  156. pageSize: 100
  157. }, function(resp) {
  158. this.itemTypeList = resp.data;
  159. }.bind(this));
  160. },
  161. },
  162. created: function() {
  163. this.f5();
  164. this.getItemTypeList();
  165. sa.onInputEnter();
  166. }
  167. })
  168. </script>
  169. </body>
  170. </html>