index.vue 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. <script setup lang="ts">
  2. import { useRole } from "./utils/hook";
  3. import { ref } from "vue";
  4. import { PureTableBar } from "@/components/RePureTableBar";
  5. import { useRenderIcon } from "@/components/ReIcon/src/hooks";
  6. import Delete from "~icons/ep/delete";
  7. import EditPen from "~icons/ep/edit-pen";
  8. import Refresh from "~icons/ep/refresh";
  9. import AddFill from "~icons/ri/add-circle-line";
  10. defineOptions({
  11. name: "SystemRole"
  12. });
  13. const formRef = ref();
  14. const tableRef = ref();
  15. const {
  16. form,
  17. loading,
  18. columns,
  19. dataList,
  20. pagination,
  21. onSearch,
  22. resetForm,
  23. openDialog,
  24. handleDelete,
  25. handleSizeChange,
  26. handleCurrentChange,
  27. handleSelectionChange
  28. } = useRole();
  29. </script>
  30. <template>
  31. <div class="main">
  32. <el-form
  33. ref="formRef"
  34. :inline="true"
  35. :model="form"
  36. class="search-form bg-bg_color w-full pl-8 pt-[12px] overflow-auto"
  37. >
  38. <el-form-item label="角色名称:" prop="name">
  39. <el-input
  40. v-model="form.name"
  41. placeholder="请输入角色名称"
  42. clearable
  43. class="w-[180px]!"
  44. />
  45. </el-form-item>
  46. <el-form-item label="角色标识:" prop="code">
  47. <el-input
  48. v-model="form.code"
  49. placeholder="请输入角色标识"
  50. clearable
  51. class="w-[180px]!"
  52. />
  53. </el-form-item>
  54. <el-form-item label="状态:" prop="status">
  55. <el-select
  56. v-model="form.status"
  57. placeholder="请选择状态"
  58. clearable
  59. class="w-[180px]!"
  60. >
  61. <el-option label="启用" :value="1" />
  62. <el-option label="停用" :value="0" />
  63. </el-select>
  64. </el-form-item>
  65. <el-form-item>
  66. <el-button
  67. type="primary"
  68. :icon="useRenderIcon('ri/search-line')"
  69. :loading="loading"
  70. @click="onSearch"
  71. >
  72. 搜索
  73. </el-button>
  74. <el-button :icon="useRenderIcon(Refresh)" @click="resetForm(formRef)">
  75. 重置
  76. </el-button>
  77. </el-form-item>
  78. </el-form>
  79. <PureTableBar
  80. title="角色管理"
  81. :columns="columns"
  82. @refresh="onSearch"
  83. >
  84. <template #buttons>
  85. <el-button
  86. type="primary"
  87. :icon="useRenderIcon(AddFill)"
  88. @click="openDialog()"
  89. >
  90. 新增角色
  91. </el-button>
  92. </template>
  93. <template v-slot="{ size, dynamicColumns }">
  94. <pure-table
  95. ref="tableRef"
  96. align-whole="center"
  97. showOverflowTooltip
  98. table-layout="auto"
  99. :loading="loading"
  100. :size="size"
  101. adaptive
  102. :adaptiveConfig="{ offsetBottom: 108 }"
  103. :data="dataList"
  104. :columns="dynamicColumns"
  105. :pagination="{ ...pagination, size }"
  106. :header-cell-style="{
  107. background: 'var(--el-fill-color-light)',
  108. color: 'var(--el-text-color-primary)'
  109. }"
  110. @selection-change="handleSelectionChange"
  111. @page-size-change="handleSizeChange"
  112. @page-current-change="handleCurrentChange"
  113. >
  114. <template #operation="{ row }">
  115. <el-button
  116. class="reset-margin"
  117. link
  118. type="primary"
  119. :size="size"
  120. :icon="useRenderIcon(EditPen)"
  121. @click="openDialog('修改', row)"
  122. >
  123. 修改
  124. </el-button>
  125. <el-popconfirm
  126. :title="`是否确认删除角色 ${row.name}?`"
  127. @confirm="handleDelete(row)"
  128. >
  129. <template #reference>
  130. <el-button
  131. class="reset-margin"
  132. link
  133. type="primary"
  134. :size="size"
  135. :icon="useRenderIcon(Delete)"
  136. >
  137. 删除
  138. </el-button>
  139. </template>
  140. </el-popconfirm>
  141. </template>
  142. </pure-table>
  143. </template>
  144. </PureTableBar>
  145. </div>
  146. </template>
  147. <style lang="scss" scoped>
  148. .main-content {
  149. margin: 24px 24px 0 !important;
  150. }
  151. .search-form {
  152. :deep(.el-form-item) {
  153. margin-bottom: 12px;
  154. }
  155. }
  156. </style>