forked from wangjiadong/comp
commit
fd4166882e
3 changed files with 85 additions and 66 deletions
@ -1,77 +1,82 @@ |
|||||||
<template> |
<template> |
||||||
<a-modal :title="title" :width="width" :visible="visible" @ok="handleOk" :okButtonProps="{ class: { 'jee-hidden': disableSubmit } }" @cancel="handleCancel" cancelText="关闭"> |
<a-modal :title="title" :width="width" :visible="visible" @ok="handleOk" |
||||||
<AwardPersionForm ref="registerForm" @ok="submitCallback" :formDisabled="disableSubmit" :formBpm="false"></AwardPersionForm> |
:okButtonProps="{ class: { 'jee-hidden': disableSubmit } }" @cancel="handleCancel" cancelText="关闭"> |
||||||
|
<AwardPersionForm ref="registerForm" @ok="submitCallback" :formDisabled="disableSubmit" :formBpm="false"> |
||||||
|
</AwardPersionForm> |
||||||
</a-modal> |
</a-modal> |
||||||
</template> |
</template> |
||||||
|
|
||||||
<script lang="ts" setup> |
<script lang="ts" setup> |
||||||
import { ref, nextTick, defineExpose } from 'vue'; |
import { ref, nextTick, defineExpose, watch } from 'vue'; |
||||||
import AwardPersionForm from './AwardPersionForm.vue' |
import AwardPersionForm from './AwardPersionForm.vue' |
||||||
|
|
||||||
const title = ref<string>(''); |
|
||||||
const width = ref<number>(800); |
|
||||||
const visible = ref<boolean>(false); |
|
||||||
const disableSubmit = ref<boolean>(false); |
|
||||||
const registerForm = ref(); |
|
||||||
const emit = defineEmits(['register', 'success']); |
|
||||||
|
|
||||||
/** |
|
||||||
* 新增 |
|
||||||
*/ |
|
||||||
function add() { |
|
||||||
title.value = '新增'; |
|
||||||
visible.value = true; |
|
||||||
nextTick(() => { |
|
||||||
registerForm.value.add(); |
|
||||||
registerForm.value.setIsT(false); |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
/** |
|
||||||
* 编辑 |
|
||||||
* @param record |
|
||||||
*/ |
|
||||||
function edit(record) { |
|
||||||
title.value = disableSubmit.value ? '详情' : '编辑'; |
|
||||||
visible.value = true; |
|
||||||
nextTick(() => { |
|
||||||
registerForm.value.edit(record); |
|
||||||
registerForm.value.setIsT(true); |
|
||||||
}); |
|
||||||
} |
|
||||||
|
|
||||||
/** |
|
||||||
* 确定按钮点击事件 |
|
||||||
*/ |
|
||||||
function handleOk() { |
|
||||||
registerForm.value.submitForm(); |
|
||||||
} |
|
||||||
|
|
||||||
/** |
const title = ref<string>(''); |
||||||
* form保存回调事件 |
const width = ref<number>(800); |
||||||
*/ |
const visible = ref<boolean>(false); |
||||||
function submitCallback() { |
const disableSubmit = ref<boolean>(false); |
||||||
handleCancel(); |
const registerForm = ref(); |
||||||
emit('success'); |
const emit = defineEmits(['register', 'success']); |
||||||
} |
watch(() => visible.value, newVal => { |
||||||
|
if (!newVal) registerForm.value.setIsT(false); |
||||||
|
}) |
||||||
|
|
||||||
/** |
/** |
||||||
* 取消按钮回调事件 |
* 新增 |
||||||
*/ |
*/ |
||||||
function handleCancel() { |
function add() { |
||||||
visible.value = false; |
title.value = '新增'; |
||||||
} |
visible.value = true; |
||||||
|
nextTick(() => { |
||||||
|
registerForm.value.add(); |
||||||
|
}); |
||||||
|
} |
||||||
|
|
||||||
defineExpose({ |
/** |
||||||
add, |
* 编辑 |
||||||
edit, |
* @param record |
||||||
disableSubmit, |
*/ |
||||||
|
function edit(record) { |
||||||
|
title.value = disableSubmit.value ? '详情' : '编辑'; |
||||||
|
visible.value = true; |
||||||
|
nextTick(() => { |
||||||
|
registerForm.value.edit(record); |
||||||
|
registerForm.value.setIsT(true); |
||||||
}); |
}); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 确定按钮点击事件 |
||||||
|
*/ |
||||||
|
function handleOk() { |
||||||
|
registerForm.value.submitForm(); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* form保存回调事件 |
||||||
|
*/ |
||||||
|
function submitCallback() { |
||||||
|
handleCancel(); |
||||||
|
emit('success'); |
||||||
|
} |
||||||
|
|
||||||
|
/** |
||||||
|
* 取消按钮回调事件 |
||||||
|
*/ |
||||||
|
function handleCancel() { |
||||||
|
visible.value = false; |
||||||
|
} |
||||||
|
|
||||||
|
defineExpose({ |
||||||
|
add, |
||||||
|
edit, |
||||||
|
disableSubmit, |
||||||
|
}); |
||||||
</script> |
</script> |
||||||
|
|
||||||
<style> |
<style> |
||||||
/**隐藏样式-modal确定按钮 */ |
/**隐藏样式-modal确定按钮 */ |
||||||
.jee-hidden { |
.jee-hidden { |
||||||
display: none !important; |
display: none !important; |
||||||
} |
} |
||||||
</style> |
</style> |
||||||
|
Loading…
Reference in new issue