sale-client 4.1.230 → 4.2.1-ronghao

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (171) hide show
  1. package/build/dev-server.js +29 -46
  2. package/package.json +2 -2
  3. package/src/App.vue +3 -3
  4. package/src/components/FilesManage/UserGeneralInfoTest.vue +4 -4
  5. package/src/components/FilesManageNew/FileUserFiles.vue +2 -4
  6. package/src/components/FilesManageNew/MeterinfoTest.vue +9 -9
  7. package/src/components/FilesManageNew/UserEssentialInfoTest.vue +201 -227
  8. package/src/components/FilesManageNew/UserGeneralInfoTest.vue +0 -2
  9. package/src/components/charge/business/CardMeterCenter.vue +1 -1
  10. package/src/components/charge/business/FilesComplete.vue +3 -3
  11. package/src/components/charge/business/IOTMeterCenter.vue +1 -1
  12. package/src/components/charge/business/OtherChargeNew.vue +68 -48
  13. package/src/components/common/userinfo_detail/UserInfoDetailManageNew.vue +10 -1
  14. package/src/components/common/userinfo_detail/ic_detail/CardHandRecord.vue +1 -1
  15. package/src/components/common/userinfo_detail/ic_detail/ChangeMeterQueryUser.vue +1 -1
  16. package/src/components/common/userinfo_detail/ic_detail/GarbageRecordList.vue +69 -0
  17. package/src/components/common/userinfo_detail/ic_detail/InsuranceChargesRecord.vue +384 -0
  18. package/src/components/common/userinfo_detail/ic_detail/WebHandQueryUser.vue +1 -1
  19. package/src/components/revenue/Common/MeterMessage.vue +1 -1
  20. package/src/components/revenue/HandManager/MeterBookUser.vue +726 -726
  21. package/src/components/revenue/HandManager/WebHand.vue +7 -4
  22. package/src/components/revenue/base/leftview/SafeCheck.vue +41 -3
  23. package/src/components/revenue/base/leftview/UserFeeInfo.vue +76 -0
  24. package/src/components/revenue/base/leftview/otherinfo.vue +1 -0
  25. package/src/components/revenue/base/rightview/CardList.vue +7 -3
  26. package/src/components/revenue/batchDeduction/batchDeductionList.vue +1 -1
  27. package/src/components/revenue/cardHandManage/cardDown.vue +18 -0
  28. package/src/components/revenue/changeInsurance/InsuranceAdd.vue +1 -0
  29. package/src/components/revenue/changeInsurance/InsuranceRecord.vue +2 -1
  30. package/src/components/revenue/comprehen/ComprehenOperation/BankPayment/BankPayment.vue +1 -1
  31. package/src/components/revenue/comprehen/ComprehenOperation/GiftFee/icTable.vue +4 -2
  32. package/src/components/revenue/comprehen/ComprehenOperation/QrPay/QrPaymentDetailed.vue +423 -423
  33. package/src/components/revenue/comprehen/Maintenance/hand/handOperate.vue +469 -469
  34. package/src/components/revenue/comprehen/Maintenance/revenue/MeterOperatemain.vue +2 -2
  35. package/src/components/revenue/machineHandManage/ArrearsQuery.vue +938 -938
  36. package/src/components/revenue/machineHandManage/HandplanQuery.vue +1 -1
  37. package/src/components/revenue/machineHandManage/machineHand.vue +3 -2
  38. package/src/components/webMeter/MeterManage/WebMeterBatchOperationValve.vue +970 -970
  39. package/src/filiale/alashan/eticket/EticketRecordList.vue +428 -428
  40. package/src/filiale/bayan/ChargeList.vue +1010 -1010
  41. package/src/filiale/bayan/StockListmain.vue +543 -543
  42. package/src/filiale/beifangshiye/OtherChargeNew.vue +625 -625
  43. package/src/filiale/dexin/MeterinfoTest.vue +1239 -0
  44. package/src/filiale/dexin/UserEssentialInfoTest.vue +602 -0
  45. package/src/filiale/dexin/sale.js +5 -0
  46. package/src/filiale/fugou/MeterinfoTest.vue +1 -1
  47. package/src/filiale/jiaxian/AutomaticPurse.vue +349 -0
  48. package/src/filiale/jiaxian/ChangeMeterQueryUser.vue +303 -0
  49. package/src/filiale/jiaxian/ChangeRecord.vue +44 -2
  50. package/src/filiale/jiaxian/FillCardQueryUser.vue +250 -0
  51. package/src/filiale/jiaxian/FillGasQueryUser.vue +270 -0
  52. package/src/filiale/jiaxian/OtherChargeQueryUser.vue +305 -0
  53. package/src/filiale/jiaxian/PriceAdjustmentQueryUser.vue +368 -0
  54. package/src/filiale/jiaxian/PriceChangeQueryUser.vue +243 -0
  55. package/src/filiale/jiaxian/QueryInstruct.vue +436 -0
  56. package/src/filiale/jiaxian/RecordQueryUser.vue +321 -0
  57. package/src/filiale/jiaxian/Repurchase.vue +181 -0
  58. package/src/filiale/jiaxian/TransferQueryUser.vue +274 -0
  59. package/src/filiale/jiaxian/UserInfoDetailManageNew.vue +11 -11
  60. package/src/filiale/jiaxian/Userinfo.vue +426 -0
  61. package/src/filiale/jiaxian/WatchCollection.vue +54 -1
  62. package/src/filiale/jiaxian/WebAutomaticPurse.vue +348 -0
  63. package/src/filiale/jiaxian/contractSigningList.vue +149 -0
  64. package/src/filiale/jiaxian/sale.js +5 -0
  65. package/src/filiale/jinhong/AutoAccountsDetail.vue +63 -0
  66. package/src/filiale/jinhong/CardList.vue +572 -0
  67. package/src/filiale/jinhong/CardMeterCenter.vue +1 -1
  68. package/src/filiale/jinhong/CardMeterCenterInner.vue +61 -22
  69. package/src/filiale/jinhong/GarbageCharge.vue +1 -1
  70. package/src/filiale/jinhong/HandplanQuery.vue +1430 -0
  71. package/src/filiale/jinhong/IOTMeterCenterInner.vue +42 -14
  72. package/src/filiale/jinhong/InsuranceAdd.vue +27 -5
  73. package/src/filiale/jinhong/InsuranceChargesDetails.vue +11 -5
  74. package/src/filiale/jinhong/InsuranceRecord.vue +4 -5
  75. package/src/filiale/jinhong/InsuranceTemp.vue +33 -5
  76. package/src/filiale/jinhong/MachineChargeService.js +8 -0
  77. package/src/filiale/jinhong/MachineMeterCenter.vue +38 -11
  78. package/src/filiale/jinhong/ShowCardSellGasInner.vue +46 -14
  79. package/src/filiale/jinhong/Userinfo.vue +75 -1
  80. package/src/filiale/jinhong/insuranceGuanL.vue +349 -0
  81. package/src/filiale/jinhong/machineDown.vue +1205 -0
  82. package/src/filiale/jinhong/sale.js +9 -0
  83. package/src/filiale/jinhuang/UserInfoDetailManageNew.vue +259 -0
  84. package/src/filiale/jinhuang/WebHand.vue +1026 -0
  85. package/src/filiale/jinhuang/WebHandQueryUser.vue +413 -0
  86. package/src/filiale/jinhuang/cardsHand.vue +911 -0
  87. package/src/filiale/jinhuang/sale.js +8 -0
  88. package/src/filiale/lixianV3/ArrearsQuery.vue +938 -938
  89. package/src/filiale/lixianV3/InsuranceAdd.vue +1 -0
  90. package/src/filiale/lixianV3/InsuranceChargesDetails.vue +425 -425
  91. package/src/filiale/meihekou/CardMeterCenter.vue +991 -0
  92. package/src/filiale/meihekou/ChargeManage.vue +3 -2
  93. package/src/filiale/meihekou/ChargeOper.vue +279 -169
  94. package/src/filiale/meihekou/HandManager.vue +57 -2
  95. package/src/filiale/meihekou/NoCardMeterCenter.vue +542 -0
  96. package/src/filiale/meihekou/OverUseCharge.vue +1 -1
  97. package/src/filiale/meihekou/PrintBill.vue +48 -41
  98. package/src/filiale/meihekou/ReissueBill.vue +4 -1
  99. package/src/filiale/meihekou/ShowCardSellGas.vue +935 -0
  100. package/src/filiale/meihekou/TransferManage.vue +704 -0
  101. package/src/filiale/meihekou/Userinfo.vue +233 -5
  102. package/src/filiale/meihekou/common/userinfo_detail/ic_detail/MachineRecordQuery.vue +281 -281
  103. package/src/filiale/meihekou/icTable.vue +233 -0
  104. package/src/filiale/meihekou/machineHand.vue +2158 -0
  105. package/src/filiale/meihekou/manualChargeCenter.vue +394 -0
  106. package/src/filiale/meihekou/meterTable.vue +220 -0
  107. package/src/filiale/meihekou/sale.js +15 -0
  108. package/src/filiale/qianneng/MeterMessage.vue +1 -1
  109. package/src/filiale/qianneng/revenue/sms/AccountMessageList.vue +508 -508
  110. package/src/filiale/rizhao/InsuranceAdd.vue +1 -0
  111. package/src/filiale/ronghao/ArrearsQuery.vue +974 -974
  112. package/src/filiale/ronghao/CardList.vue +19 -17
  113. package/src/filiale/ronghao/CardMeterChargeCancel.vue +5 -0
  114. package/src/filiale/ronghao/CardService.js +2144 -2144
  115. package/src/filiale/ronghao/ChangeMeterService.js +1 -1
  116. package/src/filiale/ronghao/ChargeList.vue +17 -17
  117. package/src/filiale/ronghao/ChargeManage.vue +325 -0
  118. package/src/filiale/ronghao/ChargeOper.vue +330 -0
  119. package/src/filiale/ronghao/FilesManageNew/UserEssentialInfoTest.vue +457 -0
  120. package/src/filiale/ronghao/FilesManageNew/UserGeneralInfoTest.vue +690 -0
  121. package/src/filiale/ronghao/HandplanQuery.vue +13 -14
  122. package/src/filiale/ronghao/IOTMeterCenter.vue +15 -6
  123. package/src/filiale/ronghao/InsuranceAdd.vue +1 -0
  124. package/src/filiale/ronghao/InsuranceManage.vue +58 -58
  125. package/src/filiale/ronghao/MachineChargeService.js +149 -149
  126. package/src/filiale/ronghao/NoCardMeterCenter.vue +534 -534
  127. package/src/filiale/ronghao/PaymentCode.vue +174 -174
  128. package/src/filiale/ronghao/PriceChangeCompensation/CompensationManage.vue +26 -26
  129. package/src/filiale/ronghao/PriceChangeCompensation/IotCompensation.vue +318 -318
  130. package/src/filiale/ronghao/PriceChangeCompensation/JbCompensation.vue +343 -343
  131. package/src/filiale/ronghao/PriceChangeCompensation/SurplusRecordDetail.vue +74 -74
  132. package/src/filiale/ronghao/ReplaceCardManage.vue +415 -415
  133. package/src/filiale/ronghao/Upload.vue +654 -654
  134. package/src/filiale/ronghao/Userinfo.vue +18 -18
  135. package/src/filiale/ronghao/cardDown.vue +1141 -1141
  136. package/src/filiale/ronghao/changemeterOperate.vue +315 -315
  137. package/src/filiale/ronghao/fillgasSpecific.vue +313 -313
  138. package/src/filiale/ronghao/ic_detail/ChargeRecordQuery.vue +106 -106
  139. package/src/filiale/ronghao/ic_detail/WatchCollection.vue +115 -115
  140. package/src/filiale/ronghao/ic_detail/WebHandQueryUser.vue +411 -411
  141. package/src/filiale/ronghao/machineDown.vue +1176 -1176
  142. package/src/filiale/ronghao/machineRefund.vue +3 -1
  143. package/src/filiale/ronghao/replacementSingleInfoOperation.vue +315 -315
  144. package/src/filiale/ronghao/sale.js +11 -0
  145. package/src/filiale/ronghao/specificInformation.vue +537 -537
  146. package/src/filiale/ronghao/uploadFilesHistory.vue +214 -0
  147. package/src/filiale/ruihua/FilesManage/MeterinfoTest.vue +10 -0
  148. package/src/filiale/shanxian/components/revenue/InsuranceAdd.vue +1 -0
  149. package/src/filiale/wuan/MeterMessage.vue +1 -1
  150. package/src/filiale/yangchun/BasicLivingList.vue +281 -0
  151. package/src/filiale/yangchun/BlackList/BlackRecordQuery.vue +1 -0
  152. package/src/filiale/yangchun/CardChangeFill.vue +1 -1
  153. package/src/filiale/yangchun/ChargeList.vue +954 -954
  154. package/src/filiale/yangchun/FilesManage/UserPaperInfoTest.vue +3 -3
  155. package/src/filiale/yangchun/NewMeterList.vue +742 -0
  156. package/src/filiale/yangchun/sale.js +3 -0
  157. package/src/filiale/yuncheng/CardList.vue +1 -1
  158. package/src/filiale/yuncheng/IndustryCommerceHand.vue +1145 -0
  159. package/src/filiale/yuncheng/IndustryCommerceHandAudit.vue +794 -0
  160. package/src/filiale/yuncheng/IndustryCommerceHandManager.vue +64 -0
  161. package/src/filiale/yuncheng/InsuranceAdd.vue +1 -0
  162. package/src/filiale/yuncheng/MeterBookUser.vue +781 -0
  163. package/src/filiale/yuncheng/UserDeviceInfoTest.vue +2 -2
  164. package/src/filiale/yuncheng/changemeterListMaintain.vue +504 -504
  165. package/src/filiale/yuncheng/industryDown.vue +1118 -0
  166. package/src/filiale/yuncheng/sale.js +11 -0
  167. package/src/filiale/yuncheng/uploadFilesHistory.vue +185 -0
  168. package/src/filiale/zhongsheng/BlackListList.vue +293 -293
  169. package/src/filiale/zhongyi/HandQueryUser.vue +389 -389
  170. package/src/plugins/CardService.js +2217 -2217
  171. package/src/sale.js +3 -1
@@ -0,0 +1,781 @@
1
+ <template>
2
+ <div class="flex">
3
+ <criteria-paged :model="model" v-ref:paged @sort="sort">
4
+ <criteria partial='criteria' @condition-changed='$parent.selfSearch' v-ref:criteria>
5
+ <div novalidate class="form-horizontal select-overspread container-fluid auto" partial>
6
+ <div class="row" >
7
+ <div class="form-group col-sm-4" >
8
+ <label class="font_normal_body">客户编号</label>
9
+ <input type="text" class="input_search" style="width:60%" v-model="model.f_userinfo_code" placeholder='客户编号'
10
+ condition="info.f_userinfo_code = '{}'" @keyup.enter="search()">
11
+ </div>
12
+ <div class="form-group col-sm-4 button-range" >
13
+ <button class="button_search" style="margin-right: 10px" @click="search()" v-el:cba>查询</button>
14
+ <button class="button_search" style="margin-right: 10px" @click="$parent.$parent.autoMeterBookSort()">表箱号排序</button>
15
+ <button class="button_search" style="margin-right: 10px" @click="$parent.$parent.saveSort()">保存当前顺序</button>
16
+ <button class="button_search" v-if="$parent.$parent.editsort == false" @click="$parent.$parent.editsort=true" v-el:cba>调整顺序</button>
17
+ <button class="button_search" v-if="$parent.$parent.editsort == true" @click="$parent.$parent.saveEditSort" v-el:cba>保存顺序</button>
18
+ <export-excel
19
+ :data="{condition: $parent.$parent.condition,orderitem: $parent.$parent.orderitem}"
20
+ :field="$parent.$parent.getfield"
21
+ sqlurl="api/af-revenue/logic/saleExport" sql-name="getMeterBookUser" :template-name="$parent.$parent.model.rows[0].f_book_name+'抄表册名'"
22
+ :choose-col="true"></export-excel>
23
+ <button class="button_export button_spacing" @click="$parent.$parent.importFile">导入</button>
24
+ <div
25
+ :class="{'button_shrink_top':$parent.$parent.criteriaShow,'button_shrink_bottom':!$parent.$parent.criteriaShow}"
26
+ @click="$parent.$parent.criteriaShow=!$parent.$parent.criteriaShow"
27
+ class="button_spacing"
28
+ style="float: right"></div>
29
+ </div>
30
+ </div>
31
+ <div class="row" v-show="$parent.$parent.criteriaShow">
32
+ <div class="col-sm-4 form-group">
33
+ <label class="font_normal_body">客户姓名</label>
34
+ <input type="text" style="width:60%" class="input_search" v-model="model.f_user_name" placeholder='客户姓名'
35
+ condition="info.f_user_name = '{}'">
36
+ </div>
37
+ <div class="col-sm-4 form-group">
38
+ <label class="font_normal_body">客户地址</label>
39
+ <input type="text" style="width:60%" class="input_search" v-model="model.f_address"
40
+ condition="address.f_address like '%{}%'" placeholder='客户地址'>
41
+ </div>
42
+ <div class="col-sm-4 form-group">
43
+ <label class="font_normal_body">表&emsp;&emsp;号</label>
44
+ <input style="width:60%" type="text" class="form-control" v-model="model.f_meternumber"
45
+ condition="uf.f_meternumber like '%{}%'" placeholder='表号'
46
+ >
47
+ </div>
48
+ <div class="col-sm-4 form-group">
49
+ <label class="font_normal_body">气表品牌</label>
50
+ <v-select :value.sync="model.f_gasbrand_id"
51
+ v-model="model.f_gasbrand_id"
52
+ :options='$parent.$parent.meterbrands' placeholder='请选择'
53
+ condition="gb.f_meter_brand = '{}'"
54
+ close-on-select></v-select>
55
+ </div>
56
+ <div class="col-sm-4 form-group">
57
+ <label class="font_normal_body">气表类型</label>
58
+ <v-select :value.sync="model.f_meter_type"
59
+ v-model="model.f_meter_type"
60
+ :options='$parent.$parent.meterTypes' placeholder='请选择'
61
+ condition="gb.f_meter_type = '{}'"
62
+ close-on-select></v-select>
63
+ </div>
64
+ <div class="col-sm-4 form-group">
65
+ <label class="font_normal_body">客户类型</label>
66
+ <v-select :value.sync="model.f_user_type"
67
+ :options='$parent.$parent.usertypes'
68
+ @change="$parent.$parent.userTypeChange()"
69
+ placeholder='请选择' v-model="model.f_user_type"
70
+ condition="uf.f_user_type = '{}'"
71
+ close-on-select></v-select>
72
+ </div>
73
+ <div class="col-sm-4 form-group">
74
+ <label class="font_normal_body">用气性质</label>
75
+ <v-select :value.sync="model.f_gasproperties" v-model="model.f_gasproperties"
76
+ :options='$parent.$parent.gasproperties' placeholder='请选择'
77
+ condition="uf.f_gasproperties = '{}'"
78
+ close-on-select></v-select>
79
+ </div>
80
+ <div class="col-sm-4 form-group">
81
+ <label class="font_normal_body">气价类型</label>
82
+ <v-select :value.sync="model.pricetype" v-model="model.pricetype"
83
+ placeholder='气价类型' :options="$parent.$parent.pricetypes"
84
+ condition="sp.f_price_type = '{}'"
85
+ close-on-select v-ref:type>
86
+ </v-select>
87
+ </div>
88
+ <div class="col-sm-4 form-group">
89
+ <label class="font_normal_body">气价名称</label>
90
+ <v-select :value.sync="model.f_price_id"
91
+ v-model="model.f_price_id"
92
+ :options="$parent.$parent.getPricenames"
93
+ placeholder='请选择'
94
+ condition="uf.f_price_id = '{}'"
95
+ close-on-select></v-select>
96
+ </div>
97
+ <div class="col-sm-4 form-group">
98
+ <label class="font_normal_body">客户电话</label>
99
+ <input class="input_search"
100
+ condition="info.f_user_phone = '{}'" placeholder='电话' style="width:60%"
101
+ type="text"
102
+ v-model="model.f_user_phone">
103
+ </div>
104
+ <div class="col-sm-4 form-group">
105
+ <label class="font_normal_body">小&emsp;&emsp;区</label>
106
+ <input style="width:60%" type="text" class="form-control" v-model="model.f_residential_area"
107
+ condition="address.f_residential_area like '%{}%'" placeholder='小区'
108
+ >
109
+ </div>
110
+ <div class="col-sm-4 form-group">
111
+ <label class="font_normal_body">楼&emsp;&emsp;栋</label>
112
+ <input style="width:60%" type="text" class="form-control" v-model="model.f_building"
113
+ condition="address.f_building like '%{}%'" placeholder='楼栋'
114
+ >
115
+ </div>
116
+ <div class="col-sm-4 form-group">
117
+ <label class="font_normal_body">单&emsp;&emsp;元</label>
118
+ <input style="width:60%" type="text" class="form-control" v-model="model.f_unit"
119
+ condition="address.f_unit like '%{}%'" placeholder='单元'
120
+ >
121
+ </div>
122
+ <div class="col-sm-4 form-group">
123
+ <label class="font_normal_body">表箱号&emsp;</label>
124
+ <input style="width:60%" type="text" class="form-control" v-model="model.f_metertitles"
125
+ condition="uf.f_metertitles like '%{}%'" placeholder='表箱号'
126
+ >
127
+ </div>
128
+ <div class="col-sm-4 form-group">
129
+ <label class="font_normal_body">入户证号</label>
130
+ <input style="width:60%" type="text" class="form-control" v-model="model.f_book_no"
131
+ condition="info.f_book_no like '%{}%'" placeholder='入户证号'
132
+ >
133
+ </div>
134
+ <div class="col-sm-4 form-group">
135
+ <label class="font_normal_body">抄&nbsp;表&nbsp;员&nbsp;</label>
136
+ <v-select :value.sync="model.f_inputtor" v-model='model.f_inputtor'
137
+ style="width:60%"
138
+ multiple="true"
139
+ condition="uf.f_inputtor in {}"
140
+ :options='$parent.$parent.inputtores' placeholder='抄表员'
141
+ close-on-select
142
+ v-el:cc></v-select>
143
+ </div>
144
+ </div>
145
+ </div>
146
+ </criteria>
147
+ <data-grid :model="model" class="table_sy" partial='list' v-ref:grid>
148
+ <template partial='head' >
149
+ <tr>
150
+ <th v-if="$parent.$parent.$parent.editsort"><nobr>排序</nobr></th>
151
+ <th v-if="$parent.$parent.$parent.removebook"><nobr>移出</nobr></th>
152
+ <th><nobr>客户编号</nobr></th>
153
+ <th><nobr>客户名称</nobr></th>
154
+ <th>
155
+ <data-order field="f_address" name="客户地址"
156
+ :order.sync="$parent.$parent.$parent.orderFields.f_address"></data-order>
157
+ </th>
158
+ <th>
159
+ <data-order field="f_street" name="街道"
160
+ :order.sync="$parent.$parent.$parent.orderFields.f_street"></data-order>
161
+ </th>
162
+ <th>
163
+ <data-order field="f_residential_area" name="小区"
164
+ :order.sync="$parent.$parent.$parent.orderFields.f_residential_area"></data-order>
165
+ </th>
166
+ <th>
167
+ <data-order field="f_building" name="楼栋"
168
+ :order.sync="$parent.$parent.$parent.orderFields.f_building"></data-order>
169
+ </th>
170
+ <th>
171
+ <data-order field="f_unit" name="单元"
172
+ :order.sync="$parent.$parent.$parent.orderFields.f_unit"></data-order>
173
+ </th>
174
+ <th>
175
+ <data-order field="f_floor" name="楼层"
176
+ :order.sync="$parent.$parent.$parent.orderFields.f_floor"></data-order>
177
+ </th>
178
+ <th>
179
+ <data-order field="f_room" name="房间号"
180
+ :order.sync="$parent.$parent.$parent.orderFields.f_room"></data-order>
181
+ </th>
182
+ <th><nobr>客户电话</nobr></th>
183
+ <th><nobr>表号</nobr></th>
184
+ <th>
185
+ <data-order field="f_meter_book_sort" name="册内排序"
186
+ :order.sync="$parent.$parent.$parent.orderFields.f_meter_book_sort"></data-order>
187
+ </th>
188
+ <th><nobr>抄表册名称</nobr></th>
189
+ <th><nobr>抄表员</nobr></th>
190
+ <th><nobr>表箱号</nobr></th>
191
+ <th><nobr>入户证号</nobr></th>
192
+ <th><nobr>表底数</nobr></th>
193
+ <th><nobr>用户类型</nobr></th>
194
+ <th><nobr>用气类型</nobr></th>
195
+ <th><nobr>气表品牌</nobr></th>
196
+ <th><nobr>气表型号</nobr></th>
197
+ <th><nobr>抄表日期</nobr></th>
198
+ </tr>
199
+ </template>
200
+ <template partial='body' >
201
+ <tr>
202
+ <td style="text-align:center" v-if="$parent.$parent.$parent.editsort">
203
+ <nobr>
204
+ <span class="glyphicon glyphicon-arrow-up" @click="$parent.$parent.$parent.sortUp($index, row)" v-el:cba></span>
205
+ &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
206
+ <span class="glyphicon glyphicon-arrow-down" @click="$parent.$parent.$parent.sortDown($index, row)" v-el:cba></span>
207
+ </nobr>
208
+ </td>
209
+ <td style="text-align:center" v-if="$parent.$parent.$parent.removebook">
210
+ <nobr>
211
+ <span title="移出表册" class="glyphicon glyphicon-paste" style="font-size: 20px" @click="$parent.$parent.$parent.delete($index, row)" v-el:cba></span>
212
+ <!-- <button class="btn btn-deltete width-10" @click="$parent.$parent.$parent.delete($index, row)"><a style="color: #e51a1abf"><b>移出表册</b></a></button>-->
213
+ </nobr>
214
+ </td>
215
+ <td style="text-align:center"><nobr><span @click="$parent.$parent.$parent.dealmsg(row)"><a><b>{{row.f_userinfo_code}}</b></a></span></nobr></td>
216
+ <td style="text-align:center"><nobr>{{row.f_user_name}}</nobr></td>
217
+ <td style="text-align:center;white-space: nowrap;"><nobr>{{row.f_address}}</nobr></td>
218
+ <td style="text-align:center;white-space: nowrap;"><nobr>{{row.f_street}}</nobr></td>
219
+ <td style="text-align:center;white-space: nowrap;"><nobr>{{row.f_residential_area}}</nobr></td>
220
+ <td style="text-align:center;white-space: nowrap;"><nobr>{{row.f_building}}</nobr></td>
221
+ <td style="text-align:center;white-space: nowrap;"><nobr>{{row.f_unit}}</nobr></td>
222
+ <td style="text-align:center;white-space: nowrap;"><nobr>{{row.f_floor}}</nobr></td>
223
+ <td style="text-align:center;white-space: nowrap;"><nobr>{{row.f_room}}</nobr></td>
224
+ <td style="text-align:center"><nobr>{{row.f_user_phone}}</nobr></td>
225
+ <td style="text-align:center;white-space: nowrap;"><nobr>{{row.f_meternumber}}</nobr></td>
226
+ <td style="text-align:center;"><nobr>{{row.f_meter_book_sort}}</nobr></td>
227
+ <td style="text-align:center"><nobr>{{row.f_book_name}}</nobr></td>
228
+ <td style="text-align:center"><nobr>{{row.f_inputtor}}</nobr></td>
229
+ <td style="text-align:center"><nobr>{{row.f_metertitles}}</nobr></td>
230
+ <td style="text-align:center"><nobr>{{row.f_book_no}}</nobr></td>
231
+ <td style="text-align:center"><nobr>{{row.f_meter_base}}</nobr></td>
232
+ <td style="text-align:center"><nobr>{{row.f_user_type}}</nobr></td>
233
+ <td style="text-align:center"><nobr>{{row.f_gasproperties}}</nobr></td>
234
+ <td style="text-align:center"><nobr>{{row.f_meter_brand}}</nobr></td>
235
+ <td style="text-align:center"><nobr>{{row.f_meter_style}}</nobr></td>
236
+ <td style="text-align:center"><nobr>{{row.f_hand_date}}</nobr></td>
237
+ </tr>
238
+ </template>
239
+ <template partial='foot'></template>
240
+ </data-grid>
241
+ </criteria-paged>
242
+ <div v-if="isSaving" class="saving-mask">
243
+ <div class="saving-mask-content">正在保存,请稍候...</div>
244
+ </div>
245
+ </div>
246
+ <modal :show.sync="sortShow" width="500px" title="修改册内排序" v-ref:modal large backdrop="false">
247
+ <article slot="modal-body" class="modal-body">
248
+ <div>
249
+ <div class="row app-row">
250
+ <p class="col-sm-6">客户编号:{{row.f_userinfo_code}}</p>
251
+ <p class="col-sm-6">客户姓名:{{row.f_user_name}}</p>
252
+ <p class="col-sm-6">所在表册:{{row.f_book_name}}</p>
253
+ <p class="col-sm-6">册内排序:{{row.f_meter_book_sort}}</p>
254
+ <label for="f_plan_name" class="font text-left">目标用户编号:</label>
255
+ <input type="text" @change="getBook()" class="search_input input-font" v-model="fileinfo.code" placeholder='目标用户编号'
256
+ >
257
+ </div>
258
+ <div class="row app-row" v-show="fileinfo.meterbook && fileinfo.sort">
259
+ <p class="col-sm-6">表册:{{fileinfo.meterbook}}</p>
260
+ <p class="col-sm-6">册内排序:{{fileinfo.sort}}</p>
261
+ </div>
262
+ <div class="row app-row">
263
+ <div class="col-sm-6" style="text-align: center;">
264
+
265
+ <button type="button" class="button_search" style="width:40%;background-color: #499EDF;color:#f2f6fa" :disabled="!(fileinfo.meterbook && fileinfo.sort)" @click="sortEdit(0)"><img src="./../../../static/images/meterBook/up.png" style="width: 20%;margin-left:-10px"></img>&nbsp;前</button>
266
+ </div>
267
+ <div class="col-sm-6" style="text-align: center;">
268
+ <button type="button" class="button_search" style="width:40%;background-color: #499EDF;color:#f2f6fa" :disabled="!(fileinfo.meterbook && fileinfo.sort)" @click="sortEdit(1)">后&nbsp;<img src="./../../../static/images/meterBook/down.png" style="width: 20%;"></img></button>
269
+ </div>
270
+ </div>
271
+ </div>
272
+
273
+
274
+ </article>
275
+ <footer slot="modal-footer" class="modal-footer" v-show="false">
276
+
277
+ </footer>
278
+ </modal>
279
+ <modal :show.sync="show" width="800px" title="文件导入" v-ref:modal large backdrop="false">
280
+ <article slot="modal-body" class="modal-body">
281
+ <file-upload class="my-file-uploader " name="UploadFile" style="border-radius: 2px;"
282
+ action="rs/file/uploadFile" tagname="导入表册用户" v-ref:file multiple></file-upload>
283
+ </article>
284
+ <footer slot="modal-footer" class="modal-footer">
285
+ </footer>
286
+ </modal>
287
+ </template>
288
+
289
+ <script>
290
+ import {HttpResetClass, PagedList} from 'vue-client'
291
+ let readyGen = async function (self) {
292
+ self.getfield = self.config.excelHeaders
293
+ // await this.$LoadParams.loadParam(this.f_filialeid)
294
+ self.search()
295
+ await self.$LoadParams.loadParam()
296
+ self.initParams()
297
+ }
298
+
299
+ export default {
300
+ title: '',
301
+ data () {
302
+ return {
303
+ model: new PagedList('api/af-revenue/sql/getMeterBookUser', 20, {orderitem: this.orderitem ? '"' + this.orderitem + ' "' : `'f_meter_book_sort asc'`}),
304
+ condition: '',
305
+ getfield: {},
306
+ show: false,
307
+ removebook: true,
308
+ row: null,
309
+ sortShow: false,
310
+ fileinfo: {
311
+ code: null,
312
+ meterbook: null,
313
+ booknum: null,
314
+ sort: null,
315
+ fileid: null,
316
+ infoid: null
317
+ },
318
+ gasproperties: [],
319
+ f_filialeid: this.$login.f.orgid,
320
+ newinfo: {
321
+ f_user_type: '',
322
+ f_gasproperties: '',
323
+ pricetype: '',
324
+ bookname: '',
325
+ f_perform_date: this.$login.toStandardDateString() + ' 00:00:00' // 操作时间
326
+ },
327
+ meterbrands: [],
328
+ adjustables: [],
329
+ meterstyle: {},
330
+ criteriaShow: false,
331
+ editsort: false,
332
+ // 排序
333
+ sortitem: 'f_meter_book_sort',
334
+ rule: 'asc',
335
+ orderitem: 'f_meter_book_sort asc',
336
+ orderFields: {
337
+ f_meter_book_sort: 'no'
338
+ },
339
+ config: {
340
+ excelHeaders: {
341
+ 'f_userfiles_id': '系统识别号',
342
+ 'f_book_name': '抄表册名称',
343
+ 'f_userinfo_code': '客户编号',
344
+ 'f_user_name': '客户姓名',
345
+ 'f_user_phone': '客户电话',
346
+ 'f_meternumber': '表号',
347
+ 'f_address': '客户地址',
348
+ 'f_inputtor': '抄表员',
349
+ 'f_meter_book_sort': '册内排序',
350
+ 'f_metertitles': '表箱号',
351
+ 'f_meter_base': '表底数',
352
+ 'f_user_type': '用户类型',
353
+ 'f_gasproperties': '用气类型',
354
+ 'f_meter_classify': '气表品牌',
355
+ 'f_gasmodel_id': '气表型号',
356
+ 'f_hand_date': '抄表日期'
357
+ }
358
+ },
359
+ isSaving: false
360
+ }
361
+ },
362
+ props: ['f_meterbook_num', 'usercount'],
363
+ async ready () {
364
+ readyGen(this)
365
+ },
366
+ methods: {
367
+ sort (field, rule) {
368
+ // 将所有排序方式设为不排序,实现相互排斥
369
+ for (let key in this.orderFields) {
370
+ if (key === field) {
371
+ this.orderFields[key] = rule
372
+ } else {
373
+ this.orderFields[key] = 'no'
374
+ }
375
+ }
376
+ // 如果新规则不排序,还原为默认排序
377
+ if (rule === 'no') {
378
+ this.model.paramSource.orderitem = `'f_meter_book_sort asc'`
379
+ this.rule = 'asc'
380
+ this.sortitem = 'f_meter_book_sort'
381
+ } else {
382
+ this.model.paramSource.orderitem = `'${field} ${rule}'`
383
+ this.orderitem = this.model.paramSource.orderitem
384
+ this.rule = rule
385
+ this.sortitem = field
386
+ }
387
+ this.search()
388
+ },
389
+ async saveSort () {
390
+ if (!this.$login.r.find(value => value == '册内用户排序')) {
391
+ this.$showMessage('你没有【册内用户排序】的权限,请联系管理员!')
392
+ return
393
+ }
394
+ if (this.model.count < this.usercount) {
395
+ this.$showAlert('该功能适用于给表册内所有用户排序的情况,请去掉查询条件', 'warning', 3000)
396
+ } else {
397
+ this.$showMessage('此操作会将表册内用户按照现有查询结果的顺序排序,是否继续', ['confirm', 'cancel']).then(async (res) => {
398
+ if (res == 'confirm') {
399
+ this.isSaving = true
400
+ try {
401
+ await this.$resetpost('api/af-revenue/logic/changeBookSort',
402
+ {
403
+ data: {
404
+ f_meter_book_num: this.f_meterbook_num,
405
+ sortitem: this.sortitem,
406
+ rule: this.rule
407
+ }
408
+ }, {resolveMsg: '已成功修改册内排序!!', rejectMsg: '册内排序修改失败!!'})
409
+ this.isSaving = false
410
+ this.$showAlert('保存成功', 'success', 2000)
411
+ } catch (error) {
412
+ this.$showAlert('保存失败', 'error', 2000)
413
+ } finally {
414
+ this.search()
415
+ }
416
+ }
417
+ })
418
+ }
419
+ },
420
+ async autoMeterBookSort () {
421
+ if (!this.$login.r.find(value => value == '册内用户排序')) {
422
+ this.$showMessage('你没有【册内用户排序】的权限,请联系管理员!')
423
+ return
424
+ }
425
+ this.$showMessage('请确认是否按照表箱自动排序?', ['confirm', 'cancel']).then((res) => {
426
+ if (res == 'confirm') {
427
+ this.$resetpost('api/af-revenue/logic/autoMeterBookSort',
428
+ {
429
+ data: {
430
+ f_meter_book_num: this.f_meterbook_num,
431
+ sortitem: this.sortitem,
432
+ rule: this.rule
433
+ }
434
+ }, {resolveMsg: '册内排序完成!!', rejectMsg: '册内排序修改失败!!'})
435
+ this.search()
436
+ }
437
+ })
438
+ },
439
+ importFile () {
440
+ if (!this.$login.r.find(value => value == '表册排序导入')) {
441
+ this.$showMessage('你没有【表册排序导入】的权限,请联系管理员!')
442
+ return
443
+ }
444
+ this.show = true
445
+ },
446
+ async sortEdit (position) {
447
+ if (!this.fileinfo.code) {
448
+ this.$showMessage('请输入目标用户编号')
449
+ return
450
+ }
451
+ // position:
452
+ // 0--将改用户的表册顺序排到目标用户前
453
+ // 1--将改用户的表册顺序排到目标用户后
454
+ if ((!this.fileinfo.sort) || (!this.fileinfo.booknum)) {
455
+ this.$showMessage('目标用户无表册或在表册内无排序')
456
+ return
457
+ }
458
+ let http = new HttpResetClass()
459
+ await http.load('POST', 'api/af-revenue/logic/sale_editBookSort', {data: {fileinfo: this.fileinfo, position: position, userfilesid: this.row.f_userfiles_id}}, {resolveMsg: '已成功将改表移到指定的表册位置', rejectMsg: '移动册内位置失败'})
460
+ this.fileinfo = {
461
+ code: null,
462
+ fileid: null,
463
+ booknum: null,
464
+ meterbook: null,
465
+ infoid: null,
466
+ sort: null
467
+ }
468
+ this.sortShow = false
469
+ this.search()
470
+ },
471
+ async getBook () {
472
+ if (this.fileinfo.code) {
473
+ let http = new HttpResetClass()
474
+ let res = await http.load('POST', 'api/af-revenue/sql/sale_getUserMeterBook', {
475
+ data: {
476
+ condition: `i.f_userinfo_code='${this.fileinfo.code}'`
477
+ }
478
+ }, {resolveMsg: null, rejectMsg: null})
479
+ console.log('-------------------res:', res.data)
480
+ if (res.data.length === 1) {
481
+ if ((!res.data[0].f_meter_book_sort) || (!res.data[0].f_meter_book_num)) {
482
+ this.$showMessage('该用户不在表册内或在表册内无排序')
483
+ this.fileinfo = {
484
+ code: this.fileinfo.code,
485
+ fileid: null,
486
+ booknum: null,
487
+ meterbook: null,
488
+ infoid: null,
489
+ sort: null
490
+ }
491
+ return
492
+ }
493
+ this.fileinfo.meterbook = res.data[0].f_book_name
494
+ this.fileinfo.sort = res.data[0].f_meter_book_sort
495
+ this.fileinfo.fileid = res.data[0].f_userfiles_id
496
+ this.fileinfo.infoid = res.data[0].f_userinfo_id
497
+ this.fileinfo.booknum = res.data[0].f_meter_book_num
498
+ } else {
499
+ this.$showMessage('请核对输入的用户编号')
500
+ this.fileinfo = {
501
+ code: this.fileinfo.code,
502
+ fileid: null,
503
+ booknum: null,
504
+ meterbook: null,
505
+ infoid: null,
506
+ sort: null
507
+ }
508
+ }
509
+ }
510
+ },
511
+ async saveEditSort () {
512
+ this.isSaving = true
513
+ try {
514
+ for (let item of this.$refs.paged.$refs.grid.model.rows) {
515
+ let param = {
516
+ f_userfiles_id: item.f_userfiles_id,
517
+ version: item.fileversion,
518
+ f_meter_book_sort: item.f_meter_book_sort
519
+ }
520
+ let http = new HttpResetClass()
521
+ await http.load('POST', 'api/af-revenue/entity/save/t_userfiles',
522
+ param,
523
+ {resolveMsg: null, rejectMsg: '保存失败'})
524
+ }
525
+ this.$showAlert('保存成功', 'success', 2000)
526
+ } catch (error) {
527
+ this.$showAlert('保存失败', 'error', 2000)
528
+ } finally {
529
+ this.search()
530
+ this.editsort = false
531
+ this.isSaving = false
532
+ }
533
+ },
534
+ // 下移按钮
535
+ sortDown (index, row) {
536
+ if (index === (this.model.rows.length - 1)) {
537
+ this.$showAlert('已经是本页最后一个了', 'warning', 2000)
538
+ } else {
539
+ let rows = this.$refs.paged.$refs.grid.model.rows
540
+ this.$refs.paged.$refs.grid.model.rows = []
541
+ let temp = rows[index + 1]
542
+ rows[index + 1] = rows[index]
543
+ rows[index] = temp
544
+ let tempsort = rows[index + 1].f_meter_book_sort
545
+ rows[index + 1].f_meter_book_sort = rows[index].f_meter_book_sort
546
+ rows[index].f_meter_book_sort = tempsort
547
+ this.$refs.paged.$refs.grid.model.rows = rows
548
+ }
549
+ },
550
+ // 上移按钮
551
+ sortUp (index, row) {
552
+ if (index === 0) {
553
+ this.$showAlert('已经是本页第一个了', 'warning', 2000)
554
+ } else {
555
+ let rows = this.$refs.paged.$refs.grid.model.rows
556
+ this.$refs.paged.$refs.grid.model.rows = []
557
+ let temp = rows[index - 1]
558
+ rows[index - 1] = rows[index]
559
+ rows[index] = temp
560
+ console.log('--------------this.$refs.paged.$refs.grid.model.rows,', rows)
561
+ let tempsort = rows[index - 1].f_meter_book_sort
562
+ rows[index - 1].f_meter_book_sort = rows[index].f_meter_book_sort
563
+ rows[index].f_meter_book_sort = tempsort
564
+ this.$refs.paged.$refs.grid.model.rows = rows
565
+ }
566
+ },
567
+ // 移出表册
568
+ async delete (index, row) {
569
+ let param = {
570
+ f_userfiles_id: row.f_userfiles_id,
571
+ version: row.fileversion,
572
+ f_meter_book_sort: '',
573
+ f_meter_book_num: ''
574
+ }
575
+ let http = new HttpResetClass()
576
+ await http.load('POST', 'api/af-revenue/entity/save/t_userfiles',
577
+ param,
578
+ {resolveMsg: null, rejectMsg: '保存失败'})
579
+ this.$refs.paged.$refs.criteria.search()
580
+ },
581
+ close () {
582
+ this.show = false
583
+ this.newinfo = {
584
+ f_user_type: '',
585
+ f_gasproperties: '',
586
+ pricetype: '',
587
+ bookname: ''
588
+ }
589
+ },
590
+ userTypeChange () {
591
+ this.gasproperties = []
592
+ if (this.$refs.paged.$refs.criteria.model !== null) {
593
+ this.$refs.paged.$refs.criteria.model.f_gasproperties = ''
594
+ this.gasproperties = this.$appdata.getParam(this.$refs.paged.$refs.criteria.model.f_user_type[0])
595
+ } else {
596
+ this.gasproperties = [{label: '全部', value: ''}]
597
+ }
598
+ },
599
+ async initParams () {
600
+ console.log('=================>加载', this.$GetSaleParam.getGasbrand())
601
+ let arr = []
602
+ let filter = this.$login.f.orgid
603
+ this.$GetSaleParam.getAdjustable(filter).forEach((item) => {
604
+ let temp = {}
605
+ temp.label = `[${item.value.f_adjustable_id}]-${item.label}`
606
+ temp.value = `${item.value.id}`
607
+ arr.push(temp)
608
+ })
609
+ this.adjustables = [{label: '全部', value: ''}, ...arr]
610
+ // 初始化气表品牌
611
+ let brandArr = []
612
+ this.$GetSaleParam.getGasbrand().forEach((item) => {
613
+ let temp = {}
614
+ temp.label = item.label
615
+ temp.value = item.value.id
616
+ brandArr.push(temp)
617
+ // 取出对应气表型号
618
+ let styleArr = []
619
+ for (let row of item.value.gasmodel) {
620
+ styleArr.push({label: row.label, value: row.value.id})
621
+ }
622
+ this.meterstyle[temp.value] = styleArr
623
+ })
624
+ this.meterbrands = [{label: '全部', value: ''}, ...brandArr]
625
+ // 初始化气表价格
626
+ this.prices = this.$GetSaleParam.getPrice(filter)
627
+ },
628
+ sortModelval () {
629
+ let sortModel = []
630
+ Object.keys(this.fields).forEach((key) => {
631
+ if (this.modelval.includes(key)) {
632
+ sortModel.push(key)
633
+ }
634
+ })
635
+ this.modelval = sortModel
636
+ console.log('选择的打印的字段', this.modelval)
637
+ },
638
+ async updateParams () {
639
+ await this.$MagLoadParams.loadParam(this.f_filialeid)
640
+ this.initParams()
641
+ },
642
+
643
+ loadMeterBooks () {
644
+ let meterbrand = this.$GetSaleParam.getGasbrand()
645
+ for (let row of meterbrand) {
646
+ console.log(row)
647
+ this.meterbrands.push({label: row.label, value: row.value.id})
648
+ }
649
+ },
650
+ search () {
651
+ this.$refs.paged.$refs.criteria.search()
652
+ },
653
+
654
+ selfSearch (args) {
655
+ this.editsort = false
656
+ args.condition = `${args.condition} and f_meter_book_num = '${this.f_meterbook_num}'`
657
+ this.condition = args.condition
658
+ this.model.search(args.condition, args.model)
659
+ },
660
+ dealmsg (val) {
661
+ this.$parent.f_userinfo_id = val.f_userinfo_id
662
+ this.$parent.listpage = false
663
+ }
664
+
665
+ },
666
+ watch: {
667
+ 'f_meterbook_num' (val) {
668
+ this.search()
669
+ }
670
+ },
671
+ events: {
672
+ onFileUpload: function (file, res) {
673
+ this.$resetpost('api/af-revenue/logic/upLoadBookFile',
674
+ {data: {
675
+ condition: this.condition,
676
+ filepath: res.f_downloadpath
677
+ }
678
+ },
679
+ {resolveMsg: null, rejectMsg: '上传失败'}).then((res) => {
680
+ this.show = false
681
+ this.$showAlert(`导入成功`, 'success', 2000)
682
+ this.search()
683
+ })
684
+ }
685
+ },
686
+ computed: {
687
+ inputtores () {
688
+ // 获取抄表员
689
+ console.log('获取抄表员', this.$login.f)
690
+ let rs = []
691
+ if (this.$login.f.f_gasman.length > 0) {
692
+ for (let i = 0; i < this.$login.f.f_gasman.length; i++) {
693
+ let temp = {
694
+ label: this.$login.f.f_gasman[i].name,
695
+ value: this.$login.f.f_gasman[i].name
696
+ }
697
+ rs.push(temp)
698
+ }
699
+ }
700
+ return [ ...rs]
701
+ },
702
+ pricetypes () {
703
+ return [{label: '全部', value: ''}, ...this.$appdata.getParam('气价类型')]
704
+ },
705
+ meterTypes () {
706
+ return [{label: '全部', value: ''}, ...this.$appdata.getParam('气表类型')]
707
+ },
708
+ usertypes () {
709
+ return [{label: '全部', value: ''}, ...this.$appdata.getParam('用户类型')]
710
+ },
711
+ getPricenames () {
712
+ console.log('getPricenames======')
713
+ let f_user_type = this.$refs.paged.$refs.criteria.model.f_user_type
714
+ let f_gasproperties = this.$refs.paged.$refs.criteria.model.f_gasproperties
715
+ let pricetype = this.$refs.paged.$refs.criteria.model.pricetype
716
+ console.log('打印一下:', pricetype)
717
+ if (this.$refs.paged.$refs.criteria.model !== null) {
718
+ let rs = []
719
+ let priceArr = []
720
+ if (pricetype.length > 0 && f_user_type.length > 0 && f_gasproperties.length > 0) {
721
+ let params = {
722
+ f_user_type: f_user_type[0],
723
+ f_gasproperties: f_gasproperties[0],
724
+ f_price_type: pricetype[0]
725
+ }
726
+ console.log('params', params)
727
+ console.log('getPricenames======', this.$GetSaleParam.getPrice(params))
728
+ this.$GetSaleParam.getPrice(params).forEach((item) => {
729
+ let temp = {}
730
+ temp.label = item.label
731
+ temp.value = item.value.f_price_id
732
+ priceArr.push(temp)
733
+ })
734
+ rs = [ ...priceArr]
735
+ }
736
+ if (rs.length === 0) {
737
+ console.log('rs读出来是空')
738
+ this.$refs.paged.$refs.criteria.model.f_price_name = ''
739
+ }
740
+ return rs
741
+ }
742
+ }
743
+
744
+ }
745
+
746
+ }
747
+ </script>
748
+
749
+ <style scoped>
750
+ .saving-mask {
751
+ position: fixed;
752
+ top: 0;
753
+ left: 0;
754
+ width: 100vw;
755
+ height: 100vh;
756
+ background: rgba(0, 0, 0, 0.3);
757
+ z-index: 9999;
758
+ display: flex;
759
+ align-items: flex-start;
760
+ justify-content: center;
761
+ padding-top: 120px;
762
+ }
763
+
764
+ .saving-mask-content {
765
+ background: #fff;
766
+ color: #333;
767
+ padding: 24px 32px;
768
+ border-radius: 8px;
769
+ font-size: 16px;
770
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
771
+ text-align: center;
772
+ min-width: 200px;
773
+ max-width: 320px;
774
+ min-height: 60px;
775
+ max-height: 120px;
776
+ width: 300px;
777
+ display: flex;
778
+ align-items: center;
779
+ justify-content: center;
780
+ }
781
+ </style>