|
@@ -14,14 +14,14 @@
|
|
|
type="textarea"
|
|
type="textarea"
|
|
|
/>
|
|
/>
|
|
|
</div>
|
|
</div>
|
|
|
- <div class="hot-words">
|
|
|
|
|
|
|
+ <div class="flex flex-col mt-30px">
|
|
|
<div>
|
|
<div>
|
|
|
<el-text tag="b">随机热词</el-text>
|
|
<el-text tag="b">随机热词</el-text>
|
|
|
</div>
|
|
</div>
|
|
|
- <el-space wrap class="word-list">
|
|
|
|
|
|
|
+ <el-space wrap class="flex flex-row flex-wrap justify-start mt-15px">
|
|
|
<el-button
|
|
<el-button
|
|
|
round
|
|
round
|
|
|
- class="btn"
|
|
|
|
|
|
|
+ class="m-0"
|
|
|
:type="selectHotWord === hotWord ? 'primary' : 'default'"
|
|
:type="selectHotWord === hotWord ? 'primary' : 'default'"
|
|
|
v-for="hotWord in ImageHotWords"
|
|
v-for="hotWord in ImageHotWords"
|
|
|
:key="hotWord"
|
|
:key="hotWord"
|
|
@@ -31,57 +31,57 @@
|
|
|
</el-button>
|
|
</el-button>
|
|
|
</el-space>
|
|
</el-space>
|
|
|
</div>
|
|
</div>
|
|
|
- <div class="model">
|
|
|
|
|
|
|
+ <div class="mt-30px">
|
|
|
<div>
|
|
<div>
|
|
|
<el-text tag="b">模型选择</el-text>
|
|
<el-text tag="b">模型选择</el-text>
|
|
|
</div>
|
|
</div>
|
|
|
- <el-space wrap class="model-list">
|
|
|
|
|
|
|
+ <el-space wrap class="mt-15px">
|
|
|
<div
|
|
<div
|
|
|
- :class="selectModel === model.key ? 'modal-item selectModel' : 'modal-item'"
|
|
|
|
|
|
|
+ :class="selectModel === model.key ? 'w-110px overflow-hidden flex flex-col items-center border-3 border-solid border-#1293ff rounded-5px cursor-pointer' : 'w-110px overflow-hidden flex flex-col items-center border-3 border-solid border-transparent cursor-pointer'"
|
|
|
v-for="model in Dall3Models"
|
|
v-for="model in Dall3Models"
|
|
|
:key="model.key"
|
|
:key="model.key"
|
|
|
>
|
|
>
|
|
|
<el-image :src="model.image" fit="contain" @click="handleModelClick(model)" />
|
|
<el-image :src="model.image" fit="contain" @click="handleModelClick(model)" />
|
|
|
- <div class="model-font">{{ model.name }}</div>
|
|
|
|
|
|
|
+ <div class="text-14px color-#3e3e3e font-bold">{{ model.name }}</div>
|
|
|
</div>
|
|
</div>
|
|
|
</el-space>
|
|
</el-space>
|
|
|
</div>
|
|
</div>
|
|
|
- <div class="image-style">
|
|
|
|
|
|
|
+ <div class="mt-30px">
|
|
|
<div>
|
|
<div>
|
|
|
<el-text tag="b">风格选择</el-text>
|
|
<el-text tag="b">风格选择</el-text>
|
|
|
</div>
|
|
</div>
|
|
|
- <el-space wrap class="image-style-list">
|
|
|
|
|
|
|
+ <el-space wrap class="mt-15px">
|
|
|
<div
|
|
<div
|
|
|
- :class="style === imageStyle.key ? 'image-style-item selectImageStyle' : 'image-style-item'"
|
|
|
|
|
|
|
+ :class="style === imageStyle.key ? 'w-110px overflow-hidden flex flex-col items-center border-3 border-solid border-#1293ff rounded-5px cursor-pointer' : 'w-110px overflow-hidden flex flex-col items-center border-3 border-solid border-transparent cursor-pointer'"
|
|
|
v-for="imageStyle in Dall3StyleList"
|
|
v-for="imageStyle in Dall3StyleList"
|
|
|
:key="imageStyle.key"
|
|
:key="imageStyle.key"
|
|
|
>
|
|
>
|
|
|
<el-image :src="imageStyle.image" fit="contain" @click="handleStyleClick(imageStyle)" />
|
|
<el-image :src="imageStyle.image" fit="contain" @click="handleStyleClick(imageStyle)" />
|
|
|
- <div class="style-font">{{ imageStyle.name }}</div>
|
|
|
|
|
|
|
+ <div class="text-14px color-#3e3e3e font-bold">{{ imageStyle.name }}</div>
|
|
|
</div>
|
|
</div>
|
|
|
</el-space>
|
|
</el-space>
|
|
|
</div>
|
|
</div>
|
|
|
- <div class="image-size">
|
|
|
|
|
|
|
+ <div class="w-full mt-30px">
|
|
|
<div>
|
|
<div>
|
|
|
<el-text tag="b">画面比例</el-text>
|
|
<el-text tag="b">画面比例</el-text>
|
|
|
</div>
|
|
</div>
|
|
|
- <el-space wrap class="size-list">
|
|
|
|
|
|
|
+ <el-space wrap class="flex flex-row justify-between w-full mt-20px">
|
|
|
<div
|
|
<div
|
|
|
- class="size-item"
|
|
|
|
|
|
|
+ class="flex flex-col items-center cursor-pointer"
|
|
|
v-for="imageSize in Dall3SizeList"
|
|
v-for="imageSize in Dall3SizeList"
|
|
|
:key="imageSize.key"
|
|
:key="imageSize.key"
|
|
|
@click="handleSizeClick(imageSize)"
|
|
@click="handleSizeClick(imageSize)"
|
|
|
>
|
|
>
|
|
|
<div
|
|
<div
|
|
|
- :class="selectSize === imageSize.key ? 'size-wrapper selectImageSize' : 'size-wrapper'"
|
|
|
|
|
|
|
+ :class="selectSize === imageSize.key ? 'flex flex-col items-center justify-center rounded-7px p-4px w-50px h-50px bg-white border-1 border-solid border-#1293ff' : 'flex flex-col items-center justify-center rounded-7px p-4px w-50px h-50px bg-white border-1 border-solid border-white'"
|
|
|
>
|
|
>
|
|
|
<div :style="imageSize.style"></div>
|
|
<div :style="imageSize.style"></div>
|
|
|
</div>
|
|
</div>
|
|
|
- <div class="size-font">{{ imageSize.name }}</div>
|
|
|
|
|
|
|
+ <div class="text-14px color-#3e3e3e font-bold">{{ imageSize.name }}</div>
|
|
|
</div>
|
|
</div>
|
|
|
</el-space>
|
|
</el-space>
|
|
|
</div>
|
|
</div>
|
|
|
- <div class="btns">
|
|
|
|
|
|
|
+ <div class="flex justify-center mt-50px">
|
|
|
<el-button
|
|
<el-button
|
|
|
type="primary"
|
|
type="primary"
|
|
|
size="large"
|
|
size="large"
|
|
@@ -229,135 +229,4 @@ const settingValues = async (detail: ImageVO) => {
|
|
|
/** 暴露组件方法 */
|
|
/** 暴露组件方法 */
|
|
|
defineExpose({ settingValues })
|
|
defineExpose({ settingValues })
|
|
|
</script>
|
|
</script>
|
|
|
-<style scoped lang="scss">
|
|
|
|
|
-// 热词
|
|
|
|
|
-.hot-words {
|
|
|
|
|
- display: flex;
|
|
|
|
|
- flex-direction: column;
|
|
|
|
|
- margin-top: 30px;
|
|
|
|
|
|
|
|
|
|
- .word-list {
|
|
|
|
|
- display: flex;
|
|
|
|
|
- flex-direction: row;
|
|
|
|
|
- flex-wrap: wrap;
|
|
|
|
|
- justify-content: start;
|
|
|
|
|
- margin-top: 15px;
|
|
|
|
|
-
|
|
|
|
|
- .btn {
|
|
|
|
|
- margin: 0;
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
-}
|
|
|
|
|
-
|
|
|
|
|
-// 模型
|
|
|
|
|
-.model {
|
|
|
|
|
- margin-top: 30px;
|
|
|
|
|
-
|
|
|
|
|
- .model-list {
|
|
|
|
|
- margin-top: 15px;
|
|
|
|
|
-
|
|
|
|
|
- .modal-item {
|
|
|
|
|
- width: 110px;
|
|
|
|
|
- //outline: 1px solid blue;
|
|
|
|
|
- overflow: hidden;
|
|
|
|
|
- display: flex;
|
|
|
|
|
- flex-direction: column;
|
|
|
|
|
- align-items: center;
|
|
|
|
|
- border: 3px solid transparent;
|
|
|
|
|
- cursor: pointer;
|
|
|
|
|
-
|
|
|
|
|
- .model-font {
|
|
|
|
|
- font-size: 14px;
|
|
|
|
|
- color: #3e3e3e;
|
|
|
|
|
- font-weight: bold;
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- .selectModel {
|
|
|
|
|
- border: 3px solid #1293ff;
|
|
|
|
|
- border-radius: 5px;
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
-}
|
|
|
|
|
-
|
|
|
|
|
-// 样式 style
|
|
|
|
|
-.image-style {
|
|
|
|
|
- margin-top: 30px;
|
|
|
|
|
-
|
|
|
|
|
- .image-style-list {
|
|
|
|
|
- margin-top: 15px;
|
|
|
|
|
-
|
|
|
|
|
- .image-style-item {
|
|
|
|
|
- width: 110px;
|
|
|
|
|
- //outline: 1px solid blue;
|
|
|
|
|
- overflow: hidden;
|
|
|
|
|
- display: flex;
|
|
|
|
|
- flex-direction: column;
|
|
|
|
|
- align-items: center;
|
|
|
|
|
- border: 3px solid transparent;
|
|
|
|
|
- cursor: pointer;
|
|
|
|
|
-
|
|
|
|
|
- .style-font {
|
|
|
|
|
- font-size: 14px;
|
|
|
|
|
- color: #3e3e3e;
|
|
|
|
|
- font-weight: bold;
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- .selectImageStyle {
|
|
|
|
|
- border: 3px solid #1293ff;
|
|
|
|
|
- border-radius: 5px;
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
-}
|
|
|
|
|
-
|
|
|
|
|
-// 尺寸
|
|
|
|
|
-.image-size {
|
|
|
|
|
- width: 100%;
|
|
|
|
|
- margin-top: 30px;
|
|
|
|
|
-
|
|
|
|
|
- .size-list {
|
|
|
|
|
- display: flex;
|
|
|
|
|
- flex-direction: row;
|
|
|
|
|
- justify-content: space-between;
|
|
|
|
|
- width: 100%;
|
|
|
|
|
- margin-top: 20px;
|
|
|
|
|
-
|
|
|
|
|
- .size-item {
|
|
|
|
|
- display: flex;
|
|
|
|
|
- flex-direction: column;
|
|
|
|
|
- align-items: center;
|
|
|
|
|
- cursor: pointer;
|
|
|
|
|
-
|
|
|
|
|
- .size-wrapper {
|
|
|
|
|
- display: flex;
|
|
|
|
|
- flex-direction: column;
|
|
|
|
|
- align-items: center;
|
|
|
|
|
- justify-content: center;
|
|
|
|
|
- border-radius: 7px;
|
|
|
|
|
- padding: 4px;
|
|
|
|
|
- width: 50px;
|
|
|
|
|
- height: 50px;
|
|
|
|
|
- background-color: #fff;
|
|
|
|
|
- border: 1px solid #fff;
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- .size-font {
|
|
|
|
|
- font-size: 14px;
|
|
|
|
|
- color: #3e3e3e;
|
|
|
|
|
- font-weight: bold;
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
- }
|
|
|
|
|
-
|
|
|
|
|
- .selectImageSize {
|
|
|
|
|
- border: 1px solid #1293ff !important;
|
|
|
|
|
- }
|
|
|
|
|
-}
|
|
|
|
|
-
|
|
|
|
|
-.btns {
|
|
|
|
|
- display: flex;
|
|
|
|
|
- justify-content: center;
|
|
|
|
|
- margin-top: 50px;
|
|
|
|
|
-}
|
|
|
|
|
-</style>
|
|
|