Compare commits

...

2 Commits

Author SHA1 Message Date
zhaoweijie
6926fbd9b7 根据业务需要封装公共表格 2022-01-05 12:20:16 +08:00
lifang
0ffa5598ff add repo object management pages 2022-01-04 10:21:56 +08:00
30 changed files with 8838 additions and 7420 deletions

57
.fes.js
View File

@ -19,13 +19,68 @@ export default {
},
},
layout: {
title: 'Fes.js',
title: '数联网控制系统',
footer: 'Created by MumbleFe',
multiTabs: false,
menus: [
{
name: 'index',
icon: 'home'
},
{
name:'networking',
icon:'apartment',
children:[
{
name:'unionManage'
},
{
name:'levelManage'
}
]
},
{
name:'repoManage',
icon:'database',
children:[
{
name:'repoList'
},
{
name:'repoDetail'
}
]
},
{
name:'objectSearch',
icon:'search'
},
{
name:'globalManage',
icon:'fullscreen',
children:[
{
name:'manageUnion'
},
{
name:'manageConfig'
},
{
name:'manageTemplate'
},
{
name:'manageData'
}
]
},
{
name:'doRight',
icon:'edit'
},
{
name:'set_up',
icon:'setting'
}
],
},
devServer: {

145
et --hard Normal file
View File

@ -0,0 +1,145 @@
commit 5a51c860ea375760c7052f7a29f4365502ecd70f (HEAD -> feat/router, origin/master, origin/feat/repoManage-a, origin/HEAD, master, feat/repoManage-a)
Merge: 991bac1 da0d0a6
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Tue Dec 28 18:58:32 2021 +0800
Merge branch 'master' of https://github.com/daotl/fes-starter
commit da0d0a651303fc87be23094f2067e174dc5fb2f7
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Tue Dec 28 18:37:34 2021 +0800
feat: add Pinia
commit 126d430ef34917d5d5a3223d51943b3a14017a56
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Tue Dec 28 17:06:43 2021 +0800
fix: add 'node' and 'jest' to types in tsconfig.json
commit 1d16701350d9d97757eb25f7f803454d28bd2cc5
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Tue Dec 28 12:20:01 2021 +0800
docs: links
commit 991bac123100b8862db757388f0e616fab0bdede (origin/feat/router)
Merge: 6e4869d 751b9e7
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Tue Dec 28 10:26:27 2021 +0800
Merge branch 'master' of https://github.com/daotl/fes-starter
commit 751b9e7b3be6a4e968f3260233c4d8522566834f
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Tue Dec 28 09:41:13 2021 +0800
chore: update fes.js deps
commit 6e4869dae154db040903a0f9c12b6b6526b69c3b
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 23:33:58 2021 +0800
chore: setup commitlint and commitizen
commit cd3ad4ef78b116d640b1b5ecb2e1cd13ad685e15
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 22:09:26 2021 +0800
chore: init from starter template
commit 80715dc6bd36bcdbd421ab963b329e83f64b0a45
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 21:54:25 2021 +0800
style: move <config> block to top
commit 4c7482cef892b1ee806b77cadc7e9284c3dd9a07
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 21:47:25 2021 +0800
feat: add Iconify icons with unplugin-icons
commit 373d34df9f988264ae0910e243231b450f0934dd
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 19:37:31 2021 +0800
feat: switch to Element Plus
commit a9b2b816f82020a2f91cdab59d094d6236c2aeff
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 19:23:47 2021 +0800
feat: add unplugin-vue-components
commit 545ef5b0ddf63c8a6bdb77e582ee00530b49ce7b
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 19:07:17 2021 +0800
feat: add unplugin-auto-imports
commit 3fa72dc0fca5f1122b705c2a8e410e57a16f1e6c
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 17:41:26 2021 +0800
docs: update README
commit d7dc53640b01c1422f85b1c03b80938b3fe7f4f7
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 17:37:41 2021 +0800
feat: add eslint-webpack-plugin
commit d848c6934c3d000e2a99c6fa8cd596fe6fe4e596
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 17:31:15 2021 +0800
docs: update README
commit 36ff5aff2bdf62ff48f044a85701b23f7e3afc8c
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 17:23:55 2021 +0800
fix: add TypeScript to devDependencies
commit 32d835ff27e141a1ee565a998cae81974467af15
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 16:14:28 2021 +0800
chore: add husky and lint-staged
commit 4908523bc41e9bcdac15720c18dd5cce1a704553
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 16:00:29 2021 +0800
chore: add recommended VSCode extensions
commit b43eac82ada23e4fd4d97f100024bf64f3362497
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 15:34:51 2021 +0800
docs: README
commit 808ee936138c8d1a50e3bd576889edc852c7f4dd
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 15:26:40 2021 +0800
feat: switch to SCSS and add Stylelint
commit 6382f68efd5a460b9ed4c794c1e4c007a2792021
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 15:06:11 2021 +0800
feat: add alias: `~` -> `src`
commit a7c776a85ef1e9626ac3c51a00e0bf5b73364ec9
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Mon Dec 27 10:44:31 2021 +0800
feat: switch to TypeScript, custom ESLint config, update deps
commit bc6bc455d8842d3bb4fd34266bcbbbc89fb5d1b3
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
Date: Sun Dec 26 17:14:46 2021 +0800
init: npx @fesjs/create-fes-app myapp

14353
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -47,6 +47,7 @@
"@daotl/prettier-config": "^0.1.2",
"@daotl/tsconfig": "^0.0.4",
"@fesjs/plugin-sass": "^2.0.0",
"@iconify-json/bi": "^1.0.10",
"@iconify-json/mdi": "^1.0.12",
"@vue/compiler-sfc": "^3.2.26",
"commitizen": "^4.2.4",

View File

@ -1,12 +1,19 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>fes.js</title>
<link rel="shortcut icon" type="image/x-icon" href="./logo.png">
</head>
<body>
<link rel="shortcut icon" type="image/x-icon" href="./logo.png" />
<!-- 引入样式 -->
<link
rel="stylesheet"
href="https://unpkg.com/element-ui/lib/theme-chalk/index.css"
/>
<!-- 引入组件库 -->
<script src="https://unpkg.com/element-ui/lib/index.js"></script>
</head>
<body>
<div id="app"></div>
</body>
</body>
</html>

View File

@ -0,0 +1,39 @@
<template>
<el-table-column v-bind="$attrs" class="ProTableColumn">
<template #default="{ row, column, $index }">
<slot
:row="row"
:column="column"
:$index="$index"
:pageIndex="calcPageIndex($index)"
:deleteRow="deleteRow.bind(null, calcPageIndex($index))"
:updatedRow="updatedRow.bind(null, calcPageIndex($index))"
>
{{ row[props?.prop] }}
</slot>
</template>
</el-table-column>
</template>
<script setup lang="ts">
import { defineProps, withDefaults, inject, Ref } from 'vue'
import { DELETE_ROW, UPDATE_ROW, PAGINATION_INFO } from '~/constants/proTable'
import { IPaginationInfo } from '~/interfaces/proTable'
interface Props {
prop: string
}
const props = withDefaults(defineProps<Props>(), {})
const paginationInfo = inject<Ref<IPaginationInfo>>(PAGINATION_INFO)
const updatedRow = inject(UPDATE_ROW)
const deleteRow = inject(DELETE_ROW)
//
const calcPageIndex = (index: number) => {
const { currentPage, pageSize } = paginationInfo!.value
return (currentPage - 1) * pageSize + index
}
</script>
<!--<style scoped lang="scss"></style>-->

View File

@ -0,0 +1,171 @@
<template>
<div v-loading="loading" class="pro-table">
<div class="header">
<div class="action-container">
<el-button
v-if="props.createText"
type="primary"
size="mini"
:icon="Plus"
@click="onCreate"
>
{{ props.createText }}
</el-button>
</div>
</div>
<el-table :data="displayTableData" v-bind="$attrs">
<slot></slot>
</el-table>
<el-config-provider :locale="zhCn">
<el-pagination
v-if="paginationInfo.showPagination"
class="pagination"
:current-page="paginationInfo.currentPage"
layout="total, jumper, prev, pager, next, sizes"
:page-size="paginationInfo.pageSize"
:total="paginationInfo.total"
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
>
</el-pagination>
</el-config-provider>
</div>
</template>
<script setup lang="ts">
import { defineProps, withDefaults, provide, ref } from 'vue'
import zhCn from 'element-plus/lib/locale/lang/zh-cn'
import { Plus } from '@element-plus/icons-vue'
import {
ITableDataItem,
IPaginationInfo,
IOnCreated,
} from '~/interfaces/proTable'
import {
DELETE_ROW,
UPDATE_ROW,
PAGINATION_INFO,
CREATE_ROW,
} from '~/constants/proTable'
import { HandleProTableData } from '~/tools/proTable'
interface Props {
request: () => Promise<{ data: ITableDataItem[] }>
//
showPagination?: boolean
currentPage?: number
pageSize?: number
pageSizes?: number[]
// header
createText?: string
}
const props = withDefaults(defineProps<Props>(), {
currentPage: 1,
pageSize: 10,
pageSizes: () => [10, 20, 30, 40, 50, 100],
showPagination: true,
})
const emit = defineEmits(['onCreated'])
//
const paginationInfo = ref<IPaginationInfo>({
currentPage: props.currentPage,
pageSize: props.pageSize,
pageSizes: props.pageSizes,
showPagination: props.showPagination,
total: 0,
})
const handleSizeChange = (val: number) => {
paginationInfo.value.pageSize = val
updateTheView()
}
const handleCurrentChange = (val: number) => {
paginationInfo.value.currentPage = val
updateTheView()
}
//
const tableData = ref<ITableDataItem[]>([])
const displayTableData = ref<ITableDataItem[]>(tableData.value)
const loading = ref(false)
async function getData() {
try {
loading.value = true
const { data } = await props.request()
tableData.value = data
paginationInfo.value.total = tableData.value?.length
updateTheView()
loading.value = false
} catch (e) {
loading.value = false
console.log((e as Error).message)
}
}
onMounted(async () => {
await getData()
})
const updateTheView = () => {
if (!paginationInfo.value?.showPagination) {
displayTableData.value = tableData.value
}
const { currentPage, pageSize } = paginationInfo.value
const pageStart: number = (currentPage - 1) * pageSize
displayTableData.value = tableData.value.slice(
pageStart,
pageStart + pageSize,
)
paginationInfo.value.total = tableData.value.length
}
const handleTable = computed(() => {
return new HandleProTableData(updateTheView, tableData)
})
const onCreate = () => {
emit('onCreated', handleTable.value.createRow)
}
//
defineExpose({
paginationInfo,
...handleTable.value,
})
// 使
provide(PAGINATION_INFO, paginationInfo)
provide(UPDATE_ROW, handleTable.value.updatedRow)
provide(DELETE_ROW, handleTable.value.deleteRow)
provide(CREATE_ROW, handleTable.value.createRow)
</script>
<style scoped lang="scss">
.pro-table {
width: 100%;
.header {
margin-bottom: 8px;
}
.pagination {
display: flex;
justify-content: flex-end;
margin-top: 15px;
$marginLeft: 15px;
::v-deep(.btn-prev) {
margin-left: $marginLeft !important;
}
::v-deep(.el-input) {
margin-left: $marginLeft !important;
}
::v-deep(.el-pager li) {
margin: 0 2px;
}
}
}
</style>

View File

@ -1,22 +1,53 @@
<template>
<div class="right">
<i-mdi-account-box
style="color: red; font-size: 2em; vertical-align: middle"
<el-icon :size="20" class="search">
<search />
</el-icon>
<el-icon class="bell"><bell /></el-icon>
<span class="line">|</span>
<a-icon type="question-circle" />
<i-bi:question-circle
style="color: #a39980; font-size: 16px; vertical-align: middle"
/>
<span>{{ name }}</span>
<div class="head"></div>
<!-- <span>{{ name }}</span> -->
</div>
</template>
<script setup lang="ts">
import useUserStore from '~/stores/user'
// import useUserStore from '~/stores/user'
const store = useUserStore()
const name = store.name
// const store = useUserStore()
// const name = store.name
// import { useModel } from '@fesjs/fes'
// import type { State } from '~/app'
import { Search, Bell } from '@element-plus/icons-vue'
// const initialState = useModel('@@initialState') as State
</script>
<style scope lang="scss">
.right {
width: 15%;
padding: 0 20px;
text-align: right;
float: right;
display: flex;
align-items: center;
justify-content: space-between;
.search,
.bell {
font-size: 20px;
color: #929292;
}
.line {
color: #929292;
}
.head {
display: inline-block;
width: 25px;
height: 25px;
border-radius: 50%;
background-color: pink;
}
}
</style>

View File

@ -0,0 +1,8 @@
// 分页信息
export const PAGINATION_INFO = 'PAGINATION_INFO'
// 修改表格数据
export const UPDATE_ROW = 'UPDATE_ROW'
// 删除表格数据
export const DELETE_ROW = 'DELETE_ROW'
// 添加数据
export const CREATE_ROW = 'CREATE_ROW'

0
src/icons/question.svg Normal file
View File

View File

@ -0,0 +1,33 @@
export interface ITableDataItem {
[key: string]: any
}
export type IPaginationInfo = {
showPagination: boolean
currentPage: number
pageSize: number
pageSizes: number[]
total: number
}
/**
* @param record
*/
export type ICreateRow = (record: ITableDataItem) => void
/**
* @param index ()
* @param newRecord
*/
export type IUpdateRow = (index: number, newRecord: ITableDataItem) => void
/**
* @param index
*/
export type IDeleteRow = (index: number) => void
export type IOnCreated = (callback: ICreateRow) => void
export interface IHandleProTableData {
createRow: ICreateRow
updatedRow: IUpdateRow
deleteRow: IDeleteRow
}

View File

@ -0,0 +1,16 @@
<config>
{
"name": "doRight",
"title": "全量确权"
}
</config>
<template>
<div>
<h1>{{ qq }}</h1>
</div>
</template>
<script setup lang="ts">
const qq = '全量确权'
</script>

View File

@ -0,0 +1,6 @@
<config>
{
"name": "globalManage",
"title": "全域监管"
}
</config>

View File

@ -0,0 +1,16 @@
<config>
{
"name": "manageConfig",
"title": "监管配置"
}
</config>
<template>
<div>
<h1>{{ jgpz }}</h1>
</div>
</template>
<script setup lang="ts">
const jgpz = '监管配置'
</script>

View File

@ -0,0 +1,16 @@
<config>
{
"name": "manageData",
"title": "监管数据"
}
</config>
<template>
<div>
<h1>{{ jgsj }}</h1>
</div>
</template>
<script setup lang="ts">
const jgsj = '监管数据'
</script>

View File

@ -0,0 +1,16 @@
<config>
{
"name": "manageTemplate",
"title": "监管模板"
}
</config>
<template>
<div>
<h1>{{ jgmb }}</h1>
</div>
</template>
<script setup lang="ts">
const jgmb = '监管模板'
</script>

View File

@ -0,0 +1,276 @@
<config>
{
"name": "manageUnion",
"title": "监管联盟"
}
</config>
<template>
<div class="all">
<div class="title">
<el-icon><home-filled /></el-icon> /
</div>
<div class="all_two">
<!-- 下拉菜单按钮 -->
<div class="menu" @click="showMenu">
<el-icon><operation /></el-icon>
{{ tree }}
<div class="line"></div>
<el-icon><arrow-down /></el-icon>
</div>
<!-- 显示的下拉选项 -->
<div v-show="isshow" class="selection">
<!-- 选项头部 -->
<div class="sel_top">
<div class="text">
<h2>选择联盟</h2>
<div class="text_a">全部</div>
</div>
<div class="del">
<el-icon
><close-bold style="width: 25px; height: 25px; color: #898a8d"
/></el-icon>
</div>
</div>
<!-- 选项头部下面的横线 -->
<div class="line_two"></div>
<!-- 横线下面的各种选项 -->
<div class="everyOperation">
<div class="operation_l">
<el-icon><avatar /></el-icon>
<span>太原市联盟</span>
</div>
<div class="operation_r">
<el-icon><circle-check-filled style="color: #2f54eb" /></el-icon>
</div>
</div>
<div class="everyOperation">
<div class="operation_l">
<el-icon><avatar /></el-icon>
<span>太原市联盟</span>
</div>
<div class="operation_r">
<el-icon><circle-check-filled style="color: #2f54eb" /></el-icon>
</div>
</div>
<div class="everyOperation">
<div class="operation_l">
<el-icon><avatar /></el-icon>
<span>太原市联盟</span>
</div>
<div class="operation_r">
<el-icon><circle-check-filled style="color: #2f54eb" /></el-icon>
</div>
</div>
<div class="everyOperation">
<div class="operation_l">
<el-icon><avatar /></el-icon>
<span>太原市联盟</span>
</div>
<div class="operation_r">
<el-icon><circle-check-filled style="color: #2f54eb" /></el-icon>
</div>
</div>
<div class="everyOperation">
<div class="operation_l">
<el-icon><avatar /></el-icon>
<span>太原市联盟</span>
</div>
<div class="operation_r">
<el-icon><circle-check-filled style="color: #2f54eb" /></el-icon>
</div>
</div>
<!-- 取消和确认按钮 -->
<div class="buttons">
<el-button>取消</el-button>
<el-button type="primary">确认</el-button>
</div>
</div>
<div class="list">
<!-- 监管联盟成员列表 -->
<div class="member_list">
<h2>监管联盟成员列表</h2>
<el-table :data="tableData" style="width: 100%">
<el-table-column prop="date" label="序号" width="180" />
<el-table-column prop="name" label="主体名称" width="180" />
<el-table-column prop="address" label="监管节点地址" />
</el-table>
</div>
<!-- 监管联盟用户列表 -->
<div class="member_list">
<h2>监管联盟用户列表</h2>
<el-table :data="tableData" style="width: 100%">
<el-table-column prop="date" label="序号" width="180" />
<el-table-column prop="name" label="主体名称" width="180" />
<el-table-column prop="address" label="用户名" />
</el-table>
</div>
</div>
</div>
</div>
</template>
<script setup lang="ts">
import {
HomeFilled,
ArrowDown,
Operation,
CloseBold,
Avatar,
CircleCheckFilled,
} from '@element-plus/icons-vue'
const isshow = ref(false)
interface User {
date: string
name: string
address: string
}
function showMenu(): any {
isshow.value = !isshow.value
if (isshow.value == false) {
tree.value = '目录结构'
} else {
tree.value = '请选择监管联盟'
}
}
const tree = ref('目录树')
const tableData = [
{
date: '2016-05-03',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-02',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-04',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-01',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
]
</script>
<style scope lang="scss">
.all {
height: 100%;
overflow: hidden;
.title {
margin: 25px 0px 30px 10px;
font-size: 14px;
color: #282b2d;
}
.all_two {
height: 100%;
padding: 0 16px 0 24px;
position: relative;
.menu {
overflow: hidden;
width: 16%;
padding: 15px 10px 15px 10px;
// height: 62px;
border-radius: 5px;
color: #fff;
text-align: center;
display: flex;
justify-content: center;
align-items: center;
background-color: rgba(0, 120, 255, 100);
.line {
margin: 0 6px 0 2px;
display: inline-block;
width: 1px;
height: 25px;
background-color: rgba(222, 222, 222, 33);
}
}
.selection {
position: absolute;
top: 70px;
left: 25px;
margin-bottom: 500px;
width: 24%;
// height: 100px;
box-shadow: 7px 0px 9px 0px rgba(111, 111, 111, 14);
padding: 15px 10px 15px 10px;
z-index: 9000;
background-color: #fff;
.sel_top {
display: flex;
justify-content: space-between;
.text {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
.text_a {
color: #2f59ee;
}
}
.del {
padding-top: 9px;
display: flex;
justify-content: center;
align-items: top;
margin-right: 10px;
}
}
.line_two {
margin-bottom: 10px;
height: 2px;
background-color: #e8e7e7;
}
.everyOperation {
border: 1px solid rgba(187, 187, 187, 100);
padding: 15px 5px 15px 5px;
border-radius: 5px;
display: flex;
justify-content: space-between;
margin-bottom: 10px;
background-color: #f7f7f7;
}
.buttons {
display: flex;
justify-content: space-around;
}
}
.list {
display: flex;
justify-content: space-between;
margin-top: 40px;
.member_list {
width: 47%;
box-shadow: 7px 0px 9px 0px rgba(111, 111, 111, 14);
font-family: 'Roboto';
border: 1px solid rgba(187, 187, 187, 100);
padding: 20px 10px 20px 10px;
h2 {
padding: 8px 5px 8px 5px;
text-align: center;
color: rgba(16, 16, 16, 100) !important;
font-weight: 700;
}
}
}
}
}
.menu .el-icon svg.icon {
width: 25px;
height: 25px;
}
.menu .el-icon {
width: 25px !important;
height: 25px !important;
margin-right: 13px !important;
}
.all .all_two .list .member_list {
padding-bottom: 500px !important;
}
</style>

View File

@ -1,35 +1,71 @@
<config>
{
"name": "index",
"title": "首页"
"name": "index",
"title": "首页"
}
</config>
<template>
<div style="padding: 32px">
<h3>fes & 拉夫德鲁</h3>
<h4>数据字典</h4>
<div v-for="item in enumsGet('status')" :key="item.key">
{{ item.value }}{{ item.key }}
</div>
<section>
计数器
<el-button @click="increment">click me{{ count }}</el-button>
</section>
</div>
<pro-table
ref="proTableRef"
:request="request"
create-text="添加"
@on-created="onCreated"
>
<pro-table-column prop="date" label="Date" width="180" />
<pro-table-column prop="name" label="Name" width="180" />
<pro-table-column prop="address" label="Address" />
<pro-table-column prop="action">
<template #default="{ deleteRow, updatedRow }">
<el-button type="text" size="small" @click.prevent="deleteRow">
Remove
</el-button>
<el-button
type="text"
size="small"
@click.prevent="
updatedRow({
name: 'update',
date: 'wiwiiw',
address: 'rtrtrttrtr',
})
"
>
update
</el-button>
</template>
</pro-table-column>
</pro-table>
</template>
<script setup lang="ts">
import { enums } from '@fesjs/fes'
import useCounterStore from '~/stores/counter'
import ProTable from '~/components/ProTable'
import ProTableColumn from '~/components/ProTable/ProTableColumn'
const store = useCounterStore()
const count = computed(() => store.clicked)
const proTableRef = ref(null)
const increment = () => {
store.clicked++
onMounted(() => {
console.log({ ...proTableRef.value }, 'ppppp')
console.log(proTableRef.value.paginationInfo)
})
const request = () => {
return new Promise((resolve) => {
setTimeout(() => {
resolve({
data: new Array(10)
.join(',')
.split(',')
.map((i, index) => ({
date: `2016-05-03${index}`,
name: `Tom${index}`,
address: 'No. 189, Grove St, Los Angeles',
})),
})
}, 1500)
})
}
const onCreated = (callback) => {
callback({ name: 'add', date: 'wiwiiw', address: 'rtrtrttrtr' })
}
const enumsGet = enums.get
</script>

View File

@ -0,0 +1,16 @@
<config>
{
"name": "levelManage",
"title": "层级管理"
}
</config>
<template>
<div>
<h1>{{ cj }}</h1>
</div>
</template>
<script setup lang="ts">
const cj = '层级管理'
</script>

View File

@ -0,0 +1,16 @@
<config>
{
"name": "networking",
"title": "数联网组网管理"
}
</config>
<template>
<div>
<h1>{{ zw }}</h1>
</div>
</template>
<script setup lang="ts">
const zw = '数联网组网管理'
</script>

View File

@ -0,0 +1,16 @@
<config>
{
"name": "unionManage",
"title": "联盟管理"
}
</config>
<template>
<div>
<h1>{{ lm }}</h1>
</div>
</template>
<script setup lang="ts">
const lm = '联盟管理'
</script>

View File

@ -0,0 +1,156 @@
<config>
{
"name": "objectSearch",
"title": "数字对象搜索"
}
</config>
<template>
<div class="all">
<!-- 小标题 -->
<div class="title">
<el-icon><home-filled /></el-icon>
</div>
<!-- "已选条件" -->
<div class="condition">
<div class="con_name">已选条件</div>
<div class="every_con">仓库IDxxx</div>
<div class="every_con">仓库IDxxx</div>
<div class="every_con">仓库IDxxx</div>
<div class="every_con">仓库IDxxx</div>
</div>
<!-- 检索结果 -->
<div class="result">
<!-- 每一条检索结果 -->
<div class="every_res">
<el-icon
><promotion style="width: 36px; height: 36px; color: #8f8f8f"
/></el-icon>
<div class="doid">doid86.5000/repo1/123</div>
<div class="detail">所属数字对象仓库ID86.5000/repo1</div>
<div class="detail">所属数字对象仓库名称太原市仓库</div>
<div class="detail">数字对象所有者太原市大数据局</div>
<div class="detail">元数据{}</div>
</div>
<div class="every_res">
<el-icon
><promotion style="width: 36px; height: 36px; color: #8f8f8f"
/></el-icon>
<div class="doid">doid86.5000/repo1/123</div>
<div class="detail">所属数字对象仓库ID86.5000/repo1</div>
<div class="detail">所属数字对象仓库名称太原市仓库</div>
<div class="detail">数字对象所有者太原市大数据局</div>
<div class="detail">元数据{}</div>
</div>
<div class="every_res">
<el-icon
><promotion style="width: 36px; height: 36px; color: #8f8f8f"
/></el-icon>
<div class="doid">doid86.5000/repo1/123</div>
<div class="detail">所属数字对象仓库ID86.5000/repo1</div>
<div class="detail">所属数字对象仓库名称太原市仓库</div>
<div class="detail">数字对象所有者太原市大数据局</div>
<div class="detail">元数据{}</div>
</div>
<div class="every_res">
<el-icon
><promotion style="width: 36px; height: 36px; color: #8f8f8f"
/></el-icon>
<div class="doid">doid86.5000/repo1/123</div>
<div class="detail">所属数字对象仓库ID86.5000/repo1</div>
<div class="detail">所属数字对象仓库名称太原市仓库</div>
<div class="detail">数字对象所有者太原市大数据局</div>
<div class="detail">元数据{}</div>
</div>
</div>
</div>
</template>
<script setup lang="ts">
import { HomeFilled, Promotion } from '@element-plus/icons-vue'
</script>
<style scope lang="scss">
.all {
overflow: hidden;
.title {
margin: 25px 0px 34px 10px;
font-size: 14px;
color: rgba(40, 43, 45, 100);
font-size: 12px;
font-family: 'SourceHanSansSC-regular';
}
.condition {
display: flex;
justify-content: space-between;
margin-bottom: 100px;
padding: 0 175px 0 55px;
.con_name {
display: flex;
justify-content: center;
align-items: center;
color: rgba(16, 16, 16, 100);
font-size: 14px;
font-family: 'SourceHanSansSC-regular';
}
.every_con {
width: 216px;
height: 34px;
line-height: 34px;
border-radius: 30px;
background-color: rgba(241, 241, 241, 100);
color: rgba(16, 16, 16, 100);
font-size: 14px;
text-align: center;
font-family: 'Roboto';
border: 1px solid rgba(187, 187, 187, 100);
}
}
.result {
display: flex;
justify-content: space-around;
flex-wrap: wrap;
margin: 0 auto;
.every_res {
width: 49%;
height: 250px;
line-height: 20px;
border-radius: 15px;
color: rgba(16, 16, 16, 100);
font-size: 14px;
text-align: center;
font-family: 'Roboto';
border: 1px solid rgba(187, 187, 187, 100);
position: relative;
padding: 7px 13px 50px 13px;
font-family: 'SourceHanSansSC-bold';
display: flex;
flex-direction: column;
justify-content: space-between;
margin-bottom: 15px;
.doid {
width: 85%;
padding: 5px 0 5px 20px;
color: rgba(16, 16, 16, 100);
font-size: 24px;
text-align: left;
font-weight: 700;
}
.detail {
color: rgba(16, 16, 16, 100);
font-size: 14px;
text-align: left;
padding-left: 20px;
}
}
}
}
.every_res svg.icon {
position: absolute;
left: 240px;
top: 14px;
}
.every_res i.el-icon {
margin-left: 52%;
}
</style>

View File

@ -0,0 +1,164 @@
<config>
{
"name": "repoDetail",
"title": "数字对象仓库详情"
}
</config>
<template>
<div class="all">
<div class="title">
<el-icon><home-filled /></el-icon> /
</div>
<!-- 白板 -->
<div class="baiban">
<!-- 太原仓库一条 -->
<div class="state">
<!-- 太原仓库标题 -->
<h2>太原仓库</h2>
<!-- 索引状态 -->
<div class="state_r">
<div>索引状态&nbsp;:&nbsp;&nbsp;&nbsp;开启</div>
<div>
<div class="green"></div>
已通过
</div>
<div>
<div class="green"></div>
在线
</div>
</div>
</div>
<!-- ID那一条 -->
<div class="data">
<div>ID: &nbsp;&nbsp;86.5000/repo1</div>
<div>所有者: &nbsp;&nbsp;太原市大数据局</div>
<div>添加时间: &nbsp;&nbsp;2021年10月20日10:30</div>
<div>操作人员: &nbsp;&nbsp;张三</div>
</div>
<!-- "说明:" -->
<div class="say">说明:</div>
<!-- 说明内容 -->
<div>
我是说明我是说明我是说明我是说明我是说明我是说明我是说明我是说明
</div>
</div>
<!-- 选项 -->
<el-tabs type="border-card">
<el-tab-pane label="DO列表">
<el-table :data="tableData" style="width: 100%">
<el-table-column prop="date" label="Date" width="180" />
<el-table-column prop="name" label="Name" width="180" />
<el-table-column prop="address" label="Address" />
</el-table>
</el-tab-pane>
<el-tab-pane label="拓扑结构">Config</el-tab-pane>
<el-tab-pane label="统计数据">Role</el-tab-pane>
</el-tabs>
<!-- 分页 -->
<div class="demo-pagination-block">
<el-pagination
v-model:currentPage="currentPage4"
:page-sizes="[100, 200, 300, 400]"
:page-size="100"
layout="total, jumper, prev, pager, next, sizes"
:total="400"
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
>
</el-pagination>
</div>
</div>
</template>
<script setup lang="ts">
import { HomeFilled } from '@element-plus/icons-vue'
const tableData = reactive([
{
date: '2016-05-03',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-02',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-04',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-01',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
])
//
const currentPage4 = ref(4)
const handleSizeChange = (val: number) => {
console.log(`${val} items per page`)
}
const handleCurrentChange = (val: number) => {
console.log(`current page: ${val}`)
}
</script>
<style lang="scss" scoped>
.all {
.title {
margin: 25px 0px 34px 10px;
font-size: 14px;
}
.baiban {
width: 1104px;
height: 183px;
border: 1px solid #ccc;
margin: 0 auto;
padding: 22px 66px 35px 28px;
box-shadow: 0px 2px 6px 0px #807d7d;
margin-bottom: 78px;
.state {
padding: 10px 0 10px 0;
overflow: hidden;
display: flex;
justify-content: space-between;
h2 {
margin: 0;
}
.state_r {
width: 30%;
display: flex;
justify-content: space-between;
div {
display: flex;
justify-content: center;
align-items: center;
}
.green {
display: inline-block;
width: 8px;
height: 8px;
margin-right: 10px;
border-radius: 50%;
background-color: #1cd74b;
}
}
}
.data {
display: flex;
justify-content: space-between;
padding-right: 132px;
}
.say {
padding: 10px 0 10px 0;
}
}
}
.el-tabs__nav-scroll {
background: #fff;
}
</style>

View File

@ -0,0 +1,476 @@
<config>
{
"name": "repoList",
"title": "数字对象仓库列表"
}
</config>
<template>
<div class="all">
<div class="title">
<el-icon><home-filled /></el-icon> /
</div>
<div class="do">
<div class="but">
<!-- 增加按钮 -->
<div class="add" @click="dialogFormVisible = true">
<el-icon class="icon"><plus /></el-icon
><el-button
type="text"
style="color: #101010 !important"
@click="dialogFormVisible = true"
>增加</el-button
>
</div>
<!-- 点击增加按钮弹出层 -->
<el-dialog
v-model="dialogFormVisible"
title="新增数字对象仓库"
width="90%"
custom-class="dialog"
>
<div class="in_dialog">
<div>
<!-- 数字对象仓库ID输入 -->
<div class="id_input">
<el-form :model="form" class="form">
<el-form-item
label="数字对象仓库ID"
:label-width="formLabelWidth"
>
<el-input v-model="form.name" autocomplete="off"></el-input>
</el-form-item>
</el-form>
<!-- "尝试连接"按钮 -->
<el-button
type="primary"
:icon="Link"
style="
height: 50px !important;
margin-left: 15px;
padding: 0 10px;
border-color: #dcdfe6;
background-color: #fff;
color: black;
"
>尝试连接</el-button
>
<el-icon class="right"
><circle-check
style="
width: 25px !important;
height: 25px !important;
color: green;
"
/></el-icon>
</div>
<!-- 名称 -->
<div class="name">
<el-form :model="form" class="form_a">
<el-form-item label="名称" :label-width="formLabelWidth">
<el-input v-model="form.name" autocomplete="off"></el-input>
</el-form-item>
</el-form>
<!-- 所有者 -->
<el-form :model="form" class="form_b">
<el-form-item label="所有者" :label-width="formLabelWidth">
<el-input v-model="form.name" autocomplete="off"></el-input>
</el-form-item>
</el-form>
<!-- 是否索引 -->
<el-form :model="form" class="form_b">
<el-form-item label="是否索引" :label-width="formLabelWidth">
<el-select v-model="value" clearable placeholder="Select">
<el-option
v-for="item in options"
:key="item.value"
:label="item.label"
:value="item.value"
>
</el-option>
</el-select>
<!-- <el-input v-model="form.name" autocomplete="off"></el-input> -->
</el-form-item>
</el-form>
</div>
<!-- 已添加的管理者 -->
<el-form :model="form" class="form_c">
<el-form-item
label="已添加的管理者"
:label-width="formLabelWidth"
>
<el-input v-model="form.name" autocomplete="off"></el-input>
</el-form-item>
</el-form>
<!-- 说明 -->
<el-form :model="form" class="form_d">
<el-form-item label="说明" :label-width="formLabelWidth">
<el-input v-model="form.name" autocomplete="off"></el-input>
</el-form-item>
</el-form>
</div>
<!-- 确定按钮 -->
<el-button
type="info"
size="medium"
plain
class="confirm"
@click="dialogFormVisible = false"
>确定</el-button
>
</div>
</el-dialog>
<!-- 删除按钮 -->
<div class="reduce">
<el-icon class="icon"><minus /></el-icon>
</div>
</div>
<!-- 搜索框 -->
<div
style="width: 375px; height: 32px; border-color: pink !important"
size="mini"
class="sousuo"
>
<el-input
v-model="input3"
placeholder="可按关键字模糊搜索"
class="input-with-select"
size="mini"
:prefix-icon="Search"
>
<template #append>
<el-select
v-model="select"
placeholder="高级搜索"
style="width: 48px"
>
<el-option label="Restaurant" value="1"></el-option>
<el-option label="Order No." value="2"></el-option>
<el-option label="Tel" value="3"></el-option>
</el-select>
</template>
</el-input>
</div>
</div>
<!-- 表格 -->
<el-table
ref="multipleTable"
:data="tableData"
style="width: 100%"
:height="400"
size="small"
>
<el-table-column type="selection" width="55" />
<el-table-column label="ID" width="120">
<template #default="scope">{{ scope.row.date }}</template>
</el-table-column>
<el-table-column property="name" label="名称" width="120" />
<el-table-column
property="address"
label="所有者"
show-overflow-tooltip
/>
</el-table>
<!-- 分页 -->
<div class="demo-pagination-block">
<el-pagination
v-model:currentPage="currentPage4"
:page-sizes="[100, 200, 300, 400]"
:page-size="100"
layout="total, jumper, prev, pager, next, sizes"
:total="400"
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
>
</el-pagination>
</div>
</div>
</template>
<script setup lang="ts">
// import { reactive, ref, toRefs } from 'vue'
import {
Search,
Plus,
Minus,
HomeFilled,
Link,
CircleCheck,
} from '@element-plus/icons-vue'
const input3 = ref('')
const select = ref('')
const tableData = reactive([
{
date: '2016-05-03',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-02',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-04',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-01',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-08',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-06',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
{
date: '2016-05-07',
name: 'Tom',
address: 'No. 189, Grove St, Los Angeles',
},
])
//
const formProps = reactive({
gridData: [
{
date: '2016-05-02',
name: 'John Smith',
address: 'No.1518, Jinshajiang Road, Putuo District',
},
{
date: '2016-05-04',
name: 'John Smith',
address: 'No.1518, Jinshajiang Road, Putuo District',
},
{
date: '2016-05-01',
name: 'John Smith',
address: 'No.1518, Jinshajiang Road, Putuo District',
},
{
date: '2016-05-03',
name: 'John Smith',
address: 'No.1518, Jinshajiang Road, Putuo District',
},
],
dialogTableVisible: false,
dialogFormVisible: false,
form: {
name: '',
region: '',
date1: '',
date2: '',
delivery: false,
type: [],
resource: '',
desc: '',
},
formLabelWidth: '120px',
})
const {
gridData,
dialogTableVisible,
dialogFormVisible,
form,
formLabelWidth,
} = toRefs(formProps)
// const multipleSelection = ref([])
const multipleTable = ref(null)
// function handleSelectionChange(val: any) {
// multipleSelection = val
// },
//
const currentPage4 = ref(4)
const handleSizeChange = (val: number) => {
console.log(`${val} items per page`)
}
const handleCurrentChange = (val: number) => {
console.log(`current page: ${val}`)
}
//el-select
const options = reactive([
{
value: 'Option1',
label: 'Option1',
},
{
value: 'Option2',
label: 'Option2',
},
{
value: 'Option3',
label: 'Option3',
},
{
value: 'Option4',
label: 'Option4',
},
{
value: 'Option5',
label: 'Option5',
},
])
const value = ref('')
</script>
<style scope lang="scss">
.all {
overflow: hidden;
.title {
margin: 25px 0px 34px 10px;
font-size: 14px;
color: rgba(40, 43, 45, 100);
font-size: 12px;
font-family: 'SourceHanSansSC-regular';
}
.do {
padding: 21px 31px 55px 10px;
box-sizing: border-box;
display: flex;
justify-content: space-between;
border-bottom: 1px solid #ccc;
box-shadow: 0px -20px 30px -30px inset #ccc;
.but {
display: flex;
justify-content: space-between;
.add,
.reduce {
// color: #101010;
display: flex;
justify-content: center;
align-items: center;
width: 126px;
height: 32px;
border: 2px solid#DDDADA;
.icon {
margin-right: 8px;
font-weight: 900;
color: #333;
}
}
.add {
margin-right: 44px;
}
.dialog {
height: 90%;
background-color: #f2f2f2;
padding: 30px;
.in_dialog {
width: 100%;
height: 100%;
margin: 0 auto;
padding: 80px 163px 172px 106px;
background-color: white;
position: relative;
.confirm {
position: absolute;
bottom: 10px;
right: 10px;
}
.id_input,
.name {
display: flex;
justify-content: space-between;
.form {
color: #101010;
}
.right {
height: 50px;
}
}
}
}
}
}
// .shadow_line {
// height: 1px;
// background-color: #ccc;
// box-shadow: 5px 8px 5px #ccc;
// }
.demo-pagination-block {
margin-top: 297px;
}
}
.input-with-select .el-input-group__prepend {
background-color: #fff;
}
.el-input__inner {
height: 32px !important;
line-height: 32px !important;
}
.ant-layout .child-layout {
background: #fff;
}
.el-table::before {
height: 0;
}
.el-dialog__body {
height: 100%;
}
.el-dialog__header {
padding: 0;
}
// element plusinput
.form input.el-input__inner {
width: 681px;
height: 50px !important;
}
.form_a input.el-input__inner,
.form_b input.el-input__inner {
width: 248px;
height: 50px !important;
}
.form_c input.el-input__inner {
height: 50px !important;
}
.form_d input.el-input__inner {
height: 200px !important;
}
.el-form-item__label {
width: 150px !important;
display: flex;
justify-content: right;
align-items: center;
color: rgba(16, 16, 16, 100);
font-size: 16px;
font-family: 'SourceHanSansSC-regular';
}
.el-dialog__title {
color: rgba(16, 16, 16, 100);
font-size: 28px;
text-align: left;
font-family: SourceHanSansSC-bold;
}
.is-leaf div.cell {
color: #101010;
font-family: 'PingFangSC-regular';
font-size: 14px;
}
.name form.form_b,
.form_a {
width: 200px !important;
}
// .el-input__inner {
// padding: 0 !important;
// }
// .all .do .but .add .icon,
// .all .do .but .reduce .icon {
// color: #101010;
// }
</style>

View File

@ -0,0 +1,16 @@
<config>
{
"name": "repoManage",
"title": "数字对象仓库管理"
}
</config>
<template>
<div>
<h1>{{ re }}</h1>
</div>
</template>
<script setup lang="ts">
const re = '数字对象仓库管理'
</script>

View File

@ -0,0 +1,16 @@
<config>
{
"name": "set_up",
"title": "设置"
}
</config>
<template>
<div>
<h1>{{ sz }}</h1>
</div>
</template>
<script setup lang="ts">
const sz = '设置'
</script>

49
src/tools/proTable.ts Normal file
View File

@ -0,0 +1,49 @@
import { ITableDataItem, IHandleProTableData } from '~/interfaces/proTable'
import { ElNotification } from 'element-plus/es'
import { Ref } from 'vue'
export class HandleProTableData implements IHandleProTableData {
updateTheView: () => void
tableData: Ref<ITableDataItem[]>
constructor(updateTheView: () => void, tableData: Ref<ITableDataItem[]>) {
this.updateTheView = updateTheView
this.tableData = tableData
}
handleError(e: unknown) {
ElNotification({
title: '提示',
message: (e as Error).message,
type: 'error',
})
}
createRow = (record: ITableDataItem) => {
try {
this.tableData.value.push(record)
this.updateTheView()
} catch (e) {
this.handleError(e)
}
}
updatedRow = (index: number, newRecord: ITableDataItem) => {
try {
this.tableData.value.splice(index, 1, newRecord)
this.updateTheView()
} catch (e) {
this.handleError(e)
}
}
deleteRow = (index: number) => {
try {
this.tableData.value.splice(index, 1)
this.updateTheView()
} catch (e) {
console.log(this)
this.handleError(e)
}
}
}

View File

@ -9,6 +9,20 @@ declare global {
const effectScope: typeof import('vue')['effectScope']
const EffectScope: typeof import('vue')['EffectScope']
const ElButton: typeof import('element-plus/es')['ElButton']
const ElConfigProvider: typeof import('element-plus/es')['ElConfigProvider']
const ElDialog: typeof import('element-plus/es')['ElDialog']
const ElForm: typeof import('element-plus/es')['ElForm']
const ElFormItem: typeof import('element-plus/es')['ElFormItem']
const ElIcon: typeof import('element-plus/es')['ElIcon']
const ElInput: typeof import('element-plus/es')['ElInput']
const ElLoadingDirective: typeof import('element-plus/es')['ElLoadingDirective']
const ElOption: typeof import('element-plus/es')['ElOption']
const ElPagination: typeof import('element-plus/es')['ElPagination']
const ElSelect: typeof import('element-plus/es')['ElSelect']
const ElTable: typeof import('element-plus/es')['ElTable']
const ElTableColumn: typeof import('element-plus/es')['ElTableColumn']
const ElTabPane: typeof import('element-plus/es')['ElTabPane']
const ElTabs: typeof import('element-plus/es')['ElTabs']
const getCurrentInstance: typeof import('vue')['getCurrentInstance']
const getCurrentScope: typeof import('vue')['getCurrentScope']
const h: typeof import('vue')['h']

View File

@ -5,10 +5,26 @@
declare module 'vue' {
export interface GlobalComponents {
ElButton: typeof import('element-plus/es')['ElButton']
IMdiAccountBox: typeof import('~icons/mdi/account-box')['default']
ElConfigProvider: typeof import('element-plus/es')['ElConfigProvider']
ElDialog: typeof import('element-plus/es')['ElDialog']
ElForm: typeof import('element-plus/es')['ElForm']
ElFormItem: typeof import('element-plus/es')['ElFormItem']
ElIcon: typeof import('element-plus/es')['ElIcon']
ElInput: typeof import('element-plus/es')['ElInput']
ElOption: typeof import('element-plus/es')['ElOption']
ElPagination: typeof import('element-plus/es')['ElPagination']
ElSelect: typeof import('element-plus/es')['ElSelect']
ElTable: typeof import('element-plus/es')['ElTable']
ElTableColumn: typeof import('element-plus/es')['ElTableColumn']
ElTabPane: typeof import('element-plus/es')['ElTabPane']
ElTabs: typeof import('element-plus/es')['ElTabs']
'IBi:questionCircle': typeof import('~icons/bi/question-circle')['default']
Loading: typeof import('element-plus/es')['ElLoadingDirective']
PageLoading: typeof import('./../components/PageLoading.vue')['default']
ProTable: typeof import('./../components/ProTable/index.vue')['default']
ProTableColumn: typeof import('./../components/ProTable/ProTableColumn.vue')['default']
UserCenter: typeof import('./../components/UserCenter.vue')['default']
}
}
export {}
export { }

View File

@ -7,7 +7,7 @@
"~/*": ["src/*"],
"@@/*": ["src/.fes/*"]
},
"types": ["node", "jest", "element-plus/global", "unplugin-icons/types/vue"]
"types": ["node", "element-plus/global", "unplugin-icons/types/vue"]
},
"include": [
"src/**/*",