balanceA.vue 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302
  1. <template>
  2. <div>
  3. <el-alert class="diy-tip" @close="tips_close" v-show="tips_show" type="success" description>
  4. <p>A分余额在线下兑换/使用过后,由管理员手动结算清零;</p>
  5. <p>清零操作为全员批量清除,请谨慎操作。此操作不会清空A分统计、排名和事件!</p>
  6. <p>每次清零将清空指定月份之前的余额(不含指定月份),不可清空未结束月份的余额:</p>
  7. <p>例如当前是2020年7月8号,指定选择2020年7月份,可清空2020年7月1号之前所有余额,不清除7月1-8号的余额。</p>
  8. </el-alert>
  9. <div class="box boxMinHeight">
  10. <el-tabs v-model="active">
  11. <el-tab-pane :disabled="loading" label="A分余额" name="balanceA"></el-tab-pane>
  12. <el-tab-pane :disabled="loading" label="清空记录" name="clearLog"></el-tab-pane>
  13. </el-tabs>
  14. <el-form :inline="true" v-if="active == 'balanceA'">
  15. <el-form-item label="部门">
  16. <el-cascader
  17. size="medium"
  18. class="date-picker-width"
  19. v-model="dept_name"
  20. :options="dept_tree"
  21. ref="dept"
  22. :props="{ checkStrictly: true, value: 'id', label: 'name', children: '_child' }"
  23. clearable
  24. filterable
  25. placeholder="全公司"
  26. ></el-cascader>
  27. </el-form-item>
  28. <el-form-item>
  29. <el-input size="medium" v-model="formData.keyword" placeholder="输入同事姓名" max="200" @keyup.enter.native="getList()" class="persons_name">
  30. <el-button size="medium" slot="append" icon="el-icon-search" @click="getList()"></el-button>
  31. </el-input>
  32. </el-form-item>
  33. <el-form-item style="float: right;"><el-button size="medium" type="primary" @click="clearAPointShow = true">清空A分余额</el-button></el-form-item>
  34. </el-form>
  35. <el-table :data="list" style="width: 100%" v-if="active == 'balanceA'" v-loading="loading">
  36. <el-table-column label="姓名" prop="name" width="250">
  37. <template slot-scope="scope">
  38. <div class="flex-box-ce">
  39. <userImage class="fl" :id="scope.row.id" :user_name="scope.row.name" :img_url="scope.row.img_url" width="50px" height="50px"></userImage>
  40. <span style="line-height: 50px; padding-left: 10px;">{{ scope.row.name }}</span>
  41. </div>
  42. </template>
  43. </el-table-column>
  44. <el-table-column show-overflow-tooltip label="部门" align="left" min-width="120px" prop="deptName"></el-table-column>
  45. <el-table-column label="A分余额" prop="balance_a"></el-table-column>
  46. <template slot="empty">
  47. <noData></noData>
  48. </template>
  49. </el-table>
  50. <el-table :data="list" style="width: 100%" v-else v-loading="loading">
  51. <el-table-column label="操作人" prop="name" width="250">
  52. <template slot-scope="scope">
  53. <div class="flex-box-ce">
  54. <userImage class="fl" :id="scope.row.id" :user_name="scope.row.name" :img_url="scope.row.img_url" width="50px" height="50px"></userImage>
  55. <span style="line-height: 50px; padding-left: 10px;">{{ scope.row.name }}</span>
  56. </div>
  57. </template>
  58. </el-table-column>
  59. <el-table-column label="内容" prop="remark"></el-table-column>
  60. <el-table-column prop="create_time" label="时间"></el-table-column>
  61. <template slot="empty">
  62. <noData></noData>
  63. </template>
  64. </el-table>
  65. <center style="padding: 20px 0;">
  66. <el-pagination
  67. background
  68. @size-change="handleSizeChange"
  69. @current-change="handleCurrentChange"
  70. :page-sizes="[10, 20, 50, 100]"
  71. layout="total, sizes, prev, pager, next"
  72. :page-size="formData.page_size"
  73. :current-page="formData.page"
  74. :total="total"
  75. ></el-pagination>
  76. </center>
  77. <el-dialog title="清空A分余额" :visible.sync="clearAPointShow" width="500px" @close="clearAPointClose('popupForm')">
  78. <el-form :model="popupForm" ref="popupForm">
  79. <el-form-item prop="month" :rules="[{ required: true, message: '请选择月份', trigger: 'blur' }]">
  80. <el-col :span="3">清空</el-col>
  81. <el-col :span="8">
  82. <el-date-picker style="width: 100%" v-model="popupForm.month" value-format="yyyy-MM" type="month" placeholder="请选择月份"></el-date-picker>
  83. </el-col>
  84. <el-col :span="6">之前的A分</el-col>
  85. </el-form-item>
  86. </el-form>
  87. <span slot="footer">
  88. <el-button @click="resetForm('popupForm')">取 消</el-button>
  89. <el-button type="primary" @click="onSubmit('popupForm')">确 定</el-button>
  90. </span>
  91. </el-dialog>
  92. </div>
  93. </div>
  94. </template>
  95. <script>
  96. export default {
  97. data() {
  98. return {
  99. active: 'balanceA',
  100. loading: false,
  101. tips_show: false,
  102. clearAPointShow: false,
  103. list: null,
  104. total: null,
  105. dept_name: '',
  106. formData: {
  107. keyword: '',
  108. dept_id: '0',
  109. page: 1,
  110. page_size: 10
  111. },
  112. dept_tree: null,
  113. popupForm: {
  114. month: ''
  115. }
  116. };
  117. },
  118. watch: {
  119. dept_name(val) {
  120. this.formData.dept_id = val[val.length - 1];
  121. this.$refs.dept.dropDownVisible = false;
  122. this.getList();
  123. },
  124. active(val) {
  125. this.list = [];
  126. this.formData = {
  127. keyword: '',
  128. dept_id: '0',
  129. page: 1,
  130. page_size: 10
  131. };
  132. val == 'balanceA' ? this.getList() : this.getLog();
  133. }
  134. },
  135. methods: {
  136. resetForm(formName) {
  137. this.clearAPointShow = false;
  138. this.$refs[formName].resetFields();
  139. },
  140. // 清空数据
  141. onSubmit(formName) {
  142. this.$refs[formName].validate(valid => {
  143. if (valid) {
  144. this.$axios('post', '/api/integral/site/a/clear', this.popupForm)
  145. .then(res => {
  146. if (res.data.code == 1) {
  147. this.$message.success('清除成功');
  148. this.resetForm(formName);
  149. this.getList();
  150. this.clearAPointShow = false;
  151. } else {
  152. this.$message.error(res.data.data.msg);
  153. }
  154. })
  155. .finally(() => {
  156. this.loading = false;
  157. });
  158. }
  159. });
  160. },
  161. // 关闭弹窗
  162. clearAPointClose(formName) {
  163. this.$refs[formName].resetFields();
  164. },
  165. // 提示信息
  166. tips_close() {
  167. this.$setCache('balanceA_tips', 'true');
  168. this.tips_show = false;
  169. },
  170. // 页码变更
  171. handleCurrentChange(val) {
  172. this.formData.page = val;
  173. this.active == 'balanceA' ? this.getList() : this.getLog();
  174. },
  175. handleSizeChange(val) {
  176. this.formData.page_size = val;
  177. this.active == 'balanceA' ? this.getList() : this.getLog();
  178. },
  179. // 获取列表
  180. getList() {
  181. this.loading = true;
  182. this.$axios('get', '/api/integral/site/a/balance', this.formData)
  183. .then(res => {
  184. if (res.data.code == 1) {
  185. this.list = this.$returnDeptName(res.data.data.list);
  186. this.total = res.data.data.total;
  187. } else {
  188. this.$message.error(res.data.data.msg);
  189. }
  190. })
  191. .finally(() => {
  192. this.loading = false;
  193. });
  194. },
  195. // 获取日志列表
  196. getLog() {
  197. let self = this;
  198. self.loading = true;
  199. let data = {
  200. page: this.formData.page,
  201. page_size: this.formData.page_size
  202. };
  203. self.$axios('get', '/api/integral/site/a/logs', data)
  204. .then(res => {
  205. if (res.data.code == 1) {
  206. self.list = res.data.data.list;
  207. self.total = res.data.data.total;
  208. } else {
  209. self.$message.error(res.data.data.msg);
  210. }
  211. })
  212. .finally(() => {
  213. self.loading = false;
  214. });
  215. },
  216. // 递归判断列表,把最后的children设为undefined
  217. getTreeData(data) {
  218. for (var i = 0; i < data.length; i++) {
  219. if (data[i]._child.length < 1) {
  220. // children若为空数组,则将children设为undefined
  221. data[i]._child = undefined;
  222. } else {
  223. // children若不为空数组,则继续 递归调用 本方法
  224. this.getTreeData(data[i]._child);
  225. }
  226. }
  227. return data;
  228. },
  229. //获取部门
  230. getDepartment() {
  231. this.$axios('get', '/api/department/tree').then(res => {
  232. this.dept_tree = this.getTreeData(res.data.data.list);
  233. });
  234. }
  235. },
  236. created() {
  237. this.getDepartment();
  238. },
  239. mounted() {
  240. if (this.$getCache('balanceA_tips')) {
  241. this.tips_show = false;
  242. } else {
  243. this.tips_show = true;
  244. }
  245. this.getList();
  246. }
  247. };
  248. </script>
  249. <style scoped lang="scss">
  250. .box {
  251. background-color: #ffffff;
  252. padding: 20px;
  253. }
  254. .listData {
  255. position: relative;
  256. display: table-cell;
  257. margin: 0 !important;
  258. padding: 20px;
  259. min-height: 600px;
  260. &::after {
  261. content: ' ';
  262. position: absolute;
  263. top: 0;
  264. left: 0;
  265. bottom: 0;
  266. width: 1px;
  267. background: #ebeef5;
  268. }
  269. & .groups_name {
  270. display: block;
  271. font-size: 20px;
  272. color: rgb(48, 49, 51);
  273. vertical-align: middle;
  274. }
  275. }
  276. ::v-deep .el-menu-item {
  277. overflow: hidden;
  278. white-space: nowrap;
  279. text-overflow: ellipsis;
  280. &.is-active {
  281. background-color: #ecf5ff;
  282. }
  283. }
  284. .diy-tip {
  285. margin-bottom: 15px;
  286. border: 1px solid #67c23a;
  287. padding: 20px 16px;
  288. p {
  289. color: #67c23a !important;
  290. font-size: 14px;
  291. margin: 0 !important;
  292. padding: 4px 0;
  293. }
  294. }
  295. </style>