80 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Vue
		
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Vue
		
	
	
| <script lang="ts" setup>
 | |
| import type {
 | |
|   OnActionClickParams,
 | |
|   VxeTableGridOptions,
 | |
| } from '#/adapter/vxe-table';
 | |
| import type { SystemSocialUserApi } from '#/api/system/social/user';
 | |
| 
 | |
| import { Page, useVbenModal } from '@vben/common-ui';
 | |
| 
 | |
| import { useVbenVxeGrid } from '#/adapter/vxe-table';
 | |
| import { getSocialUserPage } from '#/api/system/social/user';
 | |
| import { DocAlert } from '#/components/doc-alert';
 | |
| 
 | |
| import { useGridColumns, useGridFormSchema } from './data';
 | |
| import Detail from './modules/detail.vue';
 | |
| 
 | |
| const [DetailModal, detailModalApi] = useVbenModal({
 | |
|   connectedComponent: Detail,
 | |
|   destroyOnClose: true,
 | |
| });
 | |
| 
 | |
| /** 查看详情 */
 | |
| function onDetail(row: SystemSocialUserApi.SocialUser) {
 | |
|   detailModalApi.setData(row).open();
 | |
| }
 | |
| 
 | |
| /** 表格操作按钮的回调函数 */
 | |
| function onActionClick({
 | |
|   code,
 | |
|   row,
 | |
| }: OnActionClickParams<SystemSocialUserApi.SocialUser>) {
 | |
|   switch (code) {
 | |
|     case 'detail': {
 | |
|       onDetail(row);
 | |
|       break;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| const [Grid] = useVbenVxeGrid({
 | |
|   formOptions: {
 | |
|     schema: useGridFormSchema(),
 | |
|   },
 | |
|   gridOptions: {
 | |
|     columns: useGridColumns(onActionClick),
 | |
|     height: 'auto',
 | |
|     keepSource: true,
 | |
|     proxyConfig: {
 | |
|       ajax: {
 | |
|         query: async ({ page }, formValues) => {
 | |
|           return await getSocialUserPage({
 | |
|             pageNo: page.currentPage,
 | |
|             pageSize: page.pageSize,
 | |
|             ...formValues,
 | |
|           });
 | |
|         },
 | |
|       },
 | |
|     },
 | |
|     rowConfig: {
 | |
|       keyField: 'id',
 | |
|     },
 | |
|     toolbarConfig: {
 | |
|       refresh: { code: 'query' },
 | |
|       search: true,
 | |
|     },
 | |
|   } as VxeTableGridOptions<SystemSocialUserApi.SocialUser>,
 | |
| });
 | |
| </script>
 | |
| 
 | |
| <template>
 | |
|   <Page auto-content-height>
 | |
|     <template #doc>
 | |
|       <DocAlert title="三方登录" url="https://doc.iocoder.cn/social-user/" />
 | |
|     </template>
 | |
| 
 | |
|     <DetailModal />
 | |
|     <Grid table-title="社交用户列表" />
 | |
|   </Page>
 | |
| </template>
 |