Commit 3a1fe5ba by haojie

1

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