index.vue 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204
  1. <template>
  2. <div>
  3. <BasicTable @register="registerTable">
  4. <template #bodyCell="{ column, record }">
  5. <template v-if="column.key === 'type'">
  6. <Tag :color="formatDictColor(typeOptions, record.type)">
  7. {{ formatDictValue(typeOptions, record.type) }}
  8. </Tag>
  9. </template>
  10. <template v-if="column.key === 'disable'">
  11. <Tag :color="formatDictColor(disableOptions, record.disable)">
  12. {{ commonDict(disableOptions, record.disable) }}
  13. </Tag>
  14. </template>
  15. <template v-if="column.key === 'action'">
  16. <TableAction
  17. :actions="[
  18. {
  19. auth: 'sms:channel:query',
  20. icon: 'icon-eye|iconfont',
  21. tooltip: '查看',
  22. label: '查看',
  23. onClick: handleView.bind(null, record),
  24. },
  25. {
  26. auth: 'sms:channel:edit',
  27. icon: 'icon-edit|iconfont',
  28. tooltip: '编辑',
  29. label: '编辑',
  30. onClick: handleEdit.bind(null, record),
  31. },
  32. {
  33. auth: 'sms:channel:remove',
  34. icon: 'icon-delete|iconfont',
  35. tooltip: '删除',
  36. label: '删除',
  37. color: 'error',
  38. popConfirm: {
  39. title: '是否确认删除',
  40. placement: 'left',
  41. confirm: handleDelete.bind(null, record),
  42. },
  43. },
  44. ]"
  45. />
  46. </template>
  47. </template>
  48. <template #toolbar>
  49. <Button
  50. v-auth="['sms:channel:add']"
  51. type="primary"
  52. @click="handleCreate"
  53. preIcon="icon-plus|iconfont"
  54. >
  55. 新增
  56. </Button>
  57. <Button
  58. v-auth="['sms:channel:remove']"
  59. type="primary"
  60. danger
  61. @click="handleDelete(null)"
  62. preIcon="icon-delete|iconfont"
  63. >
  64. 批量删除
  65. </Button>
  66. </template>
  67. </BasicTable>
  68. <FormDrawer @register="registerDrawer" @success="handleSuccess" />
  69. <ViewDrawer @register="registerDrawerView" @success="handleSuccess" />
  70. </div>
  71. </template>
  72. <script lang="ts" setup>
  73. import { onBeforeMount, ref } from 'vue';
  74. import { Tag } from 'ant-design-vue';
  75. import { Button } from '/@/components/Button';
  76. import { BasicTable, useTable, TableAction } from '/@/components/Table';
  77. // import { useModal } from '/@/components/Modal';
  78. import { useMessage } from '/@/hooks/web/useMessage';
  79. import FormDrawer from './formDrawer.vue';
  80. import ViewDrawer from './viewDrawer.vue';
  81. import { columns, searchFormSchema } from './data';
  82. import { smsChannelQueryPage, smsChannelRemove } from '/@/api/sys/smsChannelApi';
  83. import { listDictModel } from '/@/api/common';
  84. import { formatDictColor, formatDictValue, commonDict } from '/@/utils';
  85. import { useDrawer } from '/@/components/Drawer';
  86. const typeOptions = ref();
  87. const disableOptions = ref();
  88. onBeforeMount(async () => {
  89. typeOptions.value = await listDictModel({ dictCode: 'sys_sms_channel' });
  90. disableOptions.value = await listDictModel({ dictCode: 'sys_disable_type' });
  91. });
  92. const { createConfirm, createMessage } = useMessage();
  93. // const [registerModal, { openModal }] = useModal();
  94. const [registerDrawer, { openDrawer }] = useDrawer();
  95. const [registerDrawerView, { openDrawer: openDrawerView }] = useDrawer();
  96. const tableSort = ref([
  97. {
  98. field: 'create_time',
  99. direction: 'DESC',
  100. },
  101. ]) as any;
  102. const [registerTable, { reload, getSelectRowKeys }] = useTable({
  103. title: ' ',
  104. api: smsChannelQueryPage,
  105. rowKey: 'id',
  106. columns,
  107. showIndexColumn: true,
  108. rowSelection: { type: 'checkbox' },
  109. formConfig: {
  110. labelWidth: 120,
  111. schemas: searchFormSchema,
  112. autoSubmitOnEnter: true,
  113. baseColProps: { xs: 24, sm: 12, md: 12, lg: 8 },
  114. resetButtonOptions: {
  115. preIcon: 'icon-delete|iconfont',
  116. },
  117. submitButtonOptions: {
  118. preIcon: 'icon-search|iconfont',
  119. },
  120. },
  121. useSearchForm: true,
  122. bordered: true,
  123. actionColumn: {
  124. width: 200,
  125. title: '操作',
  126. dataIndex: 'action',
  127. },
  128. beforeFetch: handleBeforeFetch,
  129. sortFn: handleSortFn,
  130. });
  131. // 详情按钮事件
  132. function handleView(record: Recordable) {
  133. console.log(record);
  134. openDrawerView(true, {
  135. record,
  136. });
  137. }
  138. // 新增按钮事件
  139. function handleCreate() {
  140. openDrawer(true, {
  141. isUpdate: false,
  142. });
  143. }
  144. // 编辑按钮事件
  145. function handleEdit(record: Recordable) {
  146. openDrawer(true, {
  147. record,
  148. isUpdate: true,
  149. });
  150. }
  151. // 删除按钮事件
  152. async function handleDelete(record: Recordable) {
  153. if (record) {
  154. await smsChannelRemove([record.id]);
  155. createMessage.success('删除成功!');
  156. await reload();
  157. } else {
  158. createConfirm({
  159. content: '你确定要删除?',
  160. iconType: 'warning',
  161. onOk: async () => {
  162. const keys = getSelectRowKeys();
  163. await smsChannelRemove(keys);
  164. createMessage.success('删除成功!');
  165. await reload();
  166. },
  167. });
  168. }
  169. }
  170. // 表格点击字段排序
  171. function handleSortFn(sortInfo) {
  172. if (sortInfo?.order && sortInfo?.columnKey) {
  173. // 默认单列排序
  174. tableSort.value = [
  175. {
  176. field: sortInfo.columnKey,
  177. direction: sortInfo.order.replace(/(\w+)(end)/g, '$1').toUpperCase(),
  178. },
  179. ];
  180. }
  181. }
  182. // 表格请求之前,对参数进行处理, 添加默认 排序
  183. function handleBeforeFetch(params) {
  184. return { ...params, orders: tableSort.value };
  185. }
  186. // 弹窗回调事件
  187. async function handleSuccess({ isUpdate, values }) {
  188. console.log(isUpdate);
  189. console.log(values);
  190. await reload();
  191. }
  192. </script>