change-balance-opt.vue 9.0 KB

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