Commit 3a1fe5ba by haojie

1

parent da11b384
......@@ -45,12 +45,7 @@ const props = withDefaults(
config: {},
}
);
const emit = defineEmits([
'update:module_status',
'moduleChange',
'delete',
'submit',
]);
const emit = defineEmits(['moduleChange', 'delete', 'submit']);
// 添加可以拖拽功能,放大缩小功能
const backimg = ref(props.edit_image);
......@@ -111,6 +106,7 @@ const ConversionImage = async () => {
}
const url = res.response.url;
// 通知父组件提交任务
console.log(url);
emit('submit', url);
}
}
......@@ -124,6 +120,7 @@ const ConversionImage = async () => {
watch(
() => props.module_status,
(v) => {
console.log('监听到了');
if (v == ModelStatus.upload) {
// 上传并提交任务
ConversionImage();
......
......@@ -90,6 +90,10 @@ const Search = async () => {
},
{
image:
'',
},
{
image:
'',
},
];
......
......@@ -21,6 +21,10 @@
color: #888fa1;
}
}
.change-img {
width: 100%;
height: 90%;
}
.load-success-box {
padding: 0 20px;
height: 100%;
......
import { defineComponent } from 'vue';
import { defineComponent, ref, watch } from 'vue';
import './index.less';
import CustomResetButton from '@/components/custom/resetbutton.vue';
import OnWait from '@/components/custom/ImgLoadingStatus/OnWait.vue';
import OnLoading from '@/components/custom/ImgLoadingStatus/OnLoading.vue';
import ImageEditVue from '@/components/custom/ImageEdit.vue';
import { ModelStatus } from '@/utils/api/Task';
export default defineComponent({
props: {
list: Object as any,
status: String,
backgroundImage: String,
config: Object as any,
OverlayImages: Object as any,
module_status: Number,
},
setup(props, ctx) {
const cur_module_status = ref(ModelStatus.wait);
watch(
() => props.module_status,
(v) => {
if (v) {
cur_module_status.value = v;
}
}
);
// 为空时展示的html
const EmptyHTML = () => {
return <OnWait></OnWait>;
......@@ -18,6 +33,10 @@ export default defineComponent({
const LoadingHTML = () => {
return <OnLoading></OnLoading>;
};
// 修改图片时的html
const EditHTML = () => {
return '';
};
// 加载完成展示的html
const LoadSuccessHTML = () => {
return (
......@@ -47,11 +66,24 @@ export default defineComponent({
return EmptyHTML();
} else if (status == 'loading') {
return LoadingHTML();
} else if (status == 'edit') {
return EditHTML();
} else {
return LoadSuccessHTML();
}
};
return () => <div class="img-res-status">{CurrentModule()}</div>;
return () => (
<div class="img-res-status">
{CurrentModule()}
<ImageEditVue
v-show={props.status == 'edit'}
module_status={cur_module_status.value}
list={props.OverlayImages}
edit_image={props.backgroundImage}
config={props.config}
></ImageEditVue>
</div>
);
},
});
......@@ -53,6 +53,9 @@
@SubmitModel="SubmitModel"
></SelectModel>
</template>
<template v-else-if="it.component_type == 'local_upload'">
<LocalUpload @SubmitImg="SubmitImg"></LocalUpload>
</template>
</template>
</div>
</div>
......@@ -72,7 +75,11 @@
<div class="generate-result">
<CustomGenerateResult
:status="AdminData.status"
:backgroundImage="backgroundImage"
:OverlayImages="OverlayImages.list"
:list="AdminData.callback_list"
:module_status="AdminData.module_status"
:config="StrategyConfig"
></CustomGenerateResult>
</div>
</div>
......@@ -90,6 +97,7 @@ import CustomInput from '@/components/custom/input/index.vue';
import CustomResetButton from '@/components/custom/resetbutton.vue';
import SelectModel from '@/components/custom/SelectModel.vue';
import CustomGenerateResult from './components/GenerateResult';
import LocalUpload from '@/components/custom/LocalUpload.vue';
import {
nextTick,
onBeforeMount,
......@@ -105,7 +113,7 @@ import {
useSubmitConversationImage,
useImageCallback,
} from '@/utils/api/scenes';
import { FormExample4 } from '@/utils/api/Task';
import { FormExample4, ModelStatus } from '@/utils/api/Task';
import { Validationrules, ChangePageHeight } from '@/utils/tool';
import { useRoute } from 'vue-router';
import { show_message } from '@/utils/tdesign_tool';
......@@ -119,6 +127,8 @@ const GenerationBox = ref();
let IntervalImg: any = null;
// 本次提交的数量
const CurSubmitNum = ref(0);
// 背景图
const backgroundImage = ref('');
// 上传策略
const StrategyConfig = ref({});
const AdminData = reactive({
......@@ -130,8 +140,13 @@ const AdminData = reactive({
* success-结束
*/
status: '',
module_status: ModelStatus.wait,
reset_num: 1,
});
//
const OverlayImages = reactive({
list: [],
});
const scenario_id = ref();
// 元素高度和页面高度比较
const getElementHeight = () => {
......@@ -139,6 +154,14 @@ const getElementHeight = () => {
ChangePageHeight(GenerationBox.value);
}
};
// 提交的图片
const SubmitImg = (item: any) => {
if (OverlayImages.list.length) {
OverlayImages.list[0] = item;
} else {
OverlayImages.list.push(item);
}
};
// 获取后台配置的组件
const getAdminComponent = async () => {
try {
......@@ -170,6 +193,8 @@ const getAdminComponent = async () => {
it.component_type = 'custom-number';
} else if (it.type == 'select_model') {
it.component_type = 'select_model';
} else if (it.type == 'local_upload') {
it.component_type = 'local_upload';
}
// 判断value的值
if (!it.value) {
......@@ -195,7 +220,8 @@ const getAdminComponent = async () => {
// 用户选择的模特
const SubmitModel = (img: string) => {
if (img) {
console.log(1);
backgroundImage.value = img;
AdminData.status = 'edit';
}
};
const getStrategy = async () => {
......@@ -288,51 +314,9 @@ const onSubmit = async (params: any) => {
};
// 提交前的校验
const beforeSubmit = () => {
// 定时器不能为开启状态
if (IntervalImg) {
show_message('请等待上一个任务完成');
return;
}
let params: any = {};
// 遍历整个列表
for (let i = 0; i < AdminData.list.length; i++) {
let item: any = AdminData.list[i];
for (let j = 0; j < item.lists.length; j++) {
let it = item.lists[j];
// 校验规则
let message = Validationrules(it.rules, it.value, it.name);
if (message) {
// 提示错误信息
show_message(message);
return;
} else {
// 类型为图片尺寸且当前选择的是自定义
if (it.type == 'radio_group_size' && it.value == '') {
// 找到options列表里的自定义模块
let customObj = it.options.find((opt: any) => opt.type == 'custom');
if (customObj) {
if (customObj.value1 && customObj.value2) {
params[it.name] = customObj.value1 + 'x' + customObj.value2;
} else {
show_message('自定义图片尺寸未填写完整');
return;
}
}
}
if (it.value) {
if (it.name == 'number') {
// 转换为number类型
params[it.name] = parseFloat(it.value + '');
} else {
// 添加params
params[it.name] = it.value;
}
}
}
}
}
console.log(params);
onSubmit(params);
// 通知子组件上传图片
AdminData.module_status = ModelStatus.upload;
AdminData.status = 'loading';
};
onBeforeMount(async () => {
// 获取上传策略
......@@ -414,11 +398,16 @@ onBeforeUnmount(() => {
.input-pay-num {
width: 100%;
}
.local-file-upload {
width: 100%;
height: 225px;
}
}
}
.confirm-box {
flex: 1;
display: flex;
align-items: center;
align-items: flex-end;
justify-content: space-between;
margin: 20px 0;
box-sizing: border-box;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment