123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 |
- <template>
- <a-spin :spinning="confirmLoading">
- <JFormContainer :disabled="disabled">
- <template #detail>
- <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.marketType">
- <j-dict-select-tag v-model:value="formData.marketType" dictCode="dict_market_type" placeholder="请选择套餐类型" allow-clear />
- </a-form-item>
- </a-col>
- <a-col :span="24">
- <a-form-item label="套餐名称" v-bind="validateInfos.planName">
- <a-input v-model:value="formData.planName" placeholder="请输入套餐名称" allow-clear />
- </a-form-item>
- </a-col>
- <a-col :span="24">
- <a-form-item label="关键词数量" v-bind="validateInfos.keywordCount">
- <a-input-number v-model:value="formData.keywordCount" placeholder="请输入关键词数量" style="width: 100%" />
- </a-form-item>
- </a-col>
- <a-col :span="24">
- <a-form-item label="关键词达标目标" v-bind="validateInfos.target">
- <a-input-number v-model:value="formData.target" placeholder="请输入关键词达标目标" style="width: 100%" />
- </a-form-item>
- </a-col>
- <a-col :span="24">
- <a-form-item label="服务时间" v-bind="validateInfos.serviceTime">
- <a-input-number v-model:value="formData.serviceTime" placeholder="请输入服务时间" style="width: 100%" />
- </a-form-item>
- </a-col>
- <a-col :span="24">
- <a-form-item label="价格" v-bind="validateInfos.price">
- <a-input-number v-model:value="formData.price" placeholder="请输入价格" style="width: 100%" />
- </a-form-item>
- </a-col>
- </a-row>
- </a-form>
- </template>
- </JFormContainer>
- </a-spin>
- </template>
- <script lang="ts" setup>
- import { ref, reactive, defineExpose, nextTick, defineProps, computed, onMounted } from 'vue';
- import { defHttp } from '/@/utils/http/axios';
- import { useMessage } from '/@/hooks/web/useMessage';
- import JDictSelectTag from '/@/components/Form/src/jeecg/components/JDictSelectTag.vue';
- import { getValueType } from '/@/utils';
- import { saveOrUpdate } from '../SeoMarketPlan.api';
- import { Form } from 'ant-design-vue';
- import JFormContainer from '/@/components/Form/src/container/JFormContainer.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: '',
- marketType: '',
- planName: '',
- keywordCount: undefined,
- target: undefined,
- serviceTime: undefined,
- price: 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 = reactive({
- marketType: [{ required: true, message: '请输入套餐类型!' }],
- planName: [{ required: true, message: '请输入套餐名称!' }],
- keywordCount: [{ required: true, message: '请输入关键词数量!' }],
- target: [{ required: true, message: '请输入关键词达标目标!' }],
- serviceTime: [{ required: true, message: '请输入服务时间!' }],
- price: [{ 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 {
- padding: 14px;
- }
- </style>
|