change-balance-opt.vue 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225
  1. <template>
  2. <div v-loading="loading">
  3. <div class="white-box">
  4. <el-tabs v-model="tabActiveName">
  5. <el-tab-pane :label="$t('financial.manuallyAdd')" name="first" v-if="permission.hasPermission(`finance/change-balance`)"><!--手动添加-->
  6. <el-form ref="form" :model="form" label-width="250px" class="bkele-form-page">
  7. <el-form-item :label="$t('financial.memberCode')"><!--会员编号-->
  8. <el-input v-model="form.userName" @change="handleChange"></el-input>
  9. </el-form-item>
  10. <el-form-item :label="$t('financial.memberName')" v-show="userInfo.REAL_NAME!==null"><!--会员姓名-->
  11. <el-input :value="userInfo.REAL_NAME" :disabled="true"></el-input>
  12. </el-form-item>
  13. <el-form-item :label="$t('financial.memberLevel')" v-show="userInfo.REAL_NAME!==null"><!--会员级别-->
  14. <el-input :value="userInfo.LEVEL_NAME" :disabled="true"></el-input>
  15. </el-form-item>
  16. <!--<el-form-item label="报单中心级别" v-show="userInfo.DEC_ROLE_NAME!=='无'">-->
  17. <!--<el-input :value="userInfo.DEC_ROLE_NAME" :disabled="true"></el-input>-->
  18. <!--</el-form-item>-->
  19. <el-form-item :label="item.label" v-show="userInfo.REAL_NAME!==null" v-for="(item,key) in type" :key="key">
  20. <el-input :value="userInfo[item.name.toUpperCase()]" :disabled="true"></el-input>
  21. </el-form-item>
  22. <el-form-item :label="$t('financial.accountType')"><!--账户类型-->
  23. <el-select v-model="form.type" :placeholder="$t('financial.pleaseSelectAccountType')"><!--请选择账户类型-->
  24. <el-option v-for="(item,key) in type" :label="item.label" :value="key" :key="key"></el-option>
  25. </el-select>
  26. </el-form-item>
  27. <el-form-item :label="$t('financial.adjustAmount')"><!--调整金额-->
  28. <el-input v-model="form.amount"></el-input>
  29. </el-form-item>
  30. <el-form-item :label="$t('financial.transactionType')"><!--交易类型-->
  31. <el-select v-model="form.dealType" :placeholder="$t('financial.pleaseSelectTranserType')"><!--请选择交易类型-->
  32. <el-option v-for="(item,key) in dealTypes" :label="item.TYPE_NAME" :value="item.ID"
  33. :key="item.ID"></el-option>
  34. </el-select>
  35. </el-form-item>
  36. <el-form-item :label="$t('common.note')"><!--备注-->
  37. <el-input v-model="form.remark"></el-input>
  38. </el-form-item>
  39. <!--备注前台显示-->
  40. <!-- <el-form-item :label="$t('financial.forgeDisplayRemark')">
  41. <el-form-item :label="$t('financial.forgeDisplayRemark')" v-show="false">
  42. <el-switch v-model="form.isShow" active-value="1" inactive-value="0">
  43. </el-switch>
  44. </el-form-item> -->
  45. <el-form-item>
  46. <el-button type="primary" :loading="submitButtonStat" :disabled="getCodeStat" @click="onSubmit">{{ $t('common.confirm') }}<!-- 提交 --></el-button>
  47. </el-form-item>
  48. </el-form>
  49. </el-tab-pane>
  50. <!--<el-tab-pane label="批量导入" name="second"-->
  51. <!--v-if="permission.hasPermission(`finance/import-change-balance-to-excel-table`)&&permission.hasPermission(`finance/import-change-balance`)">-->
  52. <!--<el-form ref="form" :model="form" label-width="250px" class="form-page">-->
  53. <!--<el-form-item label="Excel文件总行数">-->
  54. <!--<el-input v-model="excelForm.rowCount"></el-input>-->
  55. <!--</el-form-item>-->
  56. <!--<el-form-item label="">-->
  57. <!--<el-tag type="info">表格中账户类型要求英文:bonus(会员账户余额)、reconsume_points(复消积分)</el-tag>-->
  58. <!--</el-form-item>-->
  59. <!--<el-form-item>-->
  60. <!--<leo-excel-uploader-->
  61. <!--:request-upload-route="`file/upload-excel`"-->
  62. <!--:request-import-to-excel-table-route="`finance/import-change-balance-to-excel-table`"-->
  63. <!--:request-import-excel-table-to-data-route="`finance/import-change-balance`"-->
  64. <!--:import-row-count="excelForm.rowCount"-->
  65. <!--excel-option="changeBalance"-->
  66. <!--upload-btn-title="Excel导入"-->
  67. <!--style="float: left;"-->
  68. <!--&gt;</leo-excel-uploader>-->
  69. <!--<el-button type="primary" @click="handleExcel" style="float: left; margin-left: 10px;">下载模板</el-button>-->
  70. <!--</el-form-item>-->
  71. <!--</el-form>-->
  72. <!--</el-tab-pane>-->
  73. </el-tabs>
  74. </div>
  75. </div>
  76. </template>
  77. <script>
  78. import tool from '@/utils/tool'
  79. import baseInfo from '@/utils/baseInfo'
  80. import { getChangeBalanceType, multPoint, changeBalance, userFullInfo } from '@/api/finance'
  81. // import {CDN_BASE_URL} from '@/utils/config'
  82. import permission from '@/utils/permission'
  83. export default {
  84. name: 'finance_change-balance-opt',
  85. mounted() {
  86. getChangeBalanceType().then(response => {
  87. this.type = response.data.type
  88. this.dealTypes = response.data.dealTypes
  89. this.loading = false
  90. if (permission.hasPermission(`finance/import-change-balance-to-excel-table`) && permission.hasPermission(`finance/import-change-balance`)) {
  91. this.tabActiveName = 'second'
  92. }
  93. if (permission.hasPermission(`finance/change-balance`)) {
  94. this.tabActiveName = 'first'
  95. }
  96. }).catch(err => {
  97. console.log(err)
  98. this.loading = false
  99. })
  100. multPoint({opType: 1}).then(response => {
  101. this.form.balanceCode = response.data.balanceCode
  102. this.getCodeStat = false
  103. })
  104. },
  105. data() {
  106. return {
  107. form: {
  108. userName: null,
  109. type: null,
  110. amount: 0,
  111. remark: '',
  112. isShow: '1',
  113. dealType: null,
  114. balanceCode: '',
  115. },
  116. userInfo: {
  117. REAL_NAME: null,
  118. DEC_ROLE_NAME: '',
  119. BONUS: 0,
  120. BONUS_FREEZE: 0,
  121. DEC_LV: 0,
  122. DEC_DEC_LV: 0,
  123. },
  124. baseDecLevels: baseInfo.decLevels(),
  125. type: null,
  126. dealTypes: null,
  127. loading: true,
  128. submitButtonStat: false,
  129. getCodeStat: true,
  130. tool: tool,
  131. tabActiveName: 'first',
  132. excelForm: {
  133. rowCount: 0,
  134. },
  135. permission: permission,
  136. }
  137. },
  138. methods: {
  139. handleChange() {
  140. this.loading = true
  141. userFullInfo({userName: this.form.userName}).then(response => {
  142. this.userInfo = response.data
  143. this.loading = false
  144. }).catch(err => {
  145. this.loading = false
  146. this.$message({
  147. message: err,
  148. type: 'error'
  149. })
  150. })
  151. },
  152. onSubmit() {
  153. if (this.form.type === 'bonus') {
  154. if ((Number.parseFloat(this.userInfo['BONUS']) + Number.parseFloat(this.form.amount)) < 0) {
  155. this.$confirm(this.$t('financial.ecoinInsufficientNotice'), this.$t('common.hint'), {// 会员账户余额不足,是否继续提交
  156. confirmButtonText: this.$t('common.confirm'), // 确定
  157. cancelButtonText: this.$t('common.cancel'), // 取消
  158. type: 'warning'
  159. }).then(() => {
  160. this._handleSubmit()
  161. }).catch(() => {
  162. this.submitButtonStat = false
  163. return false
  164. })
  165. } else {
  166. this._handleSubmit()
  167. }
  168. } else {
  169. this._handleSubmit()
  170. }
  171. },
  172. _handleSubmit() {
  173. this.submitButtonStat = true
  174. changeBalance(this.form).then(response => {
  175. this.submitButtonStat = false
  176. this.$message({
  177. message: response.data,
  178. type: 'success'
  179. })
  180. this.$router.go(-1)
  181. }).catch(err => {
  182. this.submitButtonStat = false
  183. this.$message({
  184. message: err,
  185. type: 'error'
  186. })
  187. })
  188. },
  189. handleExcel() {
  190. // window.open(CDN_BASE_URL + `/files/bonus_change_balance.xlsx`)
  191. },
  192. }
  193. }
  194. </script>
  195. <style scoped>
  196. @media (min-width: 761px) {
  197. /deep/ .el-input__inner {
  198. width: 500px;
  199. }
  200. }
  201. @media (max-width:760px) {
  202. /deep/ .white-box {
  203. padding: 0px 0px;
  204. }
  205. /deep/ .el-form-item__content {
  206. margin-left:150px !important;
  207. }
  208. /deep/ .el-form-item__label {
  209. width:150px !important;
  210. }
  211. /deep/ .el-input__inner {
  212. width: 150px;
  213. }
  214. /* .el-input {
  215. width: 90%;
  216. } */
  217. }
  218. </style>