change-balance-opt.vue 9.3 KB

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