This commit is contained in:
AN
2025-07-08 22:18:32 +08:00
8 changed files with 73 additions and 34 deletions

View File

@ -28,7 +28,9 @@ const accept = computed(() => (props.uploadType === 'file' ? AcceptType.File : A
const fileList = ref<UploadFileInfo[]>([]);
function handleUpdateModelWhenUpload() {}
function handleUpdateModelWhenUpload() {
fileList.value = [];
}
function closeDrawer() {
visible.value = false;

View File

@ -273,7 +273,7 @@ function handleAuthUser(row: Api.System.Role) {
:data="data"
size="small"
:flex-height="!appStore.isMobile"
:scroll-x="962"
:scroll-x="1200"
:loading="loading"
remote
:row-key="row => row.roleId"

View File

@ -1,5 +1,6 @@
<script setup lang="tsx">
import { computed, watch } from 'vue';
import { computed, ref, watch } from 'vue';
import { NDatePicker } from 'naive-ui';
import { fetchGetRoleUserList, fetchGetUserList } from '@/service/api/system';
import { useAppStore } from '@/store/modules/app';
import { useDict } from '@/hooks/business/dict';
@ -133,6 +134,22 @@ watch(visible, () => {
handleUpdateModelWhenEdit();
}
});
const dateRangeCreateTime = ref<[string, string] | null>(null);
const datePickerRef = ref<InstanceType<typeof NDatePicker>>();
function onDateRangeCreateTimeUpdate(value: [string, string] | null) {
if (value?.length) {
searchParams.params!.beginTime = value[0];
searchParams.params!.endTime = value[1];
}
}
function reset() {
dateRangeCreateTime.value = null;
resetSearchParams();
}
</script>
<template>
@ -158,9 +175,22 @@ watch(visible, () => {
<NFormItemGi span="24 s:12 m:8" label="手机号码" path="phonenumber" class="pr-24px">
<NInput v-model:value="searchParams.phonenumber" placeholder="请输入手机号码" />
</NFormItemGi>
<NFormItemGi span="24 s:12 m:24" class="pr-24px" :show-feedback="false">
<NFormItemGi span="24 s:12 m:8" label="所属部门" path="deptId" class="pr-24px">
<DeptTreeSelect v-model:value="searchParams.deptId" placeholder="请选择部门" />
</NFormItemGi>
<NFormItemGi span="24 s:12 m:10" label="创建时间" path="createTime" class="pr-24px">
<NDatePicker
ref="datePickerRef"
v-model:formatted-value="dateRangeCreateTime"
type="datetimerange"
value-format="yyyy-MM-dd HH:mm:ss"
clearable
@update:formatted-value="onDateRangeCreateTimeUpdate"
/>
</NFormItemGi>
<NFormItemGi span="24 s:12 m:6" class="pr-24px" :show-feedback="false">
<NSpace class="w-full" justify="end">
<NButton @click="resetSearchParams">
<NButton @click="reset">
<template #icon>
<icon-ic-round-refresh class="text-icon" />
</template>

View File

@ -142,8 +142,12 @@ watch(visible, () => {
<div class="flex-center">
<NCheckbox v-model="data.updateSupport">{{ $t('common.updateExisting') }}</NCheckbox>
</div>
<NAlert v-if="message" :title="$t('common.importResult')" :type="success ? 'success' : 'error'" :bordered="false">
{{ message }}
<NScrollbar class="max-h-200px">
<!-- eslint-disable-next-line vue/no-v-html -->
<span v-html="message" />
</NScrollbar>
</NAlert>
<template #footer>
<NSpace justify="end" :size="16">

View File

@ -65,14 +65,15 @@ function createDefaultModel(): Model {
};
}
type RuleKey = Extract<keyof Model, 'userName' | 'nickName' | 'password' | 'status' | 'phonenumber'>;
type RuleKey = Extract<keyof Model, 'userName' | 'nickName' | 'password' | 'status' | 'phonenumber' | 'roleIds'>;
const rules: Record<RuleKey, App.Global.FormRule[]> = {
userName: [createRequiredRule($t('page.system.user.form.userName.required'))],
nickName: [createRequiredRule($t('page.system.user.form.nickName.required'))],
password: [{ ...patternRules.pwd, required: props.operateType === 'add' }],
phonenumber: [patternRules.phone],
status: [createRequiredRule($t('page.system.user.form.status.required'))]
status: [createRequiredRule($t('page.system.user.form.status.required'))],
roleIds: [{ ...createRequiredRule('请选择角色'), type: 'array' }]
};
async function getUserInfo() {