index.vue 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  1. <template>
  2. <div class="app-container">
  3. <el-form :model="queryForm" inline size="small">
  4. <el-form-item label="名称">
  5. <el-input v-model="queryForm.name" placeholder="名称" />
  6. </el-form-item>
  7. <el-form-item label="类型">
  8. <el-select v-model="queryForm.categoryId" placeholder="请选择场所类型" clearable>
  9. <el-option v-for="item in listDataType" :key="item.id" :label="item.name" :value="item.id" />
  10. </el-select>
  11. </el-form-item>
  12. </el-form>
  13. <el-row class="action-bar-container" type="flex" justify="end">
  14. <el-button type="primary" size="small" @click.native="fetchData">查询</el-button>
  15. <el-button-group>
  16. <el-button size="small" @click.native="$refs.dialogForm.open({})">
  17. 新建
  18. </el-button>
  19. <el-button size="small" @click.native="deleteByIds(multipleSelection)">
  20. 删除
  21. </el-button>
  22. </el-button-group>
  23. </el-row>
  24. <el-table
  25. v-loading="isLoading"
  26. :data="pageData.records"
  27. border
  28. fit
  29. highlight-current-row
  30. @selection-change="selectionChange"
  31. >
  32. <el-table-column type="selection" width="55" />
  33. <el-table-column label="#" prop="id" width="150" />
  34. <el-table-column label="名称" prop="name" />
  35. <el-table-column label="地址" prop="address" />
  36. <el-table-column label="类型" prop="category.name" width="150" />
  37. <el-table-column label="操作" width="70" fixed="right">
  38. <template slot-scope="scope">
  39. <el-button type="text" @click.native="$refs.dialogForm.open(scope.row)">编辑</el-button>
  40. </template>
  41. </el-table-column>
  42. </el-table>
  43. <el-pagination
  44. class="pagination-container"
  45. background
  46. layout="prev, pager, next"
  47. :total="pageData.total"
  48. :page-size="pageData.pageSize"
  49. @current-change="paginationChange"
  50. />
  51. <dialog-form ref="dialogForm" @ok="fetchData" />
  52. </div>
  53. </template>
  54. <script>
  55. import { findAllDataType } from '@/api/place/base_info'
  56. import { deleteMediaByIds, findMediaPage } from '@/api/bz'
  57. import DialogForm from './DialogForm'
  58. export default {
  59. components: {
  60. DialogForm
  61. },
  62. data() {
  63. return {
  64. isLoading: true,
  65. queryForm: {},
  66. pageData: {},
  67. listDataType: [],
  68. multipleSelection: []
  69. }
  70. },
  71. computed: {},
  72. created() {
  73. },
  74. mounted() {
  75. this.fetchData()
  76. findAllDataType().then(listDataType => {
  77. this.listDataType = listDataType
  78. })
  79. },
  80. methods: {
  81. deleteByIds(ids) {
  82. this.$confirm('确认要删除吗?', '提示', {
  83. confirmButtonText: '确定',
  84. cancelButtonText: '取消',
  85. type: 'warning'
  86. }).then(() => {
  87. deleteMediaByIds(ids).then(() => {
  88. this.fetchData()
  89. })
  90. })
  91. },
  92. fetchData() {
  93. this.isLoading = true
  94. findMediaPage({ ...this.queryForm, current: this.currentPage })
  95. .then((response) => {
  96. this.pageData = response
  97. })
  98. .finally(() => (this.isLoading = false))
  99. },
  100. paginationChange(val) {
  101. this.currentPage = val
  102. this.fetchData()
  103. },
  104. selectionChange(val) {
  105. const temp = []
  106. val.forEach(o => {
  107. temp.push(o.id)
  108. })
  109. this.multipleSelection = temp
  110. }
  111. }
  112. }
  113. </script>