【增加】Image midjourney 增加操作按钮

pull/473/head
cherishsince 2024-06-04 17:37:52 +08:00
parent 5876fdca10
commit 1be7713f56
1 changed files with 25 additions and 2 deletions

View File

@ -19,11 +19,19 @@
<img class="image" :src="imageDetail?.picUrl"/> <img class="image" :src="imageDetail?.picUrl"/>
<div v-if="imageDetail?.status === 30">{{imageDetail?.errorMessage}}</div> <div v-if="imageDetail?.status === 30">{{imageDetail?.errorMessage}}</div>
</div> </div>
<div class="image-mj-btns">
<el-button size="small" v-for="button in imageDetail?.buttons" :key="button"
style="width: 40px;margin-left: 0; margin-right: 10px; margin-top: 5px;"
@click="handlerMjBtnClick(button)"
>
{{ button.label }}{{ button.emoji }}
</el-button>
</div>
</el-card> </el-card>
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import {Delete, Download, More} from "@element-plus/icons-vue"; import {Delete, Download, More} from "@element-plus/icons-vue";
import {ImageDetailVO} from "@/api/ai/image"; import {ImageDetailVO, ImageMjButtonsVO} from "@/api/ai/image";
import {PropType} from "vue"; import {PropType} from "vue";
import {ElLoading} from "element-plus"; import {ElLoading} from "element-plus";
@ -56,6 +64,12 @@ const handlerLoading = async (status: number) => {
} }
} }
} }
/** mj 按钮 click */
const handlerMjBtnClick = async (button: ImageMjButtonsVO) => {
emits('onMjBtnClick', button)
}
// watch // watch
const { imageDetail } = toRefs(props) const { imageDetail } = toRefs(props)
watch(imageDetail, async (newVal, oldVal) => { watch(imageDetail, async (newVal, oldVal) => {
@ -63,7 +77,7 @@ watch(imageDetail, async (newVal, oldVal) => {
}) })
// emits // emits
const emits = defineEmits(['onBtnClick']) const emits = defineEmits(['onBtnClick', 'onMjBtnClick'])
// //
onMounted(async () => { onMounted(async () => {
@ -104,6 +118,15 @@ onMounted(async () => {
border-radius: 10px; border-radius: 10px;
} }
} }
.image-mj-btns {
margin-top: 5px;
width: 100%;
display: flex;
flex-direction: row;
flex-wrap: wrap;
justify-content: flex-start;
}
} }
</style> </style>