jiangchengfeiyi-xiaochengxu/pages/clothesRent/component/clothesAttributePlus.vue

278 lines
6.8 KiB
Vue
Raw Normal View History

2025-03-22 03:18:54 +00:00
<template>
<view class="flex-col page">
<view class="flex-col group">
<view class="flex-row justify-between self-stretch">
<text class="font text">请选择产品规格</text>
<image
2025-03-22 15:09:53 +00:00
@click="closePopup"
2025-03-22 03:18:54 +00:00
class="image"
:src="clothesRentUrl + '/component/cha.png'"
/>
</view>
<view class="flex-row self-stretch group_2">
<image
2025-03-22 15:09:53 +00:00
class="shrink-0 image_2" mode="aspectFill"
:src="publicPath + photoProductsInfo.introImg"
2025-03-22 03:18:54 +00:00
/>
<view class="flex-col shrink-0 group_3 ml-13">
2025-03-22 15:09:53 +00:00
<text class="self-stretch font_2 text_2">{{ photoProductsInfo.name }}</text>
<text class="mt-48 self-start font_2 text_3">{{ photoProductsInfo.price.toFixed(2) }}</text>
2025-03-22 03:18:54 +00:00
</view>
</view>
<view class="flex-col self-stretch">
<view class="flex-col justify-start items-start relative">
<view class="group_4"></view>
<text class="font_2 text_4 pos">妆造服务</text>
</view>
<view class="flex-row">
2025-03-22 15:09:53 +00:00
<view :style="styleObj1" class="flex-col justify-start items-center text-wrapper" @click="selectStatus1(true)">
2025-03-22 03:18:54 +00:00
<text class="font_3 text_5">本店上妆</text>
</view>
2025-03-22 15:09:53 +00:00
<view :style="styleObj2" class="flex-col justify-start items-center text-wrapper ml-17" @click="selectStatus(false)">
2025-03-22 03:18:54 +00:00
<text class="font_3 text_6">无需妆造</text>
</view>
</view>
</view>
<text class="self-start font_2 text_7">拍摄场地</text>
<view class="flex-row equal-division">
<view class="flex-col section equal-division-item">
<view class="flex-row justify-between items-end self-stretch">
<image
class="image_3"
:src="clothesRentUrl + '/component/indoor.png'"
/>
<view class="section_2"></view>
</view>
<text class="self-start font_3 text_8 mt-5">室内</text>
</view>
<view class="flex-col section equal-division-item ml-19">
<view class="flex-row justify-between items-end self-stretch">
<image
class="image_4"
:src="clothesRentUrl + '/component/outdoor.png'"
/>
<view class="section_2"></view>
</view>
<text class="self-start font_3 text_8 mt-5">室外</text>
</view>
</view>
</view>
<view class="flex-row justify-between items-center group_5">
<view class="flex-row items-baseline">
<text class="font text_9">定金</text>
2025-03-22 15:09:53 +00:00
<text class="font text_10">{{ photoProductsInfo.price.toFixed(2) }}</text>
2025-03-22 03:18:54 +00:00
</view>
<view class="flex-col justify-start items-center text-wrapper_2"><text class="text_11">确定</text></view>
</view>
</view>
</template>
<script setup>
2025-03-22 15:09:53 +00:00
import {onMounted, onUnmounted, ref} from 'vue'
import { clothesRentUrl } from '../../../common/globalImagesUrl';
import emitter from '../../../utils/emitter';
import { publicPath } from '../../../common/globalImagesUrl';
let style1 = { color: '#323232', borderColor: '#C3C3C3', backgroundColor: '#fff' }
let style2 = { color: '#E79EA1', borderColor: '#FFB6B9', backgroundColor: '#FBDEDF'}
const photoProductsInfo = ref({})
const styleObj1 = ref({})
const styleObj2 = ref({})
let point = -1
const closePopup = () => {
emitter.emit('closeClothesAttributePlusPopup')
}
const getPhotoProductsInfoHandler = (val) => {
console.log(val)
photoProductsInfo.value = val
}
const selectStatus = (val) => {
if (val && point ) {
}
}
onMounted(() => {
emitter.on('getPhotoProductsInfo', getPhotoProductsInfoHandler)
})
onUnmounted(() => {
emitter.off('getPhotoProductsInfo', getPhotoProductsInfoHandler)
})
2025-03-22 03:18:54 +00:00
</script>
<style scoped lang="scss">
.ml-13 {
margin-left: 24.38rpx;
}
.ml-17 {
margin-left: 31.88rpx;
}
.mt-5 {
margin-top: 9.38rpx;
}
.ml-19 {
margin-left: 35.63rpx;
}
.page {
background-color: #ffffff;
width: 100%;
overflow-y: auto;
overflow-x: hidden;
height: 100%;
2025-03-22 15:09:53 +00:00
border-radius: 20rpx 20rpx 0 0;
2025-03-22 03:18:54 +00:00
}
.group {
padding: 37.5rpx 22.5rpx;
border-bottom: solid 1.88rpx #0000001f;
}
.font {
font-size: 37.5rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
color: #323232;
}
.text {
margin: 3.75rpx 0;
line-height: 36.34rpx;
}
.image {
margin-right: 3.75rpx;
width: 52.5rpx;
height: 41.25rpx;
}
.group_2 {
margin-top: 35.63rpx;
}
.image_2 {
border-radius: 18.75rpx;
width: 198.75rpx;
height: 200.63rpx;
}
.group_3 {
2025-03-22 15:09:53 +00:00
position: relative;
2025-03-22 03:18:54 +00:00
margin-right: 112.5rpx;
margin-bottom: 7.5rpx;
width: 369.38rpx;
}
.font_2 {
font-size: 33.75rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 30.58rpx;
color: #323232;
}
.text_2 {
line-height: 41.25rpx;
}
.text_3 {
margin-left: 7.5rpx;
line-height: 22.54rpx;
2025-03-22 15:09:53 +00:00
position: absolute;
bottom: 0;
2025-03-22 03:18:54 +00:00
}
.group_4 {
margin-left: 26.25rpx;
border-radius: 9.38rpx;
width: 123.75rpx;
height: 97.95rpx;
}
.text_4 {
line-height: 32.31rpx;
}
.pos {
position: absolute;
left: 0;
top: 50%;
transform: translateY(-50%);
}
.text-wrapper {
padding: 15rpx 0;
background-color: #ffffff;
border-radius: 37.5rpx;
width: 159.38rpx;
height: 54.38rpx;
2025-03-22 15:09:53 +00:00
border: solid 1.88rpx #c3c3c3;
2025-03-22 03:18:54 +00:00
}
.font_3 {
font-size: 26.25rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 24.21rpx;
color: #323232;
}
.text_5 {
line-height: 24.41rpx;
}
.text_6 {
line-height: 23.89rpx;
}
.text_7 {
margin-top: 33.75rpx;
}
.equal-division {
align-self: stretch;
margin: 41.25rpx 15rpx 0;
}
.section {
flex: 1 1 320.63rpx;
}
.equal-division-item {
padding: 18.75rpx 22.5rpx;
background-color: #ffffff;
border-radius: 18.75rpx;
height: 157.5rpx;
border-left: solid 1.88rpx #c3c3c3;
border-right: solid 1.88rpx #c3c3c3;
border-top: solid 1.88rpx #c3c3c3;
border-bottom: solid 1.88rpx #c3c3c3;
}
.image_3 {
opacity: 0.85;
border-radius: 18.75rpx;
width: 138.75rpx;
height: 84.38rpx;
}
.section_2 {
margin-right: 15rpx;
background-color: #ffffff;
border-radius: 50%;
width: 45rpx;
height: 45rpx;
border-left: solid 1.88rpx #c3c3c3;
border-right: solid 1.88rpx #c3c3c3;
border-top: solid 1.88rpx #c3c3c3;
border-bottom: solid 1.88rpx #c3c3c3;
}
.text_8 {
margin-left: 45rpx;
}
.image_4 {
border-radius: 15rpx;
width: 138.75rpx;
height: 84.38rpx;
}
.group_5 {
padding: 37.5rpx 22.5rpx 31.88rpx;
}
.text_9 {
line-height: 34.42rpx;
}
.text_10 {
color: #e79ea1;
line-height: 25.05rpx;
}
.text-wrapper_2 {
padding: 22.5rpx 0;
background-color: #e79ea1;
border-radius: 187.5rpx;
width: 241.88rpx;
height: 76.88rpx;
}
.text_11 {
color: #ffffff;
font-size: 30rpx;
font-family: FZSongKeBenXiuKaiS-R-GB;
line-height: 28.01rpx;
}
@import url(../../../common/css/global.css);
</style>