Merge pull request #313 from kailong321200875/master
This commit is contained in:
commit
4f501e600a
|
@ -24,6 +24,7 @@ module.exports = defineConfig({
|
||||||
'plugin:prettier/recommended'
|
'plugin:prettier/recommended'
|
||||||
],
|
],
|
||||||
rules: {
|
rules: {
|
||||||
|
'vue/no-setup-props-destructure': 'off',
|
||||||
'vue/script-setup-uses-vars': 'error',
|
'vue/script-setup-uses-vars': 'error',
|
||||||
'vue/no-reserved-component-names': 'off',
|
'vue/no-reserved-component-names': 'off',
|
||||||
'@typescript-eslint/ban-ts-ignore': 'off',
|
'@typescript-eslint/ban-ts-ignore': 'off',
|
||||||
|
|
18
README.md
18
README.md
|
@ -1,6 +1,6 @@
|
||||||
<div align="center"> <a href="https://github.com/kailong321200875/vue-element-plus-admin"> <img width="100" src="./public/logo.png"> </a> <br> <br>
|
<div align="center"> <a href="https://github.com/kailong321200875/vue-element-plus-admin"> <img width="100" src="./public/logo.png"> </a> <br> <br>
|
||||||
|
|
||||||
[data:image/s3,"s3://crabby-images/99b9a/99b9ad7e842b7a3f0a1a78d57593dde8cae7d67e" alt="license"](LICENSE)
|
[data:image/s3,"s3://crabby-images/99b9a/99b9ad7e842b7a3f0a1a78d57593dde8cae7d67e" alt="license"](LICENSE) [data:image/s3,"s3://crabby-images/07719/07719249184dd55dd9f31cb048f44658212e073b" alt="repo-size"](repo-size) [data:image/s3,"s3://crabby-images/56582/5658284514ee97bc5ad1a9c9292f1e0c4b00ed40" alt="last-commit"](last-commit) [data:image/s3,"s3://crabby-images/8f490/8f4901cd0a1dc325570a7e02f84acdb45c161f1f" alt="stars"](stars) [data:image/s3,"s3://crabby-images/70ba8/70ba81a474c733835b500c515ebda6920df38b91" alt="forks"](forks) [data:image/s3,"s3://crabby-images/44a34/44a344c0a732d0fbe971bd1843647bc015f416a3" alt="release"](release) [data:image/s3,"s3://crabby-images/69bf4/69bf46ac1d31ef46c7bd9e60a8b6d63978b3688a" alt="watchers"](watchers)
|
||||||
|
|
||||||
<h1>vue-element-plus-admin</h1>
|
<h1>vue-element-plus-admin</h1>
|
||||||
</div>
|
</div>
|
||||||
|
@ -9,11 +9,11 @@
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
vue-element-plus-admin is a free and open source middle and background template based on `element-plus`. Developed using the latest mainstream technologies such as `vue3`, `vite4` and `typescript`, the out of the box middle and background front-end solution can be used as the starting template of the project and learning reference. And always pay attention to the latest technological trends and update them as soon as possible.
|
vue-element-plus-admin is a free and open source middle and background template based on `element-plus`. Developed using the latest mainstream technologies such as `vue3`, `vite` and `typescript`, the out of the box middle and background front-end solution can be used as the starting template of the project and learning reference. And always pay attention to the latest technological trends and update them as soon as possible.
|
||||||
|
|
||||||
vue-element-plus-admin is positioned as a background integration scheme, which is not suitable for secondary development as a basic template. Because it integrates many functions that you may not use, it will cause a lot of code redundancy. If your project doesn't pay attention to this problem, you can also directly carry out secondary development based on it.
|
vue-element-plus-admin is positioned as a background integration scheme, which is not suitable for secondary development as a basic template. Because it integrates many functions that you may not use, it will cause a lot of code redundancy. If your project doesn't pay attention to this problem, you can also directly carry out secondary development based on it.
|
||||||
|
|
||||||
If you need a basic template, please switch to the `tempalte` branch. `Tempalte` simply integrates some common layout functions such as layout and dynamic menu, which is more suitable for developers to carry out secondary development.
|
If you need a basic template, please switch to the `mini` branch. `mini` simply integrates some common layout functions such as layout and dynamic menu, which is more suitable for developers to carry out secondary development.
|
||||||
|
|
||||||
## Feature
|
## Feature
|
||||||
|
|
||||||
|
@ -37,6 +37,8 @@ account: **admin/admin test/test**
|
||||||
|
|
||||||
`test` account is used to simulate the front-end control authority. The server only returns the menu key to be displayed, and the front-end performs matching rendering
|
`test` account is used to simulate the front-end control authority. The server only returns the menu key to be displayed, and the front-end performs matching rendering
|
||||||
|
|
||||||
|
Online examples do not apply to menu filtering by default, but directly use Static routing
|
||||||
|
|
||||||
## Documentation
|
## Documentation
|
||||||
|
|
||||||
[Document Github](https://element-plus-admin-doc.cn/)
|
[Document Github](https://element-plus-admin-doc.cn/)
|
||||||
|
@ -127,6 +129,16 @@ Support modern browsers, not IE
|
||||||
| :-: | :-: | :-: | :-: | :-: |
|
| :-: | :-: | :-: | :-: | :-: |
|
||||||
| not support | last 2 versions | last 2 versions | last 2 versions | last 2 versions |
|
| not support | last 2 versions | last 2 versions | last 2 versions | last 2 versions |
|
||||||
|
|
||||||
|
## Donate
|
||||||
|
|
||||||
|
If you find this project helpful, welcome sponsorship to show your support~
|
||||||
|
|
||||||
|
<img src="https://github.com/kailong321200875/my-image/raw/master/pay.jpg" />
|
||||||
|
|
||||||
|
## Group
|
||||||
|
|
||||||
|
<img src="https://github.com/kailong321200875/my-image/raw/master/chat-0820.jpg" />
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
[MIT](./LICENSE)
|
[MIT](./LICENSE)
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<div align="center"> <a href="https://github.com/kailong321200875/vue-element-plus-admin"> <img width="100" src="./public/logo.png"> </a> <br> <br>
|
<div align="center"> <a href="https://github.com/kailong321200875/vue-element-plus-admin"> <img width="100" src="./public/logo.png"> </a> <br> <br>
|
||||||
|
|
||||||
[data:image/s3,"s3://crabby-images/99b9a/99b9ad7e842b7a3f0a1a78d57593dde8cae7d67e" alt="license"](LICENSE)
|
[data:image/s3,"s3://crabby-images/99b9a/99b9ad7e842b7a3f0a1a78d57593dde8cae7d67e" alt="license"](LICENSE) [data:image/s3,"s3://crabby-images/07719/07719249184dd55dd9f31cb048f44658212e073b" alt="repo-size"](repo-size) [data:image/s3,"s3://crabby-images/56582/5658284514ee97bc5ad1a9c9292f1e0c4b00ed40" alt="last-commit"](last-commit) [data:image/s3,"s3://crabby-images/8f490/8f4901cd0a1dc325570a7e02f84acdb45c161f1f" alt="stars"](stars) [data:image/s3,"s3://crabby-images/70ba8/70ba81a474c733835b500c515ebda6920df38b91" alt="forks"](forks) [data:image/s3,"s3://crabby-images/44a34/44a344c0a732d0fbe971bd1843647bc015f416a3" alt="release"](release) [data:image/s3,"s3://crabby-images/69bf4/69bf46ac1d31ef46c7bd9e60a8b6d63978b3688a" alt="watchers"](watchers)
|
||||||
|
|
||||||
<h1>vue-element-plus-admin</h1>
|
<h1>vue-element-plus-admin</h1>
|
||||||
</div>
|
</div>
|
||||||
|
@ -9,11 +9,11 @@
|
||||||
|
|
||||||
## 介绍
|
## 介绍
|
||||||
|
|
||||||
vue-element-plus-admin 是一个基于 `element-plus` 免费开源的中后台模版。使用了最新的`vue3`,`vite4`,`TypeScript`等主流技术开发,开箱即用的中后台前端解决方案,可以用来作为项目的启动模版,也可用于学习参考。并且时刻关注着最新技术动向,尽可能的第一时间更新。
|
vue-element-plus-admin 是一个基于 `element-plus` 免费开源的中后台模版。使用了最新的`vue3`,`vite`,`TypeScript`等主流技术开发,开箱即用的中后台前端解决方案,可以用来作为项目的启动模版,也可用于学习参考。并且时刻关注着最新技术动向,尽可能的第一时间更新。
|
||||||
|
|
||||||
vue-element-plus-admin 的定位是后台集成方案,不太适合当基础模板来进行二次开发。因为集成了很多你可能用不到的功能,会造成不少的代码冗余。如果你的项目不关注这方面的问题,也可以直接基于它进行二次开发。
|
vue-element-plus-admin 的定位是后台集成方案,不太适合当基础模板来进行二次开发。因为集成了很多你可能用不到的功能,会造成不少的代码冗余。如果你的项目不关注这方面的问题,也可以直接基于它进行二次开发。
|
||||||
|
|
||||||
如需要基础模版,请切换到 `tempalte` 分支,`tempalte` 只简单集成了一些如:布局、动态菜单等常用布局功能,更适合开发者进行二次开发。
|
如需要基础模版,请切换到 `mini` 分支,`mini` 只简单集成了一些如:布局、动态菜单等常用布局功能,更适合开发者进行二次开发。
|
||||||
|
|
||||||
## 特性
|
## 特性
|
||||||
|
|
||||||
|
@ -37,6 +37,8 @@ vue-element-plus-admin 的定位是后台集成方案,不太适合当基础模
|
||||||
|
|
||||||
`test` 帐号用于模拟前端控制权限,服务端只返回需要显示的菜单 key,前端进行匹配渲染
|
`test` 帐号用于模拟前端控制权限,服务端只返回需要显示的菜单 key,前端进行匹配渲染
|
||||||
|
|
||||||
|
在线例子默认不适用菜单过滤,而是直接使用静态路由表
|
||||||
|
|
||||||
## 文档
|
## 文档
|
||||||
|
|
||||||
[文档地址 Github](https://element-plus-admin-doc.cn/)
|
[文档地址 Github](https://element-plus-admin-doc.cn/)
|
||||||
|
@ -127,6 +129,16 @@ pnpm run build:pro
|
||||||
| :-: | :-: | :-: | :-: | :-: |
|
| :-: | :-: | :-: | :-: | :-: |
|
||||||
| not support | last 2 versions | last 2 versions | last 2 versions | last 2 versions |
|
| not support | last 2 versions | last 2 versions | last 2 versions | last 2 versions |
|
||||||
|
|
||||||
|
## Donate
|
||||||
|
|
||||||
|
如果你觉得这个项目有帮助,欢迎赞助以示支持~
|
||||||
|
|
||||||
|
<img src="https://gitee.com/kailong110120130/my-image/raw/master/pay.jpg" />
|
||||||
|
|
||||||
|
## 交流群
|
||||||
|
|
||||||
|
<img src="https://gitee.com/kailong110120130/my-image/raw/master/chat-0820.jpg" />
|
||||||
|
|
||||||
## 许可证
|
## 许可证
|
||||||
|
|
||||||
[MIT](./LICENSE)
|
[MIT](./LICENSE)
|
||||||
|
|
|
@ -272,6 +272,37 @@ const adminList = [
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
path: '/function',
|
||||||
|
component: '#',
|
||||||
|
redirect: '/function/multipleTabs',
|
||||||
|
name: 'Function',
|
||||||
|
meta: {
|
||||||
|
title: 'router.function',
|
||||||
|
icon: 'ri:function-fill',
|
||||||
|
alwaysShow: true
|
||||||
|
},
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
path: 'multipleTabs',
|
||||||
|
component: 'views/Function/MultipleTabs',
|
||||||
|
name: 'MultipleTabs',
|
||||||
|
meta: {
|
||||||
|
title: 'router.multipleTabs'
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'multipleTabs-demo/:id',
|
||||||
|
component: 'views/Function/MultipleTabsDemo',
|
||||||
|
name: 'MultipleTabsDemo',
|
||||||
|
meta: {
|
||||||
|
hidden: true,
|
||||||
|
title: 'router.details',
|
||||||
|
canTo: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
{
|
{
|
||||||
path: '/hooks',
|
path: '/hooks',
|
||||||
component: '#',
|
component: '#',
|
||||||
|
@ -561,6 +592,9 @@ const testList: string[] = [
|
||||||
'/components/infotip',
|
'/components/infotip',
|
||||||
'/Components/InputPassword',
|
'/Components/InputPassword',
|
||||||
'/Components/Sticky',
|
'/Components/Sticky',
|
||||||
|
'function',
|
||||||
|
'/function/multiple-tabs',
|
||||||
|
'/function/multiple-tabs-demo/:id',
|
||||||
'/hooks',
|
'/hooks',
|
||||||
'/hooks/useWatermark',
|
'/hooks/useWatermark',
|
||||||
'/hooks/useOpenTab',
|
'/hooks/useOpenTab',
|
||||||
|
|
|
@ -93,7 +93,6 @@
|
||||||
"rollup": "^3.26.3",
|
"rollup": "^3.26.3",
|
||||||
"stylelint": "^15.10.1",
|
"stylelint": "^15.10.1",
|
||||||
"stylelint-config-html": "^1.1.0",
|
"stylelint-config-html": "^1.1.0",
|
||||||
"stylelint-config-prettier": "^9.0.5",
|
|
||||||
"stylelint-config-recommended": "^13.0.0",
|
"stylelint-config-recommended": "^13.0.0",
|
||||||
"stylelint-config-standard": "^34.0.0",
|
"stylelint-config-standard": "^34.0.0",
|
||||||
"stylelint-order": "^6.0.3",
|
"stylelint-order": "^6.0.3",
|
||||||
|
|
|
@ -23,13 +23,12 @@ const toggleCollapse = () => {
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<template>
|
<template>
|
||||||
<div :class="prefixCls">
|
<div :class="prefixCls" @click="toggleCollapse">
|
||||||
<Icon
|
<Icon
|
||||||
:size="18"
|
:size="18"
|
||||||
:icon="collapse ? 'ant-design:menu-unfold-outlined' : 'ant-design:menu-fold-outlined'"
|
:icon="collapse ? 'ant-design:menu-unfold-outlined' : 'ant-design:menu-fold-outlined'"
|
||||||
:color="color"
|
:color="color"
|
||||||
class="cursor-pointer"
|
class="cursor-pointer"
|
||||||
@click="toggleCollapse"
|
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
@ -24,6 +24,9 @@ defineProps({
|
||||||
</template>
|
</template>
|
||||||
<Icon class="ml-5px" icon="bi:question-circle-fill" :size="14" />
|
<Icon class="ml-5px" icon="bi:question-circle-fill" :size="14" />
|
||||||
</ElTooltip>
|
</ElTooltip>
|
||||||
|
<div class="flex pl-20px flex-grow">
|
||||||
|
<slot name="header"></slot>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<div>
|
<div>
|
||||||
|
|
|
@ -141,7 +141,7 @@ export default defineComponent({
|
||||||
id={`${variables.namespace}-menu`}
|
id={`${variables.namespace}-menu`}
|
||||||
class={[
|
class={[
|
||||||
prefixCls,
|
prefixCls,
|
||||||
'relative bg-[var(--left-menu-bg-color)] top-1px z-3000 layout-border__right',
|
'relative bg-[var(--left-menu-bg-color)] top-1px layout-border__right',
|
||||||
{
|
{
|
||||||
'w-[var(--tab-menu-max-width)]': !unref(collapse),
|
'w-[var(--tab-menu-max-width)]': !unref(collapse),
|
||||||
'w-[var(--tab-menu-min-width)]': unref(collapse)
|
'w-[var(--tab-menu-min-width)]': unref(collapse)
|
||||||
|
|
|
@ -362,7 +362,7 @@ export default defineComponent({
|
||||||
return children && children.length
|
return children && children.length
|
||||||
? renderTreeTableColumn(children)
|
? renderTreeTableColumn(children)
|
||||||
: props?.slots?.default
|
: props?.slots?.default
|
||||||
? props.slots.default(args)
|
? props.slots.default(...args)
|
||||||
: v?.formatter
|
: v?.formatter
|
||||||
? v?.formatter?.(data.row, data.column, get(data.row, v.field), data.$index)
|
? v?.formatter?.(data.row, data.column, get(data.row, v.field), data.$index)
|
||||||
: isImageUrl
|
: isImageUrl
|
||||||
|
@ -371,7 +371,7 @@ export default defineComponent({
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (props?.slots?.header) {
|
if (props?.slots?.header) {
|
||||||
slots['header'] = (...args: any[]) => props.slots.header(args)
|
slots['header'] = (...args: any[]) => props.slots.header(...args)
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
@ -459,7 +459,7 @@ export default defineComponent({
|
||||||
return children && children.length
|
return children && children.length
|
||||||
? renderTreeTableColumn(children)
|
? renderTreeTableColumn(children)
|
||||||
: props?.slots?.default
|
: props?.slots?.default
|
||||||
? props.slots.default(args)
|
? props.slots.default(...args)
|
||||||
: v?.formatter
|
: v?.formatter
|
||||||
? v?.formatter?.(data.row, data.column, get(data.row, v.field), data.$index)
|
? v?.formatter?.(data.row, data.column, get(data.row, v.field), data.$index)
|
||||||
: isImageUrl
|
: isImageUrl
|
||||||
|
@ -468,7 +468,7 @@ export default defineComponent({
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (props?.slots?.header) {
|
if (props?.slots?.header) {
|
||||||
slots['header'] = (...args: any[]) => props.slots.header(args)
|
slots['header'] = (...args: any[]) => props.slots.header(...args)
|
||||||
}
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
|
|
@ -164,7 +164,10 @@ export default {
|
||||||
department: 'Department management',
|
department: 'Department management',
|
||||||
menuManagement: 'Menu management',
|
menuManagement: 'Menu management',
|
||||||
// 权限测试页面
|
// 权限测试页面
|
||||||
permission: 'Permission test page'
|
permission: 'Permission test page',
|
||||||
|
function: 'Function',
|
||||||
|
multipleTabs: 'Multiple tabs',
|
||||||
|
details: 'Details'
|
||||||
},
|
},
|
||||||
permission: {
|
permission: {
|
||||||
hasPermission: 'Please set the operation permission value'
|
hasPermission: 'Please set the operation permission value'
|
||||||
|
|
|
@ -163,7 +163,10 @@ export default {
|
||||||
PicturePreview: '表格图片预览',
|
PicturePreview: '表格图片预览',
|
||||||
department: '部门管理',
|
department: '部门管理',
|
||||||
menuManagement: '菜单管理',
|
menuManagement: '菜单管理',
|
||||||
permission: '权限测试页'
|
permission: '权限测试页',
|
||||||
|
function: '功能',
|
||||||
|
multipleTabs: '多开标签页',
|
||||||
|
details: '详情页'
|
||||||
},
|
},
|
||||||
permission: {
|
permission: {
|
||||||
hasPermission: '请设置操作权限值'
|
hasPermission: '请设置操作权限值'
|
||||||
|
|
|
@ -5,15 +5,15 @@ import type { RouteRecordRaw } from 'vue-router'
|
||||||
import { useTitle } from '@/hooks/web/useTitle'
|
import { useTitle } from '@/hooks/web/useTitle'
|
||||||
import { useNProgress } from '@/hooks/web/useNProgress'
|
import { useNProgress } from '@/hooks/web/useNProgress'
|
||||||
import { usePermissionStoreWithOut } from '@/store/modules/permission'
|
import { usePermissionStoreWithOut } from '@/store/modules/permission'
|
||||||
import { useDictStoreWithOut } from '@/store/modules/dict'
|
// import { useDictStoreWithOut } from '@/store/modules/dict'
|
||||||
import { usePageLoading } from '@/hooks/web/usePageLoading'
|
import { usePageLoading } from '@/hooks/web/usePageLoading'
|
||||||
import { getDictApi } from '@/api/common'
|
// import { getDictApi } from '@/api/common'
|
||||||
|
|
||||||
const permissionStore = usePermissionStoreWithOut()
|
const permissionStore = usePermissionStoreWithOut()
|
||||||
|
|
||||||
const appStore = useAppStoreWithOut()
|
const appStore = useAppStoreWithOut()
|
||||||
|
|
||||||
const dictStore = useDictStoreWithOut()
|
// const dictStore = useDictStoreWithOut()
|
||||||
|
|
||||||
const { getStorage } = useStorage()
|
const { getStorage } = useStorage()
|
||||||
|
|
||||||
|
@ -30,14 +30,14 @@ router.beforeEach(async (to, from, next) => {
|
||||||
if (to.path === '/login') {
|
if (to.path === '/login') {
|
||||||
next({ path: '/' })
|
next({ path: '/' })
|
||||||
} else {
|
} else {
|
||||||
if (!dictStore.getIsSetDict) {
|
// if (!dictStore.getIsSetDict) {
|
||||||
// 获取所有字典
|
// // 获取所有字典
|
||||||
const res = await getDictApi()
|
// const res = await getDictApi()
|
||||||
if (res) {
|
// if (res) {
|
||||||
dictStore.setDictObj(res.data)
|
// dictStore.setDictObj(res.data)
|
||||||
dictStore.setIsSetDict(true)
|
// dictStore.setIsSetDict(true)
|
||||||
}
|
// }
|
||||||
}
|
// }
|
||||||
if (permissionStore.getIsAddRouters) {
|
if (permissionStore.getIsAddRouters) {
|
||||||
next()
|
next()
|
||||||
return
|
return
|
||||||
|
|
|
@ -313,6 +313,37 @@ export const asyncRouterMap: AppRouteRecordRaw[] = [
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
path: '/function',
|
||||||
|
component: Layout,
|
||||||
|
redirect: '/function/multipleTabs',
|
||||||
|
name: 'Function',
|
||||||
|
meta: {
|
||||||
|
title: t('router.function'),
|
||||||
|
icon: 'ri:function-fill',
|
||||||
|
alwaysShow: true
|
||||||
|
},
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
path: 'multiple-tabs',
|
||||||
|
component: () => import('@/views/Function/MultipleTabs.vue'),
|
||||||
|
name: 'MultipleTabs',
|
||||||
|
meta: {
|
||||||
|
title: t('router.multipleTabs')
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: 'multiple-tabs-demo/:id',
|
||||||
|
component: () => import('@/views/Function/MultipleTabsDemo.vue'),
|
||||||
|
name: 'MultipleTabsDemo',
|
||||||
|
meta: {
|
||||||
|
hidden: true,
|
||||||
|
title: t('router.details'),
|
||||||
|
canTo: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
},
|
||||||
{
|
{
|
||||||
path: '/hooks',
|
path: '/hooks',
|
||||||
component: Layout,
|
component: Layout,
|
||||||
|
@ -333,14 +364,6 @@ export const asyncRouterMap: AppRouteRecordRaw[] = [
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// {
|
// {
|
||||||
// path: 'useOpenTab',
|
|
||||||
// component: () => import('@/views/hooks/useOpenTab.vue'),
|
|
||||||
// name: 'UseOpenTab',
|
|
||||||
// meta: {
|
|
||||||
// title: 'useOpenTab'
|
|
||||||
// }
|
|
||||||
// }
|
|
||||||
// {
|
|
||||||
// path: 'useCrudSchemas',
|
// path: 'useCrudSchemas',
|
||||||
// component: () => import('@/views/hooks/useCrudSchemas.vue'),
|
// component: () => import('@/views/hooks/useCrudSchemas.vue'),
|
||||||
// name: 'UseCrudSchemas',
|
// name: 'UseCrudSchemas',
|
||||||
|
|
|
@ -85,7 +85,7 @@ const crudSchemas = reactive<CrudSchema[]>([
|
||||||
table: {
|
table: {
|
||||||
slots: {
|
slots: {
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
return <>{data[0].row.departmentName}</>
|
return <>{data.row.departmentName}</>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -119,7 +119,7 @@ const crudSchemas = reactive<CrudSchema[]>([
|
||||||
table: {
|
table: {
|
||||||
slots: {
|
slots: {
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
const status = data[0].row.status
|
const status = data.row.status
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ElTag type={status === 0 ? 'danger' : 'success'}>
|
<ElTag type={status === 0 ? 'danger' : 'success'}>
|
||||||
|
@ -215,13 +215,13 @@ const crudSchemas = reactive<CrudSchema[]>([
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ElButton type="primary" onClick={() => action(data[0].row, 'edit')}>
|
<ElButton type="primary" onClick={() => action(data.row, 'edit')}>
|
||||||
{t('exampleDemo.edit')}
|
{t('exampleDemo.edit')}
|
||||||
</ElButton>
|
</ElButton>
|
||||||
<ElButton type="success" onClick={() => action(data[0].row, 'detail')}>
|
<ElButton type="success" onClick={() => action(data.row, 'detail')}>
|
||||||
{t('exampleDemo.detail')}
|
{t('exampleDemo.detail')}
|
||||||
</ElButton>
|
</ElButton>
|
||||||
<ElButton type="danger" onClick={() => delData(data[0].row)}>
|
<ElButton type="danger" onClick={() => delData(data.row)}>
|
||||||
{t('exampleDemo.del')}
|
{t('exampleDemo.del')}
|
||||||
</ElButton>
|
</ElButton>
|
||||||
</>
|
</>
|
||||||
|
|
|
@ -41,7 +41,7 @@ const tableColumns = reactive<TableColumn[]>([
|
||||||
label: t('menu.icon'),
|
label: t('menu.icon'),
|
||||||
slots: {
|
slots: {
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
const icon = data[0].row.meta.icon
|
const icon = data.row.meta.icon
|
||||||
if (icon) {
|
if (icon) {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
|
@ -59,7 +59,7 @@ const tableColumns = reactive<TableColumn[]>([
|
||||||
label: t('menu.permission'),
|
label: t('menu.permission'),
|
||||||
slots: {
|
slots: {
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
const permission = data[0].row.meta.permission
|
const permission = data.row.meta.permission
|
||||||
return permission ? <>{permission.join(', ')}</> : null
|
return permission ? <>{permission.join(', ')}</> : null
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -69,7 +69,7 @@ const tableColumns = reactive<TableColumn[]>([
|
||||||
label: t('menu.component'),
|
label: t('menu.component'),
|
||||||
slots: {
|
slots: {
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
const component = data[0].row.component
|
const component = data.row.component
|
||||||
return <>{component === '#' ? '顶级目录' : component === '##' ? '子目录' : component}</>
|
return <>{component === '#' ? '顶级目录' : component === '##' ? '子目录' : component}</>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -85,8 +85,8 @@ const tableColumns = reactive<TableColumn[]>([
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ElTag type={data[0].row.status === 0 ? 'danger' : 'success'}>
|
<ElTag type={data.row.status === 0 ? 'danger' : 'success'}>
|
||||||
{data[0].row.status === 1 ? t('userDemo.enable') : t('userDemo.disable')}
|
{data.row.status === 1 ? t('userDemo.enable') : t('userDemo.disable')}
|
||||||
</ElTag>
|
</ElTag>
|
||||||
</>
|
</>
|
||||||
)
|
)
|
||||||
|
@ -99,7 +99,7 @@ const tableColumns = reactive<TableColumn[]>([
|
||||||
width: 240,
|
width: 240,
|
||||||
slots: {
|
slots: {
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
const row = data[0].row
|
const row = data.row
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ElButton type="primary" onClick={() => action(row, 'edit')}>
|
<ElButton type="primary" onClick={() => action(row, 'edit')}>
|
||||||
|
|
|
@ -47,8 +47,8 @@ const tableColumns = reactive<TableColumn[]>([
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ElTag type={data[0].row.status === 0 ? 'danger' : 'success'}>
|
<ElTag type={data.row.status === 0 ? 'danger' : 'success'}>
|
||||||
{data[0].row.status === 1 ? t('userDemo.enable') : t('userDemo.disable')}
|
{data.row.status === 1 ? t('userDemo.enable') : t('userDemo.disable')}
|
||||||
</ElTag>
|
</ElTag>
|
||||||
</>
|
</>
|
||||||
)
|
)
|
||||||
|
@ -69,7 +69,7 @@ const tableColumns = reactive<TableColumn[]>([
|
||||||
width: 240,
|
width: 240,
|
||||||
slots: {
|
slots: {
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
const row = data[0].row
|
const row = data.row
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ElButton type="primary" onClick={() => action(row, 'edit')}>
|
<ElButton type="primary" onClick={() => action(row, 'edit')}>
|
||||||
|
|
|
@ -150,7 +150,7 @@ const crudSchemas = reactive<CrudSchema[]>([
|
||||||
width: 240,
|
width: 240,
|
||||||
slots: {
|
slots: {
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
const row = data[0].row as DepartmentUserItem
|
const row = data.row as DepartmentUserItem
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ElButton type="primary" onClick={() => action(row, 'edit')}>
|
<ElButton type="primary" onClick={() => action(row, 'edit')}>
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<script setup lang="tsx">
|
<script setup lang="tsx">
|
||||||
import { ContentWrap } from '@/components/ContentWrap'
|
import { ContentWrap } from '@/components/ContentWrap'
|
||||||
import { useI18n } from '@/hooks/web/useI18n'
|
import { useI18n } from '@/hooks/web/useI18n'
|
||||||
import { Table, TableColumn, TableSlotDefault } from '@/components/Table'
|
import { Table, TableColumn } from '@/components/Table'
|
||||||
import { getTableListApi } from '@/api/table'
|
import { getTableListApi } from '@/api/table'
|
||||||
import { TableData } from '@/api/table/types'
|
import { TableData } from '@/api/table/types'
|
||||||
import { ref, h } from 'vue'
|
import { ref, h } from 'vue'
|
||||||
|
@ -87,7 +87,7 @@ const getTableList = async (params?: Params) => {
|
||||||
|
|
||||||
getTableList()
|
getTableList()
|
||||||
|
|
||||||
const actionFn = (data: TableSlotDefault) => {
|
const actionFn = (data: any) => {
|
||||||
console.log(data)
|
console.log(data)
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<script setup lang="tsx">
|
<script setup lang="tsx">
|
||||||
import { ContentWrap } from '@/components/ContentWrap'
|
import { ContentWrap } from '@/components/ContentWrap'
|
||||||
import { useI18n } from '@/hooks/web/useI18n'
|
import { useI18n } from '@/hooks/web/useI18n'
|
||||||
import { Table, TableColumn, TableSlotDefault } from '@/components/Table'
|
import { Table, TableColumn } from '@/components/Table'
|
||||||
import { getTreeTableListApi } from '@/api/table'
|
import { getTreeTableListApi } from '@/api/table'
|
||||||
import { reactive, unref } from 'vue'
|
import { reactive, unref } from 'vue'
|
||||||
import { ElTag, ElButton } from 'element-plus'
|
import { ElTag, ElButton } from 'element-plus'
|
||||||
|
@ -86,7 +86,7 @@ const columns = reactive<TableColumn[]>([
|
||||||
}
|
}
|
||||||
])
|
])
|
||||||
|
|
||||||
const actionFn = (data: TableSlotDefault) => {
|
const actionFn = (data) => {
|
||||||
console.log(data)
|
console.log(data)
|
||||||
}
|
}
|
||||||
</script>
|
</script>
|
||||||
|
|
|
@ -30,8 +30,8 @@ const columns = reactive<TableColumn[]>([
|
||||||
field: 'expand',
|
field: 'expand',
|
||||||
type: 'expand',
|
type: 'expand',
|
||||||
slots: {
|
slots: {
|
||||||
default: (data: TableSlotDefault[]) => {
|
default: (data: TableSlotDefault) => {
|
||||||
const { row } = data[0]
|
const { row } = data
|
||||||
return (
|
return (
|
||||||
<div class="ml-30px">
|
<div class="ml-30px">
|
||||||
<div>
|
<div>
|
||||||
|
|
|
@ -212,13 +212,13 @@ const crudSchemas = reactive<CrudSchema[]>([
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ElButton type="primary" onClick={() => action(data[0].row, 'edit')}>
|
<ElButton type="primary" onClick={() => action(data.row, 'edit')}>
|
||||||
{t('exampleDemo.edit')}
|
{t('exampleDemo.edit')}
|
||||||
</ElButton>
|
</ElButton>
|
||||||
<ElButton type="success" onClick={() => action(data[0].row, 'detail')}>
|
<ElButton type="success" onClick={() => action(data.row, 'detail')}>
|
||||||
{t('exampleDemo.detail')}
|
{t('exampleDemo.detail')}
|
||||||
</ElButton>
|
</ElButton>
|
||||||
<ElButton type="danger" onClick={() => delData(data[0].row)}>
|
<ElButton type="danger" onClick={() => delData(data.row)}>
|
||||||
{t('exampleDemo.del')}
|
{t('exampleDemo.del')}
|
||||||
</ElButton>
|
</ElButton>
|
||||||
</>
|
</>
|
||||||
|
|
|
@ -229,13 +229,13 @@ const crudSchemas = reactive<CrudSchema[]>([
|
||||||
default: (data: any) => {
|
default: (data: any) => {
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<ElButton type="primary" onClick={() => action(data[0].row, 'edit')}>
|
<ElButton type="primary" onClick={() => action(data.row, 'edit')}>
|
||||||
{t('exampleDemo.edit')}
|
{t('exampleDemo.edit')}
|
||||||
</ElButton>
|
</ElButton>
|
||||||
<ElButton type="success" onClick={() => action(data[0].row, 'detail')}>
|
<ElButton type="success" onClick={() => action(data.row, 'detail')}>
|
||||||
{t('exampleDemo.detail')}
|
{t('exampleDemo.detail')}
|
||||||
</ElButton>
|
</ElButton>
|
||||||
<ElButton type="danger" onClick={() => delData(data[0].row)}>
|
<ElButton type="danger" onClick={() => delData(data.row)}>
|
||||||
{t('exampleDemo.del')}
|
{t('exampleDemo.del')}
|
||||||
</ElButton>
|
</ElButton>
|
||||||
</>
|
</>
|
||||||
|
|
|
@ -0,0 +1,19 @@
|
||||||
|
<script setup lang="ts">
|
||||||
|
import { ContentWrap } from '@/components/ContentWrap'
|
||||||
|
import { ElButton } from 'element-plus'
|
||||||
|
import { useRouter } from 'vue-router'
|
||||||
|
|
||||||
|
const { push } = useRouter()
|
||||||
|
|
||||||
|
const openTab = (item: number) => {
|
||||||
|
push(`/function/multiple-tabs-demo/${item}`)
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<ContentWrap>
|
||||||
|
<ElButton v-for="item in 5" :key="item" type="primary" @click="openTab(item)">
|
||||||
|
打开详情页{{ item }}
|
||||||
|
</ElButton>
|
||||||
|
</ContentWrap>
|
||||||
|
</template>
|
|
@ -0,0 +1,14 @@
|
||||||
|
<script setup lang="ts">
|
||||||
|
import { ContentWrap } from '@/components/ContentWrap'
|
||||||
|
import { ElInput } from 'element-plus'
|
||||||
|
import { ref } from 'vue'
|
||||||
|
import { useRoute } from 'vue-router'
|
||||||
|
|
||||||
|
const { params } = useRoute()
|
||||||
|
|
||||||
|
const val = ref(params.id as string)
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<ContentWrap> 获取参数: <ElInput v-model="val" /> </ContentWrap>
|
||||||
|
</template>
|
|
@ -2,7 +2,7 @@ module.exports = {
|
||||||
root: true,
|
root: true,
|
||||||
plugins: ['stylelint-order'],
|
plugins: ['stylelint-order'],
|
||||||
customSyntax: 'postcss-html',
|
customSyntax: 'postcss-html',
|
||||||
extends: ['stylelint-config-standard', 'stylelint-config-prettier'],
|
extends: ['stylelint-config-standard'],
|
||||||
rules: {
|
rules: {
|
||||||
'selector-pseudo-class-no-unknown': [
|
'selector-pseudo-class-no-unknown': [
|
||||||
true,
|
true,
|
||||||
|
|
|
@ -45,7 +45,7 @@ export default ({ command, mode }: ConfigEnv): UserConfig => {
|
||||||
if (name === 'click-outside') {
|
if (name === 'click-outside') {
|
||||||
return ''
|
return ''
|
||||||
}
|
}
|
||||||
return `element-plus/es/components/${name.substring(3)}/style/css`
|
return `element-plus/es/components/${name.replace(/^el-/, '')}/style/css`
|
||||||
}
|
}
|
||||||
}]
|
}]
|
||||||
}),
|
}),
|
||||||
|
|
Loading…
Reference in New Issue