jiangchengfeiyi-xiaochengxu/pages/clothesRent/component/clothesAttributePlus.vue
2025-03-22 23:09:53 +08:00

278 lines
6.8 KiB
Vue
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<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
@click="closePopup"
class="image"
:src="clothesRentUrl + '/component/cha.png'"
/>
</view>
<view class="flex-row self-stretch group_2">
<image
class="shrink-0 image_2" mode="aspectFill"
:src="publicPath + photoProductsInfo.introImg"
/>
<view class="flex-col shrink-0 group_3 ml-13">
<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>
</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">
<view :style="styleObj1" class="flex-col justify-start items-center text-wrapper" @click="selectStatus1(true)">
<text class="font_3 text_5">本店上妆</text>
</view>
<view :style="styleObj2" class="flex-col justify-start items-center text-wrapper ml-17" @click="selectStatus(false)">
<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>
<text class="font text_10">{{ photoProductsInfo.price.toFixed(2) }}</text>
</view>
<view class="flex-col justify-start items-center text-wrapper_2"><text class="text_11">确定</text></view>
</view>
</view>
</template>
<script setup>
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)
})
</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%;
border-radius: 20rpx 20rpx 0 0;
}
.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 {
position: relative;
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;
position: absolute;
bottom: 0;
}
.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;
border: solid 1.88rpx #c3c3c3;
}
.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>