123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- <template>
- <a-spin :spinning="confirmLoading">
- <a-form ref="formRef" class="antd-modal-form" :labelCol="labelCol" :wrapperCol="wrapperCol">
- <a-row>
- <a-col :span="24">
- <a-form-item label="名称" v-bind="validateInfos.name">
- <a-input v-model:value="formData.name" placeholder="请输入名称" :disabled="disabled"></a-input>
- </a-form-item>
- </a-col>
- <a-col :span="24">
- <a-form-item label="邮箱账号" v-bind="validateInfos.account">
- <a-input v-model:value="formData.account" placeholder="请输入邮箱账号" :disabled="(disabled||formData.id>0)?true:false"></a-input>
- </a-form-item>
- </a-col>
- <a-col :span="24">
- <a-form-item label="密码" v-bind="validateInfos.password">
- <a-input v-model:value="formData.password" placeholder="请输入密码" :disabled="(disabled||formData.id>0)?true:false"></a-input>
- </a-form-item>
- </a-col>
- <a-col :span="24">
- <a-form-item label="手机号" v-bind="validateInfos.phone">
- <a-input v-model:value="formData.phone" placeholder="请输入手机号" :disabled="disabled"></a-input>
- </a-form-item>
- </a-col>
- <!-- <a-col :span="24">-->
- <!-- <a-form-item label="关联站点" v-bind="validateInfos.siteIds">-->
- <!-- <j-vxe-site-select-cell v-model:value="formData.siteIds" :disabled="(disabled||formData.id>0)?true:false"/>-->
- <!-- </a-form-item>-->
- <!-- </a-col>-->
- <a-col :span="24">
- <a-form-item label="用户角色" v-bind="validateInfos.userRole">
- <j-dict-select-tag type='radio' v-model:value="formData.userRole" dictCode="user_role" placeholder="请选择用户角色" :disabled="(disabled||formData.id>0)?true:false"/>
- </a-form-item>
- </a-col>
- <a-col :span="24">
- <a-form-item label="所属人员" v-bind="validateInfos.sysUserCode">
- <j-select-user v-model:value="formData.sysUserCode" :disabled="disabled"/>
- </a-form-item>
- </a-col>
- </a-row>
- </a-form>
- </a-spin>
- </template>
- <script lang="ts" setup>
- import { ref, reactive, defineExpose, nextTick, defineProps, computed, onMounted } from 'vue';
- import { useMessage } from '/@/hooks/web/useMessage';
- import JDictSelectTag from '/@/components/Form/src/jeecg/components/JDictSelectTag.vue';
- import JSelectUser from '/@/components/Form/src/jeecg/components/JSelectUser.vue';
- import JVxeSiteSelectCell from '/@/components/JVxeCustom/site/JVxeSiteSelectCell.vue';
- import { getValueType } from '/@/utils';
- import { saveOrUpdate } from '../OkkiAccount.api';
- import { Form } from 'ant-design-vue';
-
- const props = defineProps({
- formDisabled: { type: Boolean, default: false },
- formData: { type: Object, default: ()=>{} },
- formBpm: { type: Boolean, default: true }
- });
- const formRef = ref();
- const useForm = Form.useForm;
- const emit = defineEmits(['register', 'ok']);
- const formData = reactive<Record<string, any>>({
- id: '',
- name:'',
- account: '',
- password: '',
- phone:'',
- siteIds: '',
- sysUserCode: '',
- userRole: undefined,
- });
- const { createMessage } = useMessage();
- const labelCol = ref<any>({ xs: { span: 24 }, sm: { span: 5 } });
- const wrapperCol = ref<any>({ xs: { span: 24 }, sm: { span: 16 } });
- const confirmLoading = ref<boolean>(false);
- //表单验证
- const validatorRules = {
- name: [{ required: true, message: '请输入名称!'},],
- account: [{ required: true, message: '请输入邮箱账号!'},],
- password: [{ required: true, message: '请输入密码!'},],
- phone: [{ required: true, message: '请输入手机号!'},],
- userRole: [{ required: true, message: '请选择用户角色!'},],
- };
- const { resetFields, validate, validateInfos } = useForm(formData, validatorRules, { immediate: false });
- // 表单禁用
- const disabled = computed(()=>{
- if(props.formBpm === true){
- if(props.formData.disabled === false){
- return false;
- }else{
- return true;
- }
- }
- return props.formDisabled;
- });
- /**
- * 新增
- */
- function add() {
- edit({});
- }
- /**
- * 编辑
- */
- function edit(record) {
- nextTick(() => {
- resetFields();
- const tmpData = {};
- Object.keys(formData).forEach((key) => {
- if(record.hasOwnProperty(key)){
- tmpData[key] = record[key]
- }
- })
- //赋值
- Object.assign(formData, tmpData);
- });
- }
- /**
- * 提交数据
- */
- async function submitForm() {
- // 触发表单验证
- await validate();
- confirmLoading.value = true;
- const isUpdate = ref<boolean>(false);
- //时间格式化
- let model = formData;
- if (model.id) {
- isUpdate.value = true;
- }
- //循环数据
- for (let data in model) {
- //如果该数据是数组并且是字符串类型
- if (model[data] instanceof Array) {
- let valueType = getValueType(formRef.value.getProps, data);
- //如果是字符串类型的需要变成以逗号分割的字符串
- if (valueType === 'string') {
- model[data] = model[data].join(',');
- }
- }
- }
- await saveOrUpdate(model, isUpdate.value)
- .then((res) => {
- if (res.success) {
- createMessage.success(res.message);
- emit('ok');
- } else {
- createMessage.warning(res.message);
- }
- })
- .finally(() => {
- confirmLoading.value = false;
- });
- }
- defineExpose({
- add,
- edit,
- submitForm,
- });
- </script>
- <style lang="less" scoped>
- .antd-modal-form {
- height: 500px !important;
- overflow-y: auto;
- padding: 14px;
- }
- </style>
|