feat: views
parent
6a2eebe486
commit
4e341517d9
|
@ -15,9 +15,7 @@
|
||||||
</template>
|
</template>
|
||||||
<Dropdown :trigger="['hover']" :dropMenuList="getDropdownList" popconfirm v-if="dropDownActions && getDropdownList.length > 0">
|
<Dropdown :trigger="['hover']" :dropMenuList="getDropdownList" popconfirm v-if="dropDownActions && getDropdownList.length > 0">
|
||||||
<slot name="more"></slot>
|
<slot name="more"></slot>
|
||||||
<a-button type="link" size="small" v-if="!$slots.more">
|
<a-button type="link" v-if="!$slots.more"> 更多<MoreOutlined class="icon-more" /> </a-button>
|
||||||
<MoreOutlined class="icon-more" />
|
|
||||||
</a-button>
|
|
||||||
</Dropdown>
|
</Dropdown>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
|
@ -36,6 +36,7 @@ export function useTableForm(
|
||||||
if (handleSearchInfoFn && isFunction(handleSearchInfoFn)) {
|
if (handleSearchInfoFn && isFunction(handleSearchInfoFn)) {
|
||||||
info = handleSearchInfoFn(info) || info
|
info = handleSearchInfoFn(info) || info
|
||||||
}
|
}
|
||||||
|
console.info(info)
|
||||||
fetch({ searchInfo: info, page: 1 })
|
fetch({ searchInfo: info, page: 1 })
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
</BasicTitle>
|
</BasicTitle>
|
||||||
<div class="flex items-center flex-1 cursor-pointer justify-self-stretch" v-if="search || toolbar">
|
<div class="flex items-center flex-1 cursor-pointer justify-self-stretch" v-if="search || toolbar">
|
||||||
<div :class="getInputSearchCls" v-if="search">
|
<div :class="getInputSearchCls" v-if="search">
|
||||||
<InputSearch :placeholder="t('common.searchText')" size="small" allowClear v-model:value="searchValue" />
|
<InputSearch :placeholder="t('common.searchText')" allowClear v-model:value="searchValue" />
|
||||||
</div>
|
</div>
|
||||||
<Dropdown @click.prevent v-if="toolbar">
|
<Dropdown @click.prevent v-if="toolbar">
|
||||||
<Icon icon="ion:ellipsis-vertical" />
|
<Icon icon="ion:ellipsis-vertical" />
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<template>
|
<template>
|
||||||
<div :class="prefixCls">
|
<div :class="prefixCls">
|
||||||
<span> {{ title }}</span>
|
<span> {{ title }}</span>
|
||||||
<InputNumber v-bind="$attrs" size="small" :class="`${prefixCls}-input-number`" @change="handleChange" />
|
<InputNumber v-bind="$attrs" :class="`${prefixCls}-input-number`" @change="handleChange" />
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script lang="ts" setup name="InputNumberItem">
|
<script lang="ts" setup name="InputNumberItem">
|
||||||
|
|
|
@ -1,14 +1,7 @@
|
||||||
<template>
|
<template>
|
||||||
<div :class="prefixCls">
|
<div :class="prefixCls">
|
||||||
<span> {{ title }}</span>
|
<span> {{ title }}</span>
|
||||||
<Select
|
<Select v-bind="getBindValue" :class="`${prefixCls}-select`" @change="handleChange as any" :disabled="disabled" :options="options" />
|
||||||
v-bind="getBindValue"
|
|
||||||
:class="`${prefixCls}-select`"
|
|
||||||
@change="handleChange as any"
|
|
||||||
:disabled="disabled"
|
|
||||||
size="small"
|
|
||||||
:options="options"
|
|
||||||
/>
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script lang="ts" setup name="SelectItem">
|
<script lang="ts" setup name="SelectItem">
|
||||||
|
|
|
@ -2,7 +2,6 @@
|
||||||
<div :class="getWrapClass">
|
<div :class="getWrapClass">
|
||||||
<Tabs
|
<Tabs
|
||||||
type="editable-card"
|
type="editable-card"
|
||||||
size="small"
|
|
||||||
:animated="false"
|
:animated="false"
|
||||||
:hideAdd="true"
|
:hideAdd="true"
|
||||||
:tabBarGutter="3"
|
:tabBarGutter="3"
|
||||||
|
|
|
@ -124,8 +124,11 @@ export class VAxios {
|
||||||
})
|
})
|
||||||
requestList = []
|
requestList = []
|
||||||
// TODO
|
// TODO
|
||||||
// res = await Promise.all([this.axiosInstance(config)])[0]
|
|
||||||
console.info('刷新令牌end', res)
|
console.info('刷新令牌end', res)
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
resolve(this.axiosInstance(config))
|
||||||
|
})
|
||||||
|
// res = await Promise.all([this.axiosInstance(config)])[0]
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.info(e)
|
console.info(e)
|
||||||
requestList.forEach((cb: any) => {
|
requestList.forEach((cb: any) => {
|
||||||
|
|
|
@ -56,7 +56,7 @@ const [registerTable, { getForm, reload }] = useTable({
|
||||||
showTableSetting: true,
|
showTableSetting: true,
|
||||||
showIndexColumn: false,
|
showIndexColumn: false,
|
||||||
actionColumn: {
|
actionColumn: {
|
||||||
width: 120,
|
width: 160,
|
||||||
title: '操作',
|
title: '操作',
|
||||||
dataIndex: 'action',
|
dataIndex: 'action',
|
||||||
fixed: 'right'
|
fixed: 'right'
|
||||||
|
|
|
@ -63,7 +63,7 @@ const [register, { expandAll, collapseAll, getForm, reload }] = useTable({
|
||||||
showIndexColumn: false,
|
showIndexColumn: false,
|
||||||
canResize: false,
|
canResize: false,
|
||||||
actionColumn: {
|
actionColumn: {
|
||||||
width: 120,
|
width: 160,
|
||||||
title: '操作',
|
title: '操作',
|
||||||
dataIndex: 'action',
|
dataIndex: 'action',
|
||||||
fixed: 'right'
|
fixed: 'right'
|
||||||
|
|
|
@ -53,7 +53,7 @@ const [registerTable, { reload }] = useTable({
|
||||||
showTableSetting: true,
|
showTableSetting: true,
|
||||||
showIndexColumn: false,
|
showIndexColumn: false,
|
||||||
actionColumn: {
|
actionColumn: {
|
||||||
width: 120,
|
width: 160,
|
||||||
title: '操作',
|
title: '操作',
|
||||||
dataIndex: 'action',
|
dataIndex: 'action',
|
||||||
fixed: 'right'
|
fixed: 'right'
|
||||||
|
|
|
@ -1,3 +1,43 @@
|
||||||
<template>
|
<template>
|
||||||
<div>开发中</div>
|
<div>
|
||||||
|
<BasicTable @register="registerTable">
|
||||||
|
<template #toolbar>
|
||||||
|
<a-button type="warning" @click="handleExport"> 导出 </a-button>
|
||||||
|
</template>
|
||||||
|
</BasicTable>
|
||||||
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
<script lang="ts" setup name="OperateLog">
|
||||||
|
import { BasicTable, useTable } from '@/components/Table'
|
||||||
|
import { OperateLogPageReqVO, exportOperateLogApi, getOperateLogPageApi } from '@/api/system/operatelog'
|
||||||
|
import { columns, searchFormSchema } from './operateLog.data'
|
||||||
|
import { useI18n } from '@/hooks/web/useI18n'
|
||||||
|
import { useMessage } from '@/hooks/web/useMessage'
|
||||||
|
|
||||||
|
const { t } = useI18n()
|
||||||
|
const { createConfirm, createMessage } = useMessage()
|
||||||
|
const [registerTable, { getForm }] = useTable({
|
||||||
|
title: '操作日志列表',
|
||||||
|
api: getOperateLogPageApi,
|
||||||
|
columns,
|
||||||
|
formConfig: {
|
||||||
|
labelWidth: 120,
|
||||||
|
schemas: searchFormSchema
|
||||||
|
},
|
||||||
|
useSearchForm: true,
|
||||||
|
showTableSetting: true,
|
||||||
|
showIndexColumn: false
|
||||||
|
})
|
||||||
|
|
||||||
|
async function handleExport() {
|
||||||
|
createConfirm({
|
||||||
|
title: '导出',
|
||||||
|
iconType: 'warning',
|
||||||
|
content: '是否要导出数据?',
|
||||||
|
async onOk() {
|
||||||
|
await exportOperateLogApi(getForm().getFieldsValue() as OperateLogPageReqVO)
|
||||||
|
createMessage.success(t('common.exportSuccessText'))
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
</script>
|
||||||
|
|
|
@ -0,0 +1,106 @@
|
||||||
|
import { getIntDictOptions } from './../../../utils/dict'
|
||||||
|
import { BasicColumn, FormSchema, useRender } from '@/components/Table'
|
||||||
|
import { DICT_TYPE } from '@/utils/dict'
|
||||||
|
import { h } from 'vue'
|
||||||
|
|
||||||
|
export const columns: BasicColumn[] = [
|
||||||
|
{
|
||||||
|
title: '日志编号',
|
||||||
|
dataIndex: 'id',
|
||||||
|
width: 100
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '操作模块',
|
||||||
|
dataIndex: 'module',
|
||||||
|
width: 120
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '操作名',
|
||||||
|
dataIndex: 'name',
|
||||||
|
width: 180
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '操作类型',
|
||||||
|
dataIndex: 'type',
|
||||||
|
width: 180,
|
||||||
|
customRender: ({ text }) => {
|
||||||
|
return useRender.renderDict(text, DICT_TYPE.SYSTEM_OPERATE_TYPE)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '操作人',
|
||||||
|
dataIndex: 'userNickname',
|
||||||
|
width: 120
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: 'userAgent',
|
||||||
|
dataIndex: 'userAgent',
|
||||||
|
width: 400
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '操作结果',
|
||||||
|
dataIndex: 'resultCode',
|
||||||
|
width: 180,
|
||||||
|
customRender: ({ text }) => {
|
||||||
|
return h('span', text === 0 ? '成功' : '失败')
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '操作日期',
|
||||||
|
dataIndex: 'startTime',
|
||||||
|
width: 180,
|
||||||
|
customRender: ({ text }) => {
|
||||||
|
return useRender.renderDate(text)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: '执行时长',
|
||||||
|
dataIndex: 'duration',
|
||||||
|
width: 180,
|
||||||
|
customRender: ({ text }) => {
|
||||||
|
return h('span', text + 'ms')
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
export const searchFormSchema: FormSchema[] = [
|
||||||
|
{
|
||||||
|
label: '系统模块',
|
||||||
|
field: 'title',
|
||||||
|
component: 'Input',
|
||||||
|
colProps: { span: 8 }
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: '操作人员',
|
||||||
|
field: 'operName',
|
||||||
|
component: 'Input',
|
||||||
|
colProps: { span: 8 }
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: '类型',
|
||||||
|
field: 'type',
|
||||||
|
component: 'Select',
|
||||||
|
componentProps: {
|
||||||
|
options: getIntDictOptions(DICT_TYPE.SYSTEM_OPERATE_TYPE)
|
||||||
|
},
|
||||||
|
colProps: { span: 8 }
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: '状态',
|
||||||
|
field: 'success',
|
||||||
|
component: 'Select',
|
||||||
|
componentProps: {
|
||||||
|
options: [
|
||||||
|
{ value: true, key: true, label: '成功' },
|
||||||
|
{ value: false, key: false, label: '失败' }
|
||||||
|
]
|
||||||
|
},
|
||||||
|
colProps: { span: 8 }
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: '操作时间',
|
||||||
|
field: 'startTime',
|
||||||
|
component: 'RangePicker',
|
||||||
|
colProps: { span: 8 }
|
||||||
|
}
|
||||||
|
]
|
|
@ -56,7 +56,7 @@ const [registerTable, { getForm, reload }] = useTable({
|
||||||
showTableSetting: true,
|
showTableSetting: true,
|
||||||
showIndexColumn: false,
|
showIndexColumn: false,
|
||||||
actionColumn: {
|
actionColumn: {
|
||||||
width: 120,
|
width: 160,
|
||||||
title: '操作',
|
title: '操作',
|
||||||
dataIndex: 'action',
|
dataIndex: 'action',
|
||||||
fixed: 'right'
|
fixed: 'right'
|
||||||
|
|
|
@ -13,7 +13,9 @@
|
||||||
icon: 'clarity:note-edit-line',
|
icon: 'clarity:note-edit-line',
|
||||||
label: '修改',
|
label: '修改',
|
||||||
onClick: handleEdit.bind(null, record)
|
onClick: handleEdit.bind(null, record)
|
||||||
},
|
}
|
||||||
|
]"
|
||||||
|
:dropDownActions="[
|
||||||
{
|
{
|
||||||
icon: 'clarity:note-edit-line',
|
icon: 'clarity:note-edit-line',
|
||||||
label: '菜单权限',
|
label: '菜单权限',
|
||||||
|
@ -66,7 +68,7 @@ const [registerTable, { getForm, reload }] = useTable({
|
||||||
showTableSetting: true,
|
showTableSetting: true,
|
||||||
showIndexColumn: false,
|
showIndexColumn: false,
|
||||||
actionColumn: {
|
actionColumn: {
|
||||||
width: 240,
|
width: 160,
|
||||||
title: '操作',
|
title: '操作',
|
||||||
dataIndex: 'action',
|
dataIndex: 'action',
|
||||||
fixed: 'right'
|
fixed: 'right'
|
||||||
|
|
|
@ -61,7 +61,7 @@ const [registerTable, { getForm, reload }] = useTable({
|
||||||
showTableSetting: true,
|
showTableSetting: true,
|
||||||
showIndexColumn: false,
|
showIndexColumn: false,
|
||||||
actionColumn: {
|
actionColumn: {
|
||||||
width: 120,
|
width: 160,
|
||||||
title: '操作',
|
title: '操作',
|
||||||
dataIndex: 'action',
|
dataIndex: 'action',
|
||||||
fixed: 'right'
|
fixed: 'right'
|
||||||
|
|
|
@ -30,7 +30,7 @@
|
||||||
</template>
|
</template>
|
||||||
</template>
|
</template>
|
||||||
</BasicTable>
|
</BasicTable>
|
||||||
<UserModel @register="registerModal" @success="handleSuccess" />
|
<UserModel @register="registerModal" @success="reload()" />
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script lang="ts" setup name="User">
|
<script lang="ts" setup name="User">
|
||||||
|
@ -49,7 +49,7 @@ const { createConfirm, createMessage } = useMessage()
|
||||||
const [registerModal, { openModal }] = useModal()
|
const [registerModal, { openModal }] = useModal()
|
||||||
const searchInfo = reactive<Recordable>({})
|
const searchInfo = reactive<Recordable>({})
|
||||||
|
|
||||||
const [registerTable, { getForm, reload, updateTableDataRecord }] = useTable({
|
const [registerTable, { getForm, reload }] = useTable({
|
||||||
title: '账号列表',
|
title: '账号列表',
|
||||||
api: getUserPageApi,
|
api: getUserPageApi,
|
||||||
columns,
|
columns,
|
||||||
|
@ -62,7 +62,7 @@ const [registerTable, { getForm, reload, updateTableDataRecord }] = useTable({
|
||||||
showTableSetting: true,
|
showTableSetting: true,
|
||||||
showIndexColumn: false,
|
showIndexColumn: false,
|
||||||
actionColumn: {
|
actionColumn: {
|
||||||
width: 120,
|
width: 160,
|
||||||
title: '操作',
|
title: '操作',
|
||||||
dataIndex: 'action',
|
dataIndex: 'action',
|
||||||
fixed: 'right'
|
fixed: 'right'
|
||||||
|
@ -100,17 +100,6 @@ async function handleDelete(record: Recordable) {
|
||||||
reload()
|
reload()
|
||||||
}
|
}
|
||||||
|
|
||||||
function handleSuccess({ isUpdate, values }) {
|
|
||||||
if (isUpdate) {
|
|
||||||
// 演示不刷新表格直接更新内部数据。
|
|
||||||
// 注意:updateTableDataRecord要求表格的rowKey属性为string并且存在于每一行的record的keys中
|
|
||||||
const result = updateTableDataRecord(values.id, values)
|
|
||||||
console.log(result)
|
|
||||||
} else {
|
|
||||||
reload()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function handleSelect(deptId = '') {
|
function handleSelect(deptId = '') {
|
||||||
searchInfo.deptId = deptId
|
searchInfo.deptId = deptId
|
||||||
reload()
|
reload()
|
||||||
|
|
|
@ -73,6 +73,9 @@ export const searchFormSchema: FormSchema[] = [
|
||||||
label: '创建时间',
|
label: '创建时间',
|
||||||
field: 'createTime',
|
field: 'createTime',
|
||||||
component: 'RangePicker',
|
component: 'RangePicker',
|
||||||
|
componentProps: {
|
||||||
|
format: 'YYYY-MM-DD HH:mm:ss'
|
||||||
|
},
|
||||||
colProps: { span: 8 }
|
colProps: { span: 8 }
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@ -121,7 +124,7 @@ export const formSchema: FormSchema[] = [
|
||||||
label: '用户名称',
|
label: '用户名称',
|
||||||
field: 'username',
|
field: 'username',
|
||||||
component: 'Input',
|
component: 'Input',
|
||||||
ifShow: ({ values }) => values.id === undefined
|
dynamicDisabled: ({ values }) => values.id !== undefined
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
label: '用户密码',
|
label: '用户密码',
|
||||||
|
@ -144,7 +147,8 @@ export const formSchema: FormSchema[] = [
|
||||||
componentProps: {
|
componentProps: {
|
||||||
api: () => listSimplePostsApi(),
|
api: () => listSimplePostsApi(),
|
||||||
labelField: 'name',
|
labelField: 'name',
|
||||||
valueField: 'id'
|
valueField: 'id',
|
||||||
|
mode: 'tags'
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in New Issue