引入typescript包,字段分配页面对接接口

This commit is contained in:
YUN-PC5\user 2023-09-26 17:06:39 +08:00
parent 4b55aa8d4c
commit e6a0491d57
6 changed files with 96 additions and 17 deletions

17
.vscode/settings.json vendored
View File

@ -5,11 +5,7 @@
"editor.formatOnPaste": true, "editor.formatOnPaste": true,
"editor.formatOnType": true, "editor.formatOnType": true,
// eslintvue // eslintvue
"eslint.validate": [ "eslint.validate": ["javascript", "typescript", "vue"],
"javascript",
"typescript",
"vue"
],
"[vue]": { "[vue]": {
"editor.defaultFormatter": "esbenp.prettier-vscode" "editor.defaultFormatter": "esbenp.prettier-vscode"
}, },
@ -27,7 +23,7 @@
// eslint --fix // eslint --fix
"editor.codeActionsOnSave": { "editor.codeActionsOnSave": {
"source.fixAll": true, "source.fixAll": true,
"eslint.autoFixOnSave": true, "eslint.autoFixOnSave": true
}, },
"eslint.options": { "eslint.options": {
"overrideConfig": { "overrideConfig": {
@ -49,11 +45,7 @@
}, },
"i18n-ally.displayLanguage": "zh-cn", "i18n-ally.displayLanguage": "zh-cn",
"i18n-ally.enabledParsers": ["json", "js"], "i18n-ally.enabledParsers": ["json", "js"],
"i18n-ally.localesPaths": [ "i18n-ally.localesPaths": ["src/i18n/lang", "src/i18n/pages/login", "src/i18n/pages/menu"],
"src/i18n/lang",
"src/i18n/pages/login",
"src/i18n/pages/menu",
],
"i18n-ally.extract.parsers.html": { "i18n-ally.extract.parsers.html": {
"attributes": ["text", "title", "alt", "placeholder", "label", "aria-label"], "attributes": ["text", "title", "alt", "placeholder", "label", "aria-label"],
"ignoredTags": ["script", "style"], "ignoredTags": ["script", "style"],
@ -61,4 +53,5 @@
"inlineText": true "inlineText": true
}, },
"i18n-ally.keystyle": "nested", "i18n-ally.keystyle": "nested",
} "typescript.tsdk": "node_modules/typescript/lib"
}

View File

@ -49,6 +49,7 @@
"@vue/compiler-sfc": "^3.3.4", "@vue/compiler-sfc": "^3.3.4",
"sass": "1.45.0", "sass": "1.45.0",
"tailwindcss": "^3.3.3", "tailwindcss": "^3.3.3",
"typescript": "^5.2.2",
"unplugin-auto-import": "0.5.3", "unplugin-auto-import": "0.5.3",
"vite": "^4.3.9", "vite": "^4.3.9",
"vite-plugin-compression": "^0.3.6", "vite-plugin-compression": "^0.3.6",

24
src/api/system/field.ts Normal file
View File

@ -0,0 +1,24 @@
import request from '@/utils/request'
const url = '/system/field/'
export const getModelList = () => {
return request({
url: url + 'getModelList',
method: 'get'
})
}
export const getFields = (params) => {
return request({
url: url + 'getFields',
method: 'get',
params
})
}
export const initFields = () => {
return request({
url: url + 'initFields',
method: 'post'
})
}

View File

@ -116,7 +116,7 @@ const showSettings = ref(false)
const theme = ref(settingsStore.theme) const theme = ref(settingsStore.theme)
const sideTheme = ref(settingsStore.sideTheme) const sideTheme = ref(settingsStore.sideTheme)
const storeSettings = computed(() => settingsStore) const storeSettings = computed(() => settingsStore)
const predefineColors = ref(['#409EFF', '#ff4500', '#ff8c00', '#ffd700', '#90ee90', '#00ced1', '#1e90ff', '#c71585']) const predefineColors = ref(['#409EFF', '#ff4500', '#ff8c00', '#ffd700', '#90ee90', '#00ced1', '#1e90ff', '#D59DFF', '#c71585'])
const { setWatermark, removeWatermark } = getmark() const { setWatermark, removeWatermark } = getmark()
// model.value = 'cafe' // model.value = 'cafe'
const mode = useColorMode({ const mode = useColorMode({

View File

@ -142,14 +142,14 @@
<template #footer v-if="isEdit"> <template #footer v-if="isEdit">
<el-row style="margin-top: -40px"> <el-row style="margin-top: -40px">
<el-col :span="18" style="border: 1px solid var(--el-color-primary); border-radius: 2px; padding: 10px"> <el-col :span="18" style="border: 1px solid var(--el-color-primary); border-radius: 2px; padding: 10px">
<el-text style="text-align: left"> <el-text class="text-left">
<div><b>终结点</b>{HTTP_Verb}:{PATH}您可以使用asterix符号来定位任何HTTP谓词</div> <div><b>终结点</b>{HTTP_Verb}:{PATH}您可以使用asterix符号来定位任何HTTP谓词</div>
<div>例如**:/api/values*:/api/values((post)|(put)):/api/values</div> <div>例如**:/api/values*:/api/values((post)|(put)):/api/values</div>
<div><b>期间</b>{INT}{PERIOD_TYPE}您可以使用以下期间类型之一s(), m(), h(), d()</div> <div><b>期间</b>{INT}{PERIOD_TYPE}您可以使用以下期间类型之一s(), m(), h(), d()</div>
<div><b>限制</b>{LONG}单位时间内的允许访问的次数</div> <div><b>限制</b>{LONG}单位时间内的允许访问的次数</div>
</el-text> </el-text>
</el-col> </el-col>
<el-col :span="6" style="position: absolute; bottom: 2px; right: 4px"> <el-col :span="6" style="bottom: 2px" class="absolute right-1">
<el-button @click="dialogVisible = false">{{ $t('btn.cancel') }}</el-button> <el-button @click="dialogVisible = false">{{ $t('btn.cancel') }}</el-button>
<el-button type="primary" @click="handleConfirm">{{ $t('btn.submit') }}</el-button> <el-button type="primary" @click="handleConfirm">{{ $t('btn.submit') }}</el-button>
</el-col> </el-col>

View File

@ -11,12 +11,44 @@
</template> </template>
</el-page-header> </el-page-header>
<el-divider /> <el-divider />
<el-row :gutter="10">
<el-col :span="10">
<el-card>
<template #header>
<b>模型</b>
</template>
<el-table :data="modelList" height="580" border highlight-current-row @current-change="handleCurrentChange">
<el-table-column prop="fullName" label="模型" />
</el-table>
</el-card>
</el-col>
<el-col :span="14">
<el-card>
<template #header>
<div class="flex justify-between items-center">
<b>数据字段</b>
<el-button type="primary" plain>{{ $t('btn.save') }}</el-button>
</div>
</template>
<el-table :data="fieldList" height="580" border>
<el-table-column prop="fieldName" label="字段名称" />
<el-table-column prop="fieldType" label="字段类型" />
<el-table-column prop="" label="是否授权" align="center">
<template #default="scope">
<el-switch v-model="value2" class="ml-2" style="--el-switch-on-color: #13ce66; --el-switch-off-color: #ff4949" />
</template>
</el-table-column>
</el-table>
</el-card>
</el-col>
</el-row>
</el-card> </el-card>
</div> </div>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import useTagsViewStore from '@/store/modules/tagsView.js' import useTagsViewStore from '@/store/modules/tagsView.js'
import { getModelList, initFields, getFields } from '@/api/system/field'
const router = useRouter() const router = useRouter()
const route = useRoute() const route = useRoute()
const cardLoading = ref(false) const cardLoading = ref(false)
@ -25,7 +57,36 @@ const goBack = () => {
router.push('/system/role') router.push('/system/role')
} }
console.log(route.query.roleId) console.log(route.query.roleId)
const handleInit = () => {} const handleInit = async () => {
await initFields()
}
interface model {
fullName: string
properties: field[]
}
interface field {
fieldName: string
fieldType: string
}
const modelList = ref<model[]>([])
const fieldList = ref<field[]>([])
const getList = async () => {
cardLoading.value = true
const { data } = await getModelList()
modelList.value = data
cardLoading.value = false
}
const handleCurrentChange = async (val: any) => {
const { data } = await getFields({ fullName: val.fullName })
fieldList.value = data
}
const getProperties = (row) => {
console.log(row)
}
const value2 = ref(true)
onMounted(() => {
getList()
})
</script> </script>
<style scoped></style> <style scoped lang="scss"></style>