billingRules.vue 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. <template>
  2. <view>
  3. <u-navbar title="计费规则" title-color="#101010"></u-navbar>
  4. <view class="background">
  5. <!-- 单位 -->
  6. <view class="unit">
  7. <view class="title">
  8. 所属收款单位
  9. </view>
  10. <view class="value">
  11. {{name}}
  12. </view>
  13. </view>
  14. <!-- 规则 -->
  15. <view class="rules">
  16. <view class="content">
  17. <view class="title">
  18. <view class="title-item">
  19. 用电分类
  20. </view>
  21. <view class="title-item">
  22. 用电时段
  23. </view>
  24. <view class="title-item">
  25. 电度电价
  26. </view>
  27. </view>
  28. <view class="classify" v-for="(item,index) in electricPeriodPriceList" :key="index"
  29. :class="item.timeList.length>1 ? 'classify2' : ''" v-if="item.timeList.length!=0">
  30. <view class="classify-title">
  31. {{item.name}}
  32. </view>
  33. <view class="classify-value">
  34. <p v-for="t in item.timeList">{{t.startTime}}-{{t.endTime}}</p>
  35. </view>
  36. <view class="classify-value">
  37. {{item.price}}元/度
  38. </view>
  39. </view>
  40. </view>
  41. </view>
  42. <!-- 备注 -->
  43. <view class="remark" v-if="tenantContract!=null">
  44. <view class="title">
  45. 备注说明:
  46. </view>
  47. <view class="value">
  48. <view class="item">1.计费规则仅展示租赁合同中的计算方式,最终扣费金额以账单中的实际扣费金额为准。
  49. </view>
  50. <view class="item" v-if="startTime!=null && endTime!=null">
  51. 2.本次租约有效期:{{startTime}}-{{endTime}}
  52. </view>
  53. </view>
  54. </view>
  55. </view>
  56. </view>
  57. </view>
  58. </template>
  59. <script>
  60. import * as API_electricityMeter from '@/apis/pagejs/electricityMeter.js'
  61. import {
  62. parseUnixTime,
  63. beforeTimeStamp,
  64. getWeek
  65. } from '@/apis/utils'
  66. export default {
  67. data() {
  68. return {
  69. electricPeriodPriceList: [],
  70. queryDate: '',
  71. meterId: '',
  72. name: '',
  73. tenantContract: null,
  74. startTime: null,
  75. endTime: null
  76. }
  77. },
  78. onLoad(op) {
  79. if (op.id) {
  80. this.meterId = op.id;
  81. this.queryDate = op.queryDate;
  82. this.getBillingRules();
  83. }
  84. },
  85. methods: {
  86. getBillingRules() {
  87. uni.showLoading({
  88. title: "加载中",
  89. mask: true,
  90. })
  91. API_electricityMeter.billingRules({
  92. meterId: this.meterId,
  93. queryDate: this.queryDate + '-01'
  94. }).then((res) => {
  95. uni.hideLoading();
  96. this.name = res.data.name;
  97. this.tenantContract = res.data.tenantContract;
  98. if (res.data.tenantContract != null) {
  99. var startTime = res.data.tenantContract.startTime;
  100. var endTime = res.data.tenantContract.endTime;
  101. if (startTime != null) {
  102. this.startTime = startTime.slice(0, 4) + '年' + parseInt(startTime.slice(5, 7)) + '月'
  103. + parseInt(startTime.slice(8)) + '日';
  104. }
  105. if (endTime != null) {
  106. this.endTime = endTime.slice(0, 4) + '年' + parseInt(endTime.slice(5, 7)) + '月'
  107. + parseInt(endTime.slice(8)) + '日';
  108. }
  109. }
  110. var list = res.data.groupPriceList;
  111. var cList = list[0];
  112. if (cList.chargeType == '1') {
  113. var time1 = '00:00';
  114. var time2 = '24:00';
  115. // if (cList.startTime) {
  116. // time1 = cList.startTime;
  117. // }
  118. // if (cList.endTime) {
  119. // time2 = cList.endTime;
  120. // }
  121. this.electricPeriodPriceList = [{
  122. period: '1',
  123. name: '单一电价',
  124. price: cList.price,
  125. timeList:[
  126. {
  127. startTime: time1,
  128. endTime: time2
  129. }]
  130. }
  131. ];
  132. } else {
  133. var list2 = [];
  134. var list3 = [
  135. {period: '1',name: '尖峰用电',price: 0,timeList:[]},
  136. {period: '2',name: '高峰用电',price: 0,timeList:[]},
  137. {period: '3',name: '平段用电',price: 0,timeList:[]},
  138. {period: '4',name: '谷段用电',price: 0,timeList:[]}
  139. ];
  140. for (var i = 0; i < list.length; i++) {
  141. list2 = [...list2, ...list[i].electricPeriodPriceList];
  142. }
  143. for (var m = 0; m < list2.length; m++) {
  144. for (var n = 0; n < list3.length; n++) {
  145. if(list2[m].period == list3[n].period) {
  146. list3[n].price = list2[m].price;
  147. list3[n].timeList.push({
  148. startTime: list2[m].startTime,
  149. endTime: list2[m].endTime
  150. });
  151. }
  152. }
  153. }
  154. this.electricPeriodPriceList = list3;
  155. }
  156. // console.log(this.electricPeriodPriceList)
  157. }).catch(error => {
  158. uni.showToast({
  159. title: error,
  160. icon: "none"
  161. })
  162. })
  163. },
  164. }
  165. }
  166. </script>
  167. <style lang="scss" scoped>
  168. .background {
  169. background: linear-gradient(180deg, rgba(22, 119, 255, 1) 0%, rgba(22, 119, 255, 0) 100%);
  170. height: 720rpx;
  171. padding-top: 24rpx;
  172. .unit {
  173. background-color: #fff;
  174. border-radius: 8px;
  175. padding: 32rpx;
  176. margin: 0 32rpx;
  177. .title {
  178. color: rgba(153, 153, 153, 1);
  179. }
  180. .value {
  181. color: rgba(51, 51, 51, 1);
  182. font-size: 40rpx;
  183. margin-top: 16rpx;
  184. font-weight: bold;
  185. }
  186. }
  187. }
  188. // 规则
  189. .rules {
  190. margin: 24rpx 32rpx 40rpx;
  191. background-color: #fff;
  192. padding-bottom: 24rpx;
  193. border-radius: 8px;
  194. .content {
  195. padding: 24rpx;
  196. .title {
  197. display: flex;
  198. justify-content: space-between;
  199. align-items: center;
  200. line-height: 96rpx;
  201. color: rgba(51, 51, 51, 1);
  202. font-size: 32rpx;
  203. font-weight: bold;
  204. .title-item {
  205. width: 33.3%;
  206. }
  207. }
  208. .classify {
  209. display: flex;
  210. align-items: center;
  211. justify-content: space-between;
  212. height: 96rpx;
  213. .classify-title,
  214. .classify-value {
  215. width: 33.3%;
  216. color: #666666;
  217. }
  218. .classify-title {
  219. color: #333333;
  220. }
  221. }
  222. .classify2 {
  223. height: 200rpx;
  224. }
  225. }
  226. // 备注
  227. .remark {
  228. padding: 40rpx 32rpx;
  229. margin: 0 24rpx;
  230. border-radius: 8px;
  231. background-color: rgba(242, 244, 246, 1);
  232. color: rgba(16, 16, 16, 1);
  233. font-size: 24rpx;
  234. line-height: 34rpx;
  235. .value {
  236. margin-top: 16rpx;
  237. }
  238. .item {
  239. margin-bottom: 8rpx;
  240. }
  241. }
  242. }
  243. </style>