Files
lanecarford_front/src/views/Workshop/uploadFace2.vue

159 lines
4.3 KiB
Vue
Raw Normal View History

<script setup lang="ts">
2025-11-17 17:33:32 +08:00
import { ref, reactive, onMounted, computed } from 'vue'
import { useRouter, useRoute } from 'vue-router'
2025-10-23 15:11:24 +08:00
import { uploadCustomerPhoto } from '@/api/workshop'
2025-12-23 09:30:33 +08:00
import { useGenerateStore, useHGenerateStore } from '@/stores'
2025-12-22 13:02:53 +08:00
import { IsHistoryFlow } from '@/types/enum'
2025-10-23 17:01:13 +08:00
const generateStore = useGenerateStore()
2025-12-23 09:30:33 +08:00
const hGenerateStore = useHGenerateStore()
2025-10-23 17:01:13 +08:00
2025-10-16 11:01:54 +08:00
const emit = defineEmits(['view-type'])
onMounted(() => {
emit('view-type', 1)
})
2025-10-10 15:50:21 +08:00
const router = useRouter()
2025-11-17 17:33:32 +08:00
const route = useRoute()
const query = computed(() => route.query)
2025-12-22 13:02:53 +08:00
const isHistoryFlow = computed(() => IsHistoryFlow(query.value.flowType))
2025-10-24 11:47:07 +08:00
const fileData = generateStore.photoInfo
2025-11-03 10:17:32 +08:00
if (!fileData.file?.size) generateStore.updatePhotoInfo({})
// 上传照片
const handleUploadFace = () => {
const input = document.createElement('input')
input.type = 'file'
input.accept = 'image/*'
2025-10-23 17:01:13 +08:00
// input.capture = 'camera'
input.click()
input.onchange = (e: any) => {
const file = e.target.files[0]
if (!file) return
2025-10-23 15:11:24 +08:00
const url = URL.createObjectURL(file)
2025-10-24 11:47:07 +08:00
fileData.id = ''
2025-10-23 15:11:24 +08:00
fileData.url = url
fileData.file = file
// const reader = new FileReader()
// reader.readAsDataURL(file)
// reader.onload = () => {
// faceUrl.value = reader.result as string
// }
}
}
// 生成照片
const handleGenerate = () => {
2025-11-17 17:33:32 +08:00
if (fileData.id) return router.push({ name: 'customize', query: query.value })
2025-10-23 15:11:24 +08:00
if (!fileData.file) return
const formData = new FormData()
2025-10-24 15:19:29 +08:00
formData.append('customerId', generateStore.customerId + '')
formData.append('visitRecordId', generateStore.visitRecordId + '')
2025-10-23 15:11:24 +08:00
formData.append('file', fileData.file)
2025-10-24 11:47:07 +08:00
uploadCustomerPhoto(formData).then((res) => {
2025-11-03 10:17:32 +08:00
generateStore.updatePhotoInfo({ ...res, file: fileData.file })
2025-12-23 09:30:33 +08:00
isHistoryFlow.value ? hGenerateStore.clearCustomizeInfo() : generateStore.clearCustomizeInfo()
2025-11-17 17:33:32 +08:00
router.push({ name: 'customize', query: query.value })
2025-10-23 15:11:24 +08:00
})
}
2025-10-24 15:19:29 +08:00
// 处理照片加载错误
const pictureLoadError = (e: any) => {
2025-10-24 16:21:04 +08:00
generateStore.updatePhotoInfo({})
2025-10-24 15:19:29 +08:00
}
</script>
<template>
<!-- 展示照片 -->
2025-10-16 13:57:00 +08:00
<div class="upload-face-2">
<img src="@/assets/images/workshop/bg/picture_bg.png" class="bg" />
<div class="content">
<div class="title">
Upload your Face<br />
to Try-on
</div>
<!-- 照片 -->
2025-10-23 15:11:24 +08:00
<div class="picture" v-if="fileData.url">
2025-10-24 15:19:29 +08:00
<img :src="fileData.url" @error="pictureLoadError" />
</div>
<div class="btns">
2025-10-23 15:11:24 +08:00
<template v-if="fileData.url">
2025-10-16 13:57:00 +08:00
<button class="sandblasted-blurred" @click="handleUploadFace"><span>Re-try</span></button>
<button class="sandblasted-blurred" @click="handleGenerate"><span>Generate</span></button>
</template>
<button v-else class="sandblasted-blurred" @click="handleUploadFace">
<span>Upload</span>
</button>
</div>
</div>
</div>
</template>
<style scoped lang="less">
2025-10-16 13:57:00 +08:00
.upload-face-2 {
width: 100%;
2025-10-16 11:01:54 +08:00
flex: 1;
overflow: hidden;
position: relative;
color: #fff;
> * {
position: absolute;
}
> .bg {
position: relative;
width: 100%;
height: auto;
2025-11-03 10:17:32 +08:00
min-height: 100%;
object-fit: cover;
}
> .content {
2025-10-16 13:57:00 +08:00
top: 0;
left: 0;
width: 100%;
2025-10-16 13:57:00 +08:00
height: 100%;
display: flex;
flex-direction: column;
align-items: center;
2025-10-16 13:57:00 +08:00
justify-content: center;
> .title {
font-family: satoshiBold;
font-size: 11rem;
text-align: center;
line-height: 124%;
2025-10-16 13:57:00 +08:00
margin-bottom: 7.8rem;
}
> .picture {
width: 65.3rem;
height: 86.5rem;
border-radius: 1rem;
backdrop-filter: blur(5.27rem);
-webkit-backdrop-filter: blur(5.27rem);
-moz-backdrop-filter: blur(5.27rem);
-ms-backdrop-filter: blur(5.27rem);
-o-backdrop-filter: blur(5.27rem);
box-shadow: 1.9rem 2.3rem 1.66rem 0.23rem -0.3rem 0.23rem #36180c40;
border: 0.439rem solid #fff;
// border-image: linear-gradient(90deg,#BF926E94, #ffffff) 1;
display: flex;
align-items: center;
justify-content: center;
> img {
width: 58.9rem;
height: 79.2rem;
border-radius: 1rem;
border: 0.2rem solid #d9d9d9;
2025-10-23 15:11:24 +08:00
object-fit: cover;
}
}
> .btns {
2025-10-16 13:57:00 +08:00
margin-top: 7.8rem;
width: 100%;
display: flex;
justify-content: center;
> button {
2025-12-22 13:02:53 +08:00
width: 35rem;
height: 8.3rem;
margin: 0 5rem;
2025-12-22 13:02:53 +08:00
// border-radius: 4.3rem;
border-width: 0.25rem;
}
}
}
}
</style>