mirror of
https://github.com/pure-admin/vue-pure-admin.git
synced 2025-06-06 08:27:54 +08:00
156 lines
4.0 KiB
Vue
156 lines
4.0 KiB
Vue
<script setup lang="ts">
|
||
import { ref } from "vue";
|
||
import { formRules } from "./rule";
|
||
import ReCol from "@/components/ReCol";
|
||
import { usePublicHooks } from "../hooks";
|
||
|
||
/** TODO
|
||
* 针对类型的props/emit声明,vue3.3.0版本以下不支持复杂的类型和从其他文件进行类型导入,等后续vue正式发布3.3.0版本再优化
|
||
* https://cn.vuejs.org/api/sfc-script-setup.html#typescript-only-features
|
||
*/
|
||
interface FormProps {
|
||
formInline: {
|
||
higherDeptOptions: Record<string, unknown>[];
|
||
parentId: number;
|
||
name: string;
|
||
principal: string;
|
||
phone: string | number;
|
||
email: string;
|
||
sort: number;
|
||
status: number;
|
||
remark: string;
|
||
};
|
||
}
|
||
|
||
const props = withDefaults(defineProps<FormProps>(), {
|
||
formInline: () => ({
|
||
higherDeptOptions: [],
|
||
parentId: 0,
|
||
name: "",
|
||
principal: "",
|
||
phone: "",
|
||
email: "",
|
||
sort: 0,
|
||
status: 1,
|
||
remark: ""
|
||
})
|
||
});
|
||
|
||
const ruleFormRef = ref();
|
||
const { switchStyle } = usePublicHooks();
|
||
const newFormInline = ref(props.formInline);
|
||
|
||
function getRef() {
|
||
return ruleFormRef.value;
|
||
}
|
||
|
||
defineExpose({ getRef });
|
||
</script>
|
||
|
||
<template>
|
||
<el-form
|
||
ref="ruleFormRef"
|
||
:model="newFormInline"
|
||
:rules="formRules"
|
||
label-width="82px"
|
||
>
|
||
<el-row :gutter="30">
|
||
<re-col>
|
||
<el-form-item label="上级部门">
|
||
<el-cascader
|
||
class="w-full"
|
||
v-model="newFormInline.parentId"
|
||
:options="newFormInline.higherDeptOptions"
|
||
:props="{
|
||
value: 'id',
|
||
label: 'name',
|
||
emitPath: false,
|
||
checkStrictly: true
|
||
}"
|
||
clearable
|
||
filterable
|
||
placeholder="请选择上级部门"
|
||
>
|
||
<template #default="{ node, data }">
|
||
<span>{{ data.name }}</span>
|
||
<span v-if="!node.isLeaf"> ({{ data.children.length }}) </span>
|
||
</template>
|
||
</el-cascader>
|
||
</el-form-item>
|
||
</re-col>
|
||
|
||
<re-col :value="12" :xs="24" :sm="24">
|
||
<el-form-item label="部门名称" prop="name">
|
||
<el-input
|
||
v-model="newFormInline.name"
|
||
clearable
|
||
placeholder="请输入部门名称"
|
||
/>
|
||
</el-form-item>
|
||
</re-col>
|
||
<re-col :value="12" :xs="24" :sm="24">
|
||
<el-form-item label="部门负责人">
|
||
<el-input
|
||
v-model="newFormInline.principal"
|
||
clearable
|
||
placeholder="请输入部门负责人"
|
||
/>
|
||
</el-form-item>
|
||
</re-col>
|
||
|
||
<re-col :value="12" :xs="24" :sm="24">
|
||
<el-form-item label="手机号" prop="phone">
|
||
<el-input
|
||
v-model="newFormInline.phone"
|
||
clearable
|
||
placeholder="请输入手机号"
|
||
/>
|
||
</el-form-item>
|
||
</re-col>
|
||
<re-col :value="12" :xs="24" :sm="24">
|
||
<el-form-item label="邮箱" prop="email">
|
||
<el-input
|
||
v-model="newFormInline.email"
|
||
clearable
|
||
placeholder="请输入邮箱"
|
||
/>
|
||
</el-form-item>
|
||
</re-col>
|
||
|
||
<re-col :value="12" :xs="24" :sm="24">
|
||
<el-form-item label="排序">
|
||
<el-input-number
|
||
v-model="newFormInline.sort"
|
||
:min="0"
|
||
:max="9999"
|
||
controls-position="right"
|
||
/>
|
||
</el-form-item>
|
||
</re-col>
|
||
<re-col :value="12" :xs="24" :sm="24">
|
||
<el-form-item label="部门状态">
|
||
<el-switch
|
||
v-model="newFormInline.status"
|
||
inline-prompt
|
||
:active-value="1"
|
||
:inactive-value="0"
|
||
active-text="启用"
|
||
inactive-text="停用"
|
||
:style="switchStyle"
|
||
/>
|
||
</el-form-item>
|
||
</re-col>
|
||
|
||
<re-col>
|
||
<el-form-item label="备注">
|
||
<el-input
|
||
v-model="newFormInline.remark"
|
||
placeholder="请输入备注信息"
|
||
type="textarea"
|
||
/>
|
||
</el-form-item>
|
||
</re-col>
|
||
</el-row>
|
||
</el-form>
|
||
</template>
|