forked from iod/cpnode-front
Compare commits
2 Commits
master
...
feat/route
Author | SHA1 | Date | |
---|---|---|---|
|
6926fbd9b7 | ||
|
0ffa5598ff |
57
.fes.js
57
.fes.js
@ -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
145
et --hard
Normal file
@ -0,0 +1,145 @@
|
||||
[33mcommit 5a51c860ea375760c7052f7a29f4365502ecd70f[m[33m ([m[1;36mHEAD -> [m[1;32mfeat/router[m[33m, [m[1;31morigin/master[m[33m, [m[1;31morigin/feat/repoManage-a[m[33m, [m[1;31morigin/HEAD[m[33m, [m[1;32mmaster[m[33m, [m[1;32mfeat/repoManage-a[m[33m)[m
|
||||
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
|
||||
|
||||
[33mcommit da0d0a651303fc87be23094f2067e174dc5fb2f7[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Tue Dec 28 18:37:34 2021 +0800
|
||||
|
||||
feat: add Pinia
|
||||
|
||||
[33mcommit 126d430ef34917d5d5a3223d51943b3a14017a56[m
|
||||
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
|
||||
|
||||
[33mcommit 1d16701350d9d97757eb25f7f803454d28bd2cc5[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Tue Dec 28 12:20:01 2021 +0800
|
||||
|
||||
docs: links
|
||||
|
||||
[33mcommit 991bac123100b8862db757388f0e616fab0bdede[m[33m ([m[1;31morigin/feat/router[m[33m)[m
|
||||
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
|
||||
|
||||
[33mcommit 751b9e7b3be6a4e968f3260233c4d8522566834f[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Tue Dec 28 09:41:13 2021 +0800
|
||||
|
||||
chore: update fes.js deps
|
||||
|
||||
[33mcommit 6e4869dae154db040903a0f9c12b6b6526b69c3b[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 23:33:58 2021 +0800
|
||||
|
||||
chore: setup commitlint and commitizen
|
||||
|
||||
[33mcommit cd3ad4ef78b116d640b1b5ecb2e1cd13ad685e15[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 22:09:26 2021 +0800
|
||||
|
||||
chore: init from starter template
|
||||
|
||||
[33mcommit 80715dc6bd36bcdbd421ab963b329e83f64b0a45[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 21:54:25 2021 +0800
|
||||
|
||||
style: move <config> block to top
|
||||
|
||||
[33mcommit 4c7482cef892b1ee806b77cadc7e9284c3dd9a07[m
|
||||
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
|
||||
|
||||
[33mcommit 373d34df9f988264ae0910e243231b450f0934dd[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 19:37:31 2021 +0800
|
||||
|
||||
feat: switch to Element Plus
|
||||
|
||||
[33mcommit a9b2b816f82020a2f91cdab59d094d6236c2aeff[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 19:23:47 2021 +0800
|
||||
|
||||
feat: add unplugin-vue-components
|
||||
|
||||
[33mcommit 545ef5b0ddf63c8a6bdb77e582ee00530b49ce7b[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 19:07:17 2021 +0800
|
||||
|
||||
feat: add unplugin-auto-imports
|
||||
|
||||
[33mcommit 3fa72dc0fca5f1122b705c2a8e410e57a16f1e6c[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 17:41:26 2021 +0800
|
||||
|
||||
docs: update README
|
||||
|
||||
[33mcommit d7dc53640b01c1422f85b1c03b80938b3fe7f4f7[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 17:37:41 2021 +0800
|
||||
|
||||
feat: add eslint-webpack-plugin
|
||||
|
||||
[33mcommit d848c6934c3d000e2a99c6fa8cd596fe6fe4e596[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 17:31:15 2021 +0800
|
||||
|
||||
docs: update README
|
||||
|
||||
[33mcommit 36ff5aff2bdf62ff48f044a85701b23f7e3afc8c[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 17:23:55 2021 +0800
|
||||
|
||||
fix: add TypeScript to devDependencies
|
||||
|
||||
[33mcommit 32d835ff27e141a1ee565a998cae81974467af15[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 16:14:28 2021 +0800
|
||||
|
||||
chore: add husky and lint-staged
|
||||
|
||||
[33mcommit 4908523bc41e9bcdac15720c18dd5cce1a704553[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 16:00:29 2021 +0800
|
||||
|
||||
chore: add recommended VSCode extensions
|
||||
|
||||
[33mcommit b43eac82ada23e4fd4d97f100024bf64f3362497[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 15:34:51 2021 +0800
|
||||
|
||||
docs: README
|
||||
|
||||
[33mcommit 808ee936138c8d1a50e3bd576889edc852c7f4dd[m
|
||||
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
|
||||
|
||||
[33mcommit 6382f68efd5a460b9ed4c794c1e4c007a2792021[m
|
||||
Author: Nex Zhu <4370605+NexZhu@users.noreply.github.com>
|
||||
Date: Mon Dec 27 15:06:11 2021 +0800
|
||||
|
||||
feat: add alias: `~` -> `src`
|
||||
|
||||
[33mcommit a7c776a85ef1e9626ac3c51a00e0bf5b73364ec9[m
|
||||
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
|
||||
|
||||
[33mcommit bc6bc455d8842d3bb4fd34266bcbbbc89fb5d1b3[m
|
||||
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
14353
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
@ -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",
|
||||
|
@ -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>
|
||||
|
39
src/components/ProTable/ProTableColumn.vue
Normal file
39
src/components/ProTable/ProTableColumn.vue
Normal 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>-->
|
171
src/components/ProTable/index.vue
Normal file
171
src/components/ProTable/index.vue
Normal 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>
|
@ -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>
|
||||
|
8
src/constants/proTable.ts
Normal file
8
src/constants/proTable.ts
Normal 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
0
src/icons/question.svg
Normal file
33
src/interfaces/proTable.ts
Normal file
33
src/interfaces/proTable.ts
Normal 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
|
||||
}
|
16
src/pages/doRight/doRight.vue
Normal file
16
src/pages/doRight/doRight.vue
Normal file
@ -0,0 +1,16 @@
|
||||
<config>
|
||||
{
|
||||
"name": "doRight",
|
||||
"title": "全量确权"
|
||||
}
|
||||
</config>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<h1>{{ qq }}</h1>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
const qq = '全量确权'
|
||||
</script>
|
6
src/pages/globalManage/globalManage.vue
Normal file
6
src/pages/globalManage/globalManage.vue
Normal file
@ -0,0 +1,6 @@
|
||||
<config>
|
||||
{
|
||||
"name": "globalManage",
|
||||
"title": "全域监管"
|
||||
}
|
||||
</config>
|
16
src/pages/globalManage/manageConfig.vue
Normal file
16
src/pages/globalManage/manageConfig.vue
Normal file
@ -0,0 +1,16 @@
|
||||
<config>
|
||||
{
|
||||
"name": "manageConfig",
|
||||
"title": "监管配置"
|
||||
}
|
||||
</config>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<h1>{{ jgpz }}</h1>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
const jgpz = '监管配置'
|
||||
</script>
|
16
src/pages/globalManage/manageData.vue
Normal file
16
src/pages/globalManage/manageData.vue
Normal file
@ -0,0 +1,16 @@
|
||||
<config>
|
||||
{
|
||||
"name": "manageData",
|
||||
"title": "监管数据"
|
||||
}
|
||||
</config>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<h1>{{ jgsj }}</h1>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
const jgsj = '监管数据'
|
||||
</script>
|
16
src/pages/globalManage/manageTemplate.vue
Normal file
16
src/pages/globalManage/manageTemplate.vue
Normal file
@ -0,0 +1,16 @@
|
||||
<config>
|
||||
{
|
||||
"name": "manageTemplate",
|
||||
"title": "监管模板"
|
||||
}
|
||||
</config>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<h1>{{ jgmb }}</h1>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
const jgmb = '监管模板'
|
||||
</script>
|
276
src/pages/globalManage/manageUnion.vue
Normal file
276
src/pages/globalManage/manageUnion.vue
Normal 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>
|
@ -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>
|
||||
|
16
src/pages/networking/levelManage.vue
Normal file
16
src/pages/networking/levelManage.vue
Normal file
@ -0,0 +1,16 @@
|
||||
<config>
|
||||
{
|
||||
"name": "levelManage",
|
||||
"title": "层级管理"
|
||||
}
|
||||
</config>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<h1>{{ cj }}</h1>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
const cj = '层级管理'
|
||||
</script>
|
16
src/pages/networking/networking.vue
Normal file
16
src/pages/networking/networking.vue
Normal file
@ -0,0 +1,16 @@
|
||||
<config>
|
||||
{
|
||||
"name": "networking",
|
||||
"title": "数联网组网管理"
|
||||
}
|
||||
</config>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<h1>{{ zw }}</h1>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
const zw = '数联网组网管理'
|
||||
</script>
|
16
src/pages/networking/unionManage.vue
Normal file
16
src/pages/networking/unionManage.vue
Normal file
@ -0,0 +1,16 @@
|
||||
<config>
|
||||
{
|
||||
"name": "unionManage",
|
||||
"title": "联盟管理"
|
||||
}
|
||||
</config>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<h1>{{ lm }}</h1>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
const lm = '联盟管理'
|
||||
</script>
|
156
src/pages/objectSearch/objectSearch.vue
Normal file
156
src/pages/objectSearch/objectSearch.vue
Normal 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">仓库ID:xxx</div>
|
||||
<div class="every_con">仓库ID:xxx</div>
|
||||
<div class="every_con">仓库ID:xxx</div>
|
||||
<div class="every_con">仓库ID:xxx</div>
|
||||
</div>
|
||||
<!-- 检索结果 -->
|
||||
<div class="result">
|
||||
<!-- 每一条检索结果 -->
|
||||
<div class="every_res">
|
||||
<el-icon
|
||||
><promotion style="width: 36px; height: 36px; color: #8f8f8f"
|
||||
/></el-icon>
|
||||
<div class="doid">doid:86.5000/repo1/123</div>
|
||||
<div class="detail">所属数字对象仓库ID:86.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">doid:86.5000/repo1/123</div>
|
||||
<div class="detail">所属数字对象仓库ID:86.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">doid:86.5000/repo1/123</div>
|
||||
<div class="detail">所属数字对象仓库ID:86.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">doid:86.5000/repo1/123</div>
|
||||
<div class="detail">所属数字对象仓库ID:86.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>
|
164
src/pages/repoManage/repoDetail.vue
Normal file
164
src/pages/repoManage/repoDetail.vue
Normal 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>索引状态 : 开启</div>
|
||||
<div>
|
||||
<div class="green"></div>
|
||||
已通过
|
||||
</div>
|
||||
<div>
|
||||
<div class="green"></div>
|
||||
在线
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!-- ID那一条 -->
|
||||
<div class="data">
|
||||
<div>ID: 86.5000/repo1</div>
|
||||
<div>所有者: 太原市大数据局</div>
|
||||
<div>添加时间: 2021年10月20日10:30</div>
|
||||
<div>操作人员: 张三</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>
|
476
src/pages/repoManage/repoList.vue
Normal file
476
src/pages/repoManage/repoList.vue
Normal 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 plus中的input的样式
|
||||
.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>
|
16
src/pages/repoManage/repoManage.vue
Normal file
16
src/pages/repoManage/repoManage.vue
Normal file
@ -0,0 +1,16 @@
|
||||
<config>
|
||||
{
|
||||
"name": "repoManage",
|
||||
"title": "数字对象仓库管理"
|
||||
}
|
||||
</config>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<h1>{{ re }}</h1>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
const re = '数字对象仓库管理'
|
||||
</script>
|
16
src/pages/set_up/set_up.vue
Normal file
16
src/pages/set_up/set_up.vue
Normal 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
49
src/tools/proTable.ts
Normal 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)
|
||||
}
|
||||
}
|
||||
}
|
14
src/types/auto-imports.d.ts
vendored
14
src/types/auto-imports.d.ts
vendored
@ -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']
|
||||
|
20
src/types/components.d.ts
vendored
20
src/types/components.d.ts
vendored
@ -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 { }
|
||||
|
@ -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/**/*",
|
||||
|
Loading…
Reference in New Issue
Block a user