Merge branch 'develop'

This commit is contained in:
kailong321200875 2022-08-13 09:34:19 +08:00
commit 996f220194
25 changed files with 206 additions and 230 deletions

View File

@ -27,80 +27,80 @@
}, },
"dependencies": { "dependencies": {
"@iconify/iconify": "^2.2.1", "@iconify/iconify": "^2.2.1",
"@vueuse/core": "^9.0.2", "@vueuse/core": "^9.1.0",
"@wangeditor/editor": "^5.1.14", "@wangeditor/editor": "^5.1.14",
"@wangeditor/editor-for-vue": "^5.1.10", "@wangeditor/editor-for-vue": "^5.1.10",
"@zxcvbn-ts/core": "^2.0.3", "@zxcvbn-ts/core": "^2.0.4",
"animate.css": "^4.1.1", "animate.css": "^4.1.1",
"axios": "^0.27.2", "axios": "^0.27.2",
"echarts": "^5.3.3", "echarts": "^5.3.3",
"echarts-wordcloud": "^2.0.0", "echarts-wordcloud": "^2.0.0",
"element-plus": "2.2.11", "element-plus": "2.2.13",
"intro.js": "^6.0.0", "intro.js": "^6.0.0",
"lodash-es": "^4.17.21", "lodash-es": "^4.17.21",
"mitt": "^3.0.0", "mitt": "^3.0.0",
"mockjs": "^1.1.0", "mockjs": "^1.1.0",
"nprogress": "^0.2.0", "nprogress": "^0.2.0",
"pinia": "^2.0.17", "pinia": "^2.0.18",
"pinia-plugin-persist": "^1.0.0", "pinia-plugin-persist": "^1.0.0",
"qrcode": "^1.5.1", "qrcode": "^1.5.1",
"qs": "^6.11.0", "qs": "^6.11.0",
"url": "^0.11.0", "url": "^0.11.0",
"vue": "3.2.37", "vue": "3.2.37",
"vue-i18n": "9.1.10", "vue-i18n": "9.2.2",
"vue-router": "^4.1.3", "vue-router": "^4.1.3",
"vue-types": "^4.2.0", "vue-types": "^4.2.1",
"web-storage-cache": "^1.1.1" "web-storage-cache": "^1.1.1"
}, },
"devDependencies": { "devDependencies": {
"@commitlint/cli": "^17.0.3", "@commitlint/cli": "^17.0.3",
"@commitlint/config-conventional": "^17.0.3", "@commitlint/config-conventional": "^17.0.3",
"@iconify/json": "^2.1.85", "@iconify/json": "^2.1.91",
"@intlify/vite-plugin-vue-i18n": "^5.0.1", "@intlify/vite-plugin-vue-i18n": "^6.0.1",
"@purge-icons/generated": "^0.8.1", "@purge-icons/generated": "^0.9.0",
"@types/intro.js": "^5.1.0", "@types/intro.js": "^5.1.0",
"@types/lodash-es": "^4.17.6", "@types/lodash-es": "^4.17.6",
"@types/node": "^18.6.2", "@types/node": "^18.7.2",
"@types/nprogress": "^0.2.0", "@types/nprogress": "^0.2.0",
"@types/qrcode": "^1.4.2", "@types/qrcode": "^1.4.2",
"@types/qs": "^6.9.7", "@types/qs": "^6.9.7",
"@typescript-eslint/eslint-plugin": "^5.31.0", "@typescript-eslint/eslint-plugin": "^5.33.0",
"@typescript-eslint/parser": "^5.31.0", "@typescript-eslint/parser": "^5.33.0",
"@vitejs/plugin-vue": "^3.0.1", "@vitejs/plugin-vue": "^3.0.3",
"@vitejs/plugin-vue-jsx": "^2.0.0", "@vitejs/plugin-vue-jsx": "^2.0.0",
"autoprefixer": "^10.4.8", "autoprefixer": "^10.4.8",
"eslint": "^8.20.0", "eslint": "^8.21.0",
"eslint-config-prettier": "^8.5.0", "eslint-config-prettier": "^8.5.0",
"eslint-define-config": "^1.5.1", "eslint-define-config": "^1.6.0",
"eslint-plugin-prettier": "^4.2.1", "eslint-plugin-prettier": "^4.2.1",
"eslint-plugin-vue": "^9.3.0", "eslint-plugin-vue": "^9.3.0",
"husky": "^8.0.1", "husky": "^8.0.1",
"less": "^4.1.3", "less": "^4.1.3",
"lint-staged": "^13.0.3", "lint-staged": "^13.0.3",
"plop": "^3.1.1", "plop": "^3.1.1",
"postcss": "^8.4.14", "postcss": "^8.4.16",
"postcss-html": "^1.5.0", "postcss-html": "^1.5.0",
"postcss-less": "^6.0.0", "postcss-less": "^6.0.0",
"prettier": "^2.7.1", "prettier": "^2.7.1",
"rimraf": "^3.0.2", "rimraf": "^3.0.2",
"rollup": "^2.77.2", "rollup": "^2.77.3",
"stylelint": "^14.9.1", "stylelint": "^14.10.0",
"stylelint-config-html": "^1.1.0", "stylelint-config-html": "^1.1.0",
"stylelint-config-prettier": "^9.0.3", "stylelint-config-prettier": "^9.0.3",
"stylelint-config-recommended": "^8.0.0", "stylelint-config-recommended": "^9.0.0",
"stylelint-config-standard": "^26.0.0", "stylelint-config-standard": "^27.0.0",
"stylelint-order": "^5.0.0", "stylelint-order": "^5.0.0",
"typescript": "4.7.4", "typescript": "4.7.4",
"unplugin-vue-define-options": "^0.6.2", "unplugin-vue-macros": "^0.8.3",
"vite": "3.0.4", "vite": "3.0.7",
"vite-plugin-eslint": "^1.7.0", "vite-plugin-eslint": "^1.8.0",
"vite-plugin-html": "^3.2.0", "vite-plugin-html": "^3.2.0",
"vite-plugin-mock": "^2.9.6", "vite-plugin-mock": "^2.9.6",
"vite-plugin-purge-icons": "^0.8.2", "vite-plugin-purge-icons": "^0.9.0",
"vite-plugin-style-import": "1.4.1", "vite-plugin-style-import": "2.0.0",
"vite-plugin-svg-icons": "^2.0.1", "vite-plugin-svg-icons": "^2.0.1",
"vite-plugin-windicss": "^1.8.7", "vite-plugin-windicss": "^1.8.7",
"vue-tsc": "^0.39.2", "vue-tsc": "^0.40.1",
"windicss": "^3.5.6", "windicss": "^3.5.6",
"windicss-analysis": "^0.3.5" "windicss-analysis": "^0.3.5"
}, },

View File

@ -1,15 +1,11 @@
import { useAxios } from '@/hooks/web/useAxios' import request from '@/config/axios'
const request = useAxios()
// 获取所有字典 // 获取所有字典
export const getDictApi = async (): Promise<IResponse> => { export const getDictApi = (): Promise<IResponse> => {
const res = await request.get({ url: '/dict/list' }) return request.get({ url: '/dict/list' })
return res && res.data
} }
// 模拟获取某个字典 // 模拟获取某个字典
export const getDictOneApi = async (): Promise<IResponse> => { export const getDictOneApi = async (): Promise<IResponse> => {
const res = await request.get({ url: '/dict/one' }) return request.get({ url: '/dict/one' })
return res && res.data
} }

View File

@ -1,4 +1,4 @@
import { useAxios } from '@/hooks/web/useAxios' import request from '@/config/axios'
import type { import type {
AnalysisTotalTypes, AnalysisTotalTypes,
UserAccessSource, UserAccessSource,
@ -6,24 +6,18 @@ import type {
MonthlySales MonthlySales
} from './types' } from './types'
const request = useAxios() export const getCountApi = (): Promise<IResponse<AnalysisTotalTypes[]>> => {
return request.get({ url: '/analysis/total' })
export const getCountApi = async (): Promise<IResponse<AnalysisTotalTypes[]>> => {
const res = await request.get({ url: '/analysis/total' })
return res && res.data
} }
export const getUserAccessSourceApi = async (): Promise<IResponse<UserAccessSource[]>> => { export const getUserAccessSourceApi = (): Promise<IResponse<UserAccessSource[]>> => {
const res = await request.get({ url: '/analysis/userAccessSource' }) return request.get({ url: '/analysis/userAccessSource' })
return res && res.data
} }
export const getWeeklyUserActivityApi = async (): Promise<IResponse<WeeklyUserActivity[]>> => { export const getWeeklyUserActivityApi = (): Promise<IResponse<WeeklyUserActivity[]>> => {
const res = await request.get({ url: '/analysis/weeklyUserActivity' }) return request.get({ url: '/analysis/weeklyUserActivity' })
return res && res.data
} }
export const getMonthlySalesApi = async (): Promise<IResponse<MonthlySales[]>> => { export const getMonthlySalesApi = (): Promise<IResponse<MonthlySales[]>> => {
const res = await request.get({ url: '/analysis/monthlySales' }) return request.get({ url: '/analysis/monthlySales' })
return res && res.data
} }

View File

@ -1,29 +1,22 @@
import { useAxios } from '@/hooks/web/useAxios' import request from '@/config/axios'
import type { WorkplaceTotal, Project, Dynamic, Team, RadarData } from './types' import type { WorkplaceTotal, Project, Dynamic, Team, RadarData } from './types'
const request = useAxios() export const getCountApi = (): Promise<IResponse<WorkplaceTotal>> => {
return request.get({ url: '/workplace/total' })
export const getCountApi = async (): Promise<IResponse<WorkplaceTotal>> => {
const res = await request.get({ url: '/workplace/total' })
return res && res.data
} }
export const getProjectApi = async (): Promise<IResponse<Project>> => { export const getProjectApi = (): Promise<IResponse<Project>> => {
const res = await request.get({ url: '/workplace/project' }) return request.get({ url: '/workplace/project' })
return res && res.data
} }
export const getDynamicApi = async (): Promise<IResponse<Dynamic[]>> => { export const getDynamicApi = (): Promise<IResponse<Dynamic[]>> => {
const res = await request.get({ url: '/workplace/dynamic' }) return request.get({ url: '/workplace/dynamic' })
return res && res.data
} }
export const getTeamApi = async (): Promise<IResponse<Team[]>> => { export const getTeamApi = (): Promise<IResponse<Team[]>> => {
const res = await request.get({ url: '/workplace/team' }) return request.get({ url: '/workplace/team' })
return res && res.data
} }
export const getRadarApi = async (): Promise<IResponse<RadarData[]>> => { export const getRadarApi = (): Promise<IResponse<RadarData[]>> => {
const res = await request.get({ url: '/workplace/radar' }) return request.get({ url: '/workplace/radar' })
return res && res.data
} }

View File

@ -1,20 +1,16 @@
import { useAxios } from '@/hooks/web/useAxios' import request from '@/config/axios'
import type { UserType } from './types' import type { UserType } from './types'
interface RoleParams { interface RoleParams {
roleName: string roleName: string
} }
const request = useAxios() export const loginApi = (data: UserType): Promise<IResponse<UserType>> => {
return request.post({ url: '/user/login', data })
export const loginApi = async (data: UserType): Promise<IResponse<UserType>> => {
const res = await request.post({ url: '/user/login', data })
return res && res.data
} }
export const loginOutApi = async (): Promise<IResponse> => { export const loginOutApi = (): Promise<IResponse> => {
const res = await request.get({ url: '/user/loginOut' }) return request.get({ url: '/user/loginOut' })
return res && res.data
} }
export const getUserListApi = ({ params }: AxiosConfig) => { export const getUserListApi = ({ params }: AxiosConfig) => {
@ -24,14 +20,12 @@ export const getUserListApi = ({ params }: AxiosConfig) => {
}>({ url: '/user/list', params }) }>({ url: '/user/list', params })
} }
export const getAdminRoleApi = async ( export const getAdminRoleApi = (
params: RoleParams params: RoleParams
): Promise<IResponse<AppCustomRouteRecordRaw[]>> => { ): Promise<IResponse<AppCustomRouteRecordRaw[]>> => {
const res = await request.get({ url: '/role/list', params }) return request.get({ url: '/role/list', params })
return res && res.data
} }
export const getTestRoleApi = async (params: RoleParams): Promise<IResponse<string[]>> => { export const getTestRoleApi = (params: RoleParams): Promise<IResponse<string[]>> => {
const res = await request.get({ url: '/role/list', params }) return request.get({ url: '/role/list', params })
return res && res.data
} }

View File

@ -1,24 +1,18 @@
import { useAxios } from '@/hooks/web/useAxios' import request from '@/config/axios'
import type { TableData } from './types' import type { TableData } from './types'
const request = useAxios() export const getTableListApi = (params: any): Promise<IResponse> => {
return request.get({ url: '/example/list', params })
export const getTableListApi = async (params: any): Promise<IResponse> => {
const res = await request.get({ url: '/example/list', params })
return res && res.data
} }
export const saveTableApi = async (data: Partial<TableData>): Promise<IResponse> => { export const saveTableApi = (data: Partial<TableData>): Promise<IResponse> => {
const res = await request.post({ url: '/example/save', data }) return request.post({ url: '/example/save', data })
return res && res.data
} }
export const getTableDetApi = async (id: string): Promise<IResponse<TableData>> => { export const getTableDetApi = (id: string): Promise<IResponse<TableData>> => {
const res = await request.get({ url: '/example/detail', params: { id } }) return request.get({ url: '/example/detail', params: { id } })
return res && res.data
} }
export const delTableListApi = async (ids: string[] | number[]): Promise<IResponse> => { export const delTableListApi = (ids: string[] | number[]): Promise<IResponse> => {
const res = await request.post({ url: '/example/delete', data: { ids } }) return request.post({ url: '/example/delete', data: { ids } })
return res && res.data
} }

View File

@ -15,7 +15,7 @@ const title = computed(() => appStore.getTitle)
<template> <template>
<div <div
:class="prefixCls" :class="prefixCls"
class="text-center text-[var(--el-text-color-placeholder)] bg-[var(--app-contnet-bg-color)] h-[var(--app-footer-height)] leading-[var(--app-footer-height)] dark:bg-[var(--el-bg-color)]" class="text-center text-[var(--el-text-color-placeholder)] bg-[var(--app-content-bg-color)] h-[var(--app-footer-height)] leading-[var(--app-footer-height)] dark:bg-[var(--el-bg-color)]"
> >
Copyright ©2021-present {{ title }} Copyright ©2021-present {{ title }}
</div> </div>

View File

@ -1,9 +1,11 @@
import Table from './src/Table.vue' import Table from './src/Table.vue'
import { ElTable } from 'element-plus'
export interface TableExpose { export interface TableExpose {
setProps: (props: Recordable) => void setProps: (props: Recordable) => void
setColumn: (columnProps: TableSetPropsType[]) => void setColumn: (columnProps: TableSetPropsType[]) => void
selections: Recordable[] selections: Recordable[]
elTableRef: ComponentRef<typeof ElTable>
} }
export { Table } export { Table }

View File

@ -99,7 +99,8 @@ export default defineComponent({
expose({ expose({
setProps, setProps,
setColumn, setColumn,
selections selections,
elTableRef
}) })
const pagination = computed(() => { const pagination = computed(() => {

View File

@ -1,69 +1,33 @@
import axios, { AxiosInstance, AxiosRequestConfig, AxiosResponse, AxiosError } from 'axios' import { service } from './service'
import { ElMessage } from 'element-plus' import { config } from './config'
import qs from 'qs' const { default_headers } = config
import { config } from '@/config/axios/config' const request = (option: any) => {
const { url, method, params, data, headersType, responseType } = option
const { result_code, base_url } = config return service({
url: url,
export const PATH_URL = base_url[import.meta.env.VITE_API_BASEPATH] method,
params,
// 创建axios实例 data,
const service: AxiosInstance = axios.create({ responseType: responseType,
baseURL: PATH_URL, // api 的 base_url headers: {
timeout: config.request_timeout // 请求超时时间 'Content-Type': headersType || default_headers
})
// request拦截器
service.interceptors.request.use(
(config: AxiosRequestConfig) => {
if (
config.method === 'post' &&
config!.headers!['Content-Type'] === 'application/x-www-form-urlencoded'
) {
config.data = qs.stringify(config.data)
} }
// 添加token可根据实际业务修改 })
// config!.headers!['Authorization'] = 'something' }
// get参数编码 export default {
if (config.method === 'get' && config.params) { get: <T = any>(option: any) => {
let url = config.url as string return request({ method: 'get', ...option }) as unknown as T
url += '?'
const keys = Object.keys(config.params)
for (const key of keys) {
if (config.params[key] !== void 0 && config.params[key] !== null) {
url += `${key}=${encodeURIComponent(config.params[key])}&`
}
}
url = url.substring(0, url.length - 1)
config.params = {}
config.url = url
}
return config
}, },
(error: AxiosError) => { post: <T = any>(option: any) => {
// Do something with request error return request({ method: 'post', ...option }) as unknown as T
console.log(error) // for debug
Promise.reject(error)
}
)
// response 拦截器
service.interceptors.response.use(
(response: AxiosResponse<Recordable>) => {
if (response.data.code === result_code) {
return response
} else {
ElMessage.error(response.data.message)
}
}, },
(error: AxiosError) => { delete: <T = any>(option: any) => {
console.log('err' + error) // for debug return request({ method: 'delete', ...option }) as unknown as T
ElMessage.error(error.message) },
return Promise.reject(error) put: <T = any>(option: any) => {
return request({ method: 'put', ...option }) as unknown as T
} }
) }
export { service }

View File

@ -0,0 +1,70 @@
import axios, { AxiosInstance, AxiosRequestConfig, AxiosResponse, AxiosError } from 'axios'
import qs from 'qs'
import { config } from './config'
import { ElMessage } from 'element-plus'
const { result_code, base_url } = config
export const PATH_URL = base_url[import.meta.env.VITE_API_BASEPATH]
// 创建axios实例
const service: AxiosInstance = axios.create({
baseURL: PATH_URL, // api 的 base_url
timeout: config.request_timeout // 请求超时时间
})
// request拦截器
service.interceptors.request.use(
(config: AxiosRequestConfig) => {
if (
config.method === 'post' &&
(config.headers as any)['Content-Type'] === 'application/x-www-form-urlencoded'
) {
config.data = qs.stringify(config.data)
}
// get参数编码
if (config.method === 'get' && config.params) {
let url = config.url as string
url += '?'
const keys = Object.keys(config.params)
for (const key of keys) {
if (config.params[key] !== void 0 && config.params[key] !== null) {
url += `${key}=${encodeURIComponent(config.params[key])}&`
}
}
url = url.substring(0, url.length - 1)
config.params = {}
config.url = url
}
return config
},
(error: AxiosError) => {
// Do something with request error
console.log(error) // for debug
Promise.reject(error)
}
)
// response 拦截器
service.interceptors.response.use(
(response: AxiosResponse<any>) => {
if (response.config.responseType === 'blob') {
// 如果是文件流,直接过
return response
} else if (response.data.code === result_code) {
return response.data
} else {
ElMessage.error(response.data.message)
}
},
(error: AxiosError) => {
console.log('err' + error) // for debug
ElMessage.error(error.message)
return Promise.reject(error)
}
)
export { service }

View File

@ -1,46 +0,0 @@
import { service } from '@/config/axios'
import { AxiosPromise } from 'axios'
import { config } from '@/config/axios/config'
const { default_headers } = config
const request = (option: AxiosConfig) => {
const { url, method, params, data, headersType, responseType } = option
return service({
url: url,
method,
params,
data,
responseType: responseType,
headers: {
'Content-Type': headersType || default_headers
}
})
}
function getFn<T = any>(option: AxiosConfig): AxiosPromise<T> {
return request({ method: 'get', ...option })
}
function postFn<T = any>(option: AxiosConfig): AxiosPromise<T> {
return request({ method: 'post', ...option })
}
function deleteFn<T = any>(option: AxiosConfig): AxiosPromise<T> {
return request({ method: 'delete', ...option })
}
function putFn<T = any>(option: AxiosConfig): AxiosPromise<T> {
return request({ method: 'put', ...option })
}
export const useAxios = () => {
return {
get: getFn,
post: postFn,
delete: deleteFn,
put: putFn
}
}

View File

@ -41,7 +41,7 @@ export const useI18n = (
const tFn: I18nGlobalTranslation = (key: string, ...arg: any[]) => { const tFn: I18nGlobalTranslation = (key: string, ...arg: any[]) => {
if (!key) return '' if (!key) return ''
if (!key.includes('.') && !namespace) return key if (!key.includes('.') && !namespace) return key
return t(getKey(namespace, key), ...(arg as I18nTranslationRestParameters)) return (t as any)(getKey(namespace, key), ...(arg as I18nTranslationRestParameters))
} }
return { return {
...methods, ...methods,

View File

@ -89,7 +89,7 @@ export const useTable = <T = any>(config?: UseTableConfig<T>) => {
const register = (ref: typeof Table & TableExpose, elRef: ComponentRef<typeof ElTable>) => { const register = (ref: typeof Table & TableExpose, elRef: ComponentRef<typeof ElTable>) => {
tableRef.value = ref tableRef.value = ref
elTableRef.value = elRef elTableRef.value = unref(elRef)
} }
const getTable = async () => { const getTable = async () => {

View File

@ -70,7 +70,7 @@ export default defineComponent({
@prefix-cls: ~'@{namespace}-layout'; @prefix-cls: ~'@{namespace}-layout';
.@{prefix-cls} { .@{prefix-cls} {
background-color: var(--app-contnet-bg-color); background-color: var(--app-content-bg-color);
:deep(.@{elNamespace}-scrollbar__view) { :deep(.@{elNamespace}-scrollbar__view) {
height: 100% !important; height: 100% !important;
} }

View File

@ -22,7 +22,7 @@ const getCaches = computed((): string[] => {
<template> <template>
<section <section
:class="[ :class="[
'p-[var(--app-content-padding)] w-[100%] bg-[var(--app-contnet-bg-color)] dark:bg-[var(--el-bg-color)]', 'p-[var(--app-content-padding)] w-[100%] bg-[var(--app-content-bg-color)] dark:bg-[var(--el-bg-color)]',
{ {
'!min-h-[calc(100%-var(--app-footer-height))]': '!min-h-[calc(100%-var(--app-footer-height))]':
fixedHeader && (layout === 'classic' || layout === 'topLeft') && footer, fixedHeader && (layout === 'classic' || layout === 'topLeft') && footer,

View File

@ -377,7 +377,8 @@ export default {
showExpandedRows: 'Show expanded rows', showExpandedRows: 'Show expanded rows',
hiddenExpandedRows: 'Hidden expanded rows', hiddenExpandedRows: 'Hidden expanded rows',
changeTitle: 'Change title', changeTitle: 'Change title',
header: 'Header' header: 'Header',
selectAllNone: 'Select all / none'
}, },
richText: { richText: {
richText: 'Rich text', richText: 'Rich text',

View File

@ -374,7 +374,8 @@ export default {
showExpandedRows: '显示展开行', showExpandedRows: '显示展开行',
hiddenExpandedRows: '隐藏展开行', hiddenExpandedRows: '隐藏展开行',
changeTitle: '修改标题', changeTitle: '修改标题',
header: '头部' header: '头部',
selectAllNone: '全选/全不选'
}, },
richText: { richText: {
richText: '富文本', richText: '富文本',

View File

@ -59,7 +59,7 @@
--app-content-padding: 20px; --app-content-padding: 20px;
--app-contnet-bg-color: #f5f7f9; --app-content-bg-color: #f5f7f9;
--app-footer-height: 50px; --app-footer-height: 50px;

View File

@ -59,12 +59,12 @@ const getTableList = async (params?: Params) => {
pageSize: 10 pageSize: 10
} }
}) })
.catch(() => {}) // .catch(() => {})
.finally(() => { // .finally(() => {
loading.value = false // loading.value = false
}) // })
if (res) { if (res) {
tableDataList.value = res.data.list tableDataList.value = res.list
} }
} }

View File

@ -59,12 +59,12 @@ const getTableList = async (params?: Params) => {
pageSize: 10 pageSize: 10
} }
}) })
.catch(() => {}) // .catch(() => {})
.finally(() => { // .finally(() => {
loading.value = false // loading.value = false
}) // })
if (res) { if (res) {
tableDataList.value = res.data.list tableDataList.value = res.list
} }
} }

View File

@ -125,6 +125,10 @@ const showExpandedRows = (show: boolean) => {
expand: show expand: show
}) })
} }
const selectAllNone = () => {
unref(tableRef)?.elTableRef?.toggleAllSelection()
}
</script> </script>
<template> <template>
@ -146,6 +150,8 @@ const showExpandedRows = (show: boolean) => {
<ElButton @click="showExpandedRows(true)">{{ t('tableDemo.showExpandedRows') }}</ElButton> <ElButton @click="showExpandedRows(true)">{{ t('tableDemo.showExpandedRows') }}</ElButton>
<ElButton @click="showExpandedRows(false)">{{ t('tableDemo.hiddenExpandedRows') }}</ElButton> <ElButton @click="showExpandedRows(false)">{{ t('tableDemo.hiddenExpandedRows') }}</ElButton>
<ElButton @click="selectAllNone">{{ t('tableDemo.selectAllNone') }}</ElButton>
</ContentWrap> </ContentWrap>
<ContentWrap :title="`RefTable ${t('tableDemo.example')}`"> <ContentWrap :title="`RefTable ${t('tableDemo.example')}`">
<Table <Table

View File

@ -8,7 +8,7 @@ import { ref, h, reactive, unref } from 'vue'
import { ElTag, ElButton } from 'element-plus' import { ElTag, ElButton } from 'element-plus'
import { useTable } from '@/hooks/web/useTable' import { useTable } from '@/hooks/web/useTable'
const { register, tableObject, methods } = useTable<TableData>({ const { register, tableObject, methods, elTableRef } = useTable<TableData>({
getListApi: getTableListApi, getListApi: getTableListApi,
response: { response: {
list: 'list', list: 'list',
@ -124,6 +124,10 @@ const showExpandedRows = (show: boolean) => {
expand: show expand: show
}) })
} }
const selectAllNone = () => {
unref(elTableRef)?.toggleAllSelection()
}
</script> </script>
<template> <template>
@ -145,6 +149,8 @@ const showExpandedRows = (show: boolean) => {
<ElButton @click="showExpandedRows(true)">{{ t('tableDemo.showExpandedRows') }}</ElButton> <ElButton @click="showExpandedRows(true)">{{ t('tableDemo.showExpandedRows') }}</ElButton>
<ElButton @click="showExpandedRows(false)">{{ t('tableDemo.hiddenExpandedRows') }}</ElButton> <ElButton @click="showExpandedRows(false)">{{ t('tableDemo.hiddenExpandedRows') }}</ElButton>
<ElButton @click="selectAllNone">{{ t('tableDemo.selectAllNone') }}</ElButton>
</ContentWrap> </ContentWrap>
<ContentWrap :title="`UseTable ${t('tableDemo.example')}`"> <ContentWrap :title="`UseTable ${t('tableDemo.example')}`">
<Table <Table

View File

@ -30,7 +30,7 @@
"@types/intro.js", "@types/intro.js",
"@types/qrcode", "@types/qrcode",
"vite-plugin-svg-icons/client", "vite-plugin-svg-icons/client",
"unplugin-vue-define-options" "unplugin-vue-macros/macros-global"
], ],
"typeRoots": ["./node_modules/@types/", "./types"] "typeRoots": ["./node_modules/@types/", "./types"]
}, },

View File

@ -6,12 +6,12 @@ import WindiCSS from 'vite-plugin-windicss'
import VueJsx from '@vitejs/plugin-vue-jsx' import VueJsx from '@vitejs/plugin-vue-jsx'
import EslintPlugin from 'vite-plugin-eslint' import EslintPlugin from 'vite-plugin-eslint'
import VueI18n from '@intlify/vite-plugin-vue-i18n' import VueI18n from '@intlify/vite-plugin-vue-i18n'
import styleImport, { ElementPlusResolve } from 'vite-plugin-style-import' import { createStyleImportPlugin, ElementPlusResolve } from 'vite-plugin-style-import'
import { createSvgIconsPlugin } from 'vite-plugin-svg-icons' import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'
import PurgeIcons from 'vite-plugin-purge-icons' import PurgeIcons from 'vite-plugin-purge-icons'
import { viteMockServe } from 'vite-plugin-mock' import { viteMockServe } from 'vite-plugin-mock'
import DefineOptions from 'unplugin-vue-define-options/vite'
import { createHtmlPlugin } from 'vite-plugin-html' import { createHtmlPlugin } from 'vite-plugin-html'
import VueMarcos from 'unplugin-vue-macros/vite'
// https://vitejs.dev/config/ // https://vitejs.dev/config/
const root = process.cwd() const root = process.cwd()
@ -34,7 +34,7 @@ export default ({ command, mode }: ConfigEnv): UserConfig => {
Vue(), Vue(),
VueJsx(), VueJsx(),
WindiCSS(), WindiCSS(),
styleImport({ createStyleImportPlugin({
resolves: [ElementPlusResolve()], resolves: [ElementPlusResolve()],
libs: [{ libs: [{
libraryName: 'element-plus', libraryName: 'element-plus',
@ -70,7 +70,7 @@ export default ({ command, mode }: ConfigEnv): UserConfig => {
setupProdMockServer() setupProdMockServer()
` `
}), }),
DefineOptions(), VueMarcos(),
createHtmlPlugin({ createHtmlPlugin({
inject: { inject: {
data: { data: {