feat: add functions mj page for mobile

This commit is contained in:
RockYang 2024-01-31 07:24:35 +08:00
parent 56a91db7e7
commit f6826fcefc
3 changed files with 119 additions and 26 deletions

View File

@ -1,9 +1,6 @@
.mobile-mj { .mobile-mj {
.content { .content {
.van-field__label { padding-bottom 60px
width 100px
text-align right
}
.text-line { .text-line {
padding 6px padding 6px
@ -63,6 +60,15 @@
} }
} }
} }
.van-button {
position relative
.van-tag {
position absolute
right 20px
}
}
} }
} }
} }

View File

@ -5,10 +5,13 @@ import 'vant/lib/index.css';
import App from './App.vue' import App from './App.vue'
import {createPinia} from "pinia"; import {createPinia} from "pinia";
import { import {
Badge,
Button, Button,
Cell, Cell,
CellGroup, CellGroup,
Col, Col,
Collapse,
CollapseItem,
ConfigProvider, ConfigProvider,
Dialog, Dialog,
DropdownItem, DropdownItem,
@ -73,6 +76,9 @@ app.use(Overlay)
app.use(Col) app.use(Col)
app.use(Row) app.use(Row)
app.use(Slider) app.use(Slider)
app.use(Badge)
app.use(Collapse);
app.use(CollapseItem);
app.use(router).use(ElementPlus).mount('#app') app.use(router).use(ElementPlus).mount('#app')

View File

@ -28,7 +28,9 @@
<div class="icon"> <div class="icon">
<van-image :src="item.img" fit="cover"></van-image> <van-image :src="item.img" fit="cover"></van-image>
</div> </div>
<div class="text">{{ item.text }}</div> <div class="text">
<van-text-ellipsis :content="item.text"/>
</div>
</div> </div>
</van-col> </van-col>
</van-row> </van-row>
@ -59,14 +61,6 @@
</van-field> </van-field>
</div> </div>
<div class="text-line">
<van-field label="垫图">
<template #input>
<van-uploader v-model="imgList" :after-read="afterRead"/>
</template>
</van-field>
</div>
<div class="text-line"> <div class="text-line">
<van-field <van-field
v-model="params.prompt" v-model="params.prompt"
@ -78,23 +72,52 @@
/> />
</div> </div>
<van-collapse v-model="activeColspan">
<van-collapse-item title="垫图" name="img">
<van-field>
<template #input>
<van-uploader v-model="imgList" :after-read="uploadImg"/>
</template>
</van-field>
</van-collapse-item>
<van-collapse-item title="反向提示词" name="neg_prompt">
<van-field
v-model="params.prompt"
rows="3"
autosize
type="textarea"
placeholder="不想出现在图片上的元素(例如:树,建筑)"
/>
</van-collapse-item>
</van-collapse>
<div class="text-line"> <div class="text-line">
<van-button round block type="primary" native-type="submit"> <van-button round block type="primary" native-type="submit">
<van-tag type="success">可用额度:{{ imgCalls }}</van-tag>
立即生成 立即生成
</van-button> </van-button>
</div> </div>
</van-form> </van-form>
<h2>任务列表</h2>
</div> </div>
</div> </div>
</template> </template>
<script setup> <script setup>
import {onMounted, ref} from "vue"; import {onMounted, ref} from "vue";
import {showFailToast, showNotify, showSuccessToast, showToast} from "vant"; import {showFailToast, showToast} from "vant";
import {httpGet, httpPost} from "@/utils/http"; import {httpPost} from "@/utils/http";
import Compressor from 'compressorjs'; import Compressor from "compressorjs";
import {ElMessage} from "element-plus";
import {getSessionId} from "@/store/session";
import {checkSession} from "@/action/session";
import Clipboard from "clipboard";
import {useRouter} from "vue-router";
const title = ref('MidJourney 绘画') const title = ref('MidJourney 绘画')
const activeColspan = ref([""])
const rates = [ const rates = [
{css: "square", value: "1:1", text: "1:1", img: "/images/mj/rate_1_1.png"}, {css: "square", value: "1:1", text: "1:1", img: "/images/mj/rate_1_1.png"},
@ -105,12 +128,12 @@ const rates = [
{css: "size9-16", value: "9:16", text: "9:16", img: "/images/mj/rate_9_16.png"}, {css: "size9-16", value: "9:16", text: "9:16", img: "/images/mj/rate_9_16.png"},
] ]
const models = [ const models = [
{text: "写实模式MJ-6.0", value: " --v 6", img: "/images/mj/mj-v6.png"}, {text: "MJ-6.0", value: " --v 6", img: "/images/mj/mj-v6.png"},
{text: "优质模式MJ-5.2", value: " --v 5.2", img: "/images/mj/mj-v5.2.png"}, {text: "MJ-5.2", value: " --v 5.2", img: "/images/mj/mj-v5.2.png"},
{text: "动漫风niji5 原始", value: " --niji 5", img: "/images/mj/mj-niji.png"}, {text: "Niji5 原始", value: " --niji 5", img: "/images/mj/mj-niji.png"},
{text: "动漫风niji5 可爱", value: " --niji 5 --style cute", img: "/images/mj/nj1.jpg"}, {text: "Niji5 可爱", value: " --niji 5 --style cute", img: "/images/mj/nj1.jpg"},
{text: "动漫风niji5 风景", value: " --niji 5 --style scenic", img: "/images/mj/nj2.jpg"}, {text: "Niji5 风景", value: " --niji 5 --style scenic", img: "/images/mj/nj2.jpg"},
{text: "动漫风niji5 表现力", value: " --niji 5 --style expressive", img: "/images/mj/nj3.jpg"}, {text: "Niji5 表现力", value: " --niji 5 --style expressive", img: "/images/mj/nj3.jpg"},
] ]
const imgList = ref([]) const imgList = ref([])
const params = ref({ const params = ref({
@ -128,7 +151,31 @@ const params = ref({
tile: false, tile: false,
quality: 0 quality: 0
}) })
const imgCalls = ref(0)
const userId = ref(0)
const router = useRouter()
onMounted(() => {
checkSession().then(user => {
imgCalls.value = user['img_calls']
userId.value = user.id
// fetchRunningJobs(userId.value)
// fetchFinishJobs(userId.value)
// connect()
}).catch(() => {
router.push('/login')
});
const clipboard = new Clipboard('.copy-prompt');
clipboard.on('success', () => {
ElMessage.success("复制成功!");
})
clipboard.on('error', () => {
ElMessage.error('复制失败!');
})
})
// //
const changeRate = (item) => { const changeRate = (item) => {
params.value.rate = item.value params.value.rate = item.value
@ -139,11 +186,45 @@ const changeModel = (item) => {
} }
//
const uploadImg = (file) => {
file.status = "uploading"
//
new Compressor(file.file, {
quality: 0.6,
success(result) {
const formData = new FormData();
formData.append('file', result, result.name);
//
httpPost('/api/upload', formData).then(res => {
file.url = res.data.url
file.status = "done"
}).catch(e => {
file.status = 'failed'
file.message = '上传失败'
showFailToast("图片上传失败:" + e.message)
})
},
error(err) {
console.log(err.message);
},
});
};
const generate = () => { const generate = () => {
httpPost('/api/user/profile/update', form.value).then(() => { if (params.value.prompt === '' && params.value.task_type === "image") {
showSuccessToast('保存成功') return showFailToast("请输入绘画提示词!")
}).catch(() => { }
showFailToast('保存失败') if (params.value.model.indexOf("niji") !== -1 && params.value.raw) {
return showFailToast("动漫模型不允许启用原始模式")
}
params.value.session_id = getSessionId()
params.value.img_arr = imgList.value.map(img => img.url)
httpPost("/api/mj/image", params.value).then(() => {
ElMessage.success("绘画任务推送成功,请耐心等待任务执行...")
imgCalls.value -= 1
}).catch(e => {
ElMessage.error("任务推送失败:" + e.message)
}) })
} }
</script> </script>