index.vue 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. <template>
  2. <div>
  3. <Search :search="search" :reset="reset">
  4. <template v-slot:body>
  5. <el-form-item label="岗位名称" prop="job_name">
  6. <el-input v-model="query.job_name" name="job_name" clearable />
  7. </el-form-item>
  8. </template>
  9. </Search>
  10. <div class="table-default">
  11. <Operate :show="open" />
  12. <el-table :data="tableData" class="mt-3" v-loading="loading">
  13. <el-table-column prop="job_name" label="岗位名称" />
  14. <el-table-column prop="coding" label="岗位编码" />
  15. <el-table-column prop="status" label="状态">
  16. <template #default="scope">
  17. <Status v-model="scope.row.status" :id="scope.row.id" :api="api" />
  18. </template>
  19. </el-table-column>
  20. <el-table-column prop="sort" label="排序" />
  21. <el-table-column prop="description" label="岗位描述" />
  22. <el-table-column label="操作" width="200">
  23. <template #default="scope">
  24. <Update @click="open(scope.row.id)" />
  25. <Destroy @click="destroy(api, scope.row.id)" />
  26. </template>
  27. </el-table-column>
  28. </el-table>
  29. <Paginate />
  30. </div>
  31. <Dialog v-model="visible" :title="title" destroy-on-close>
  32. <Create @close="close(reset)" :primary="id" :api="api" />
  33. </Dialog>
  34. </div>
  35. </template>
  36. <script lang="ts" setup>
  37. import {computed, onMounted} from 'vue'
  38. import Create from './form/create.vue'
  39. import {useGetList} from '/admin/composables/curd/useGetList'
  40. import {useDestroy} from '/admin/composables/curd/useDestroy'
  41. import {useOpen} from '/admin/composables/curd/useOpen'
  42. const api = 'permissions/jobs'
  43. const { data, query, search, reset, loading } = useGetList(api)
  44. const { destroy, deleted } = useDestroy()
  45. const tableData = computed(() => data.value?.data)
  46. const { open, close, title, visible, id } = useOpen()
  47. onMounted(() => {
  48. search()
  49. deleted(reset)
  50. })
  51. </script>