homeQuick.vue 6.85 KB
<template>
  <div v-if="language == 0" class="itemBox">
    <el-row :gutter="20">
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item" @click="popRemark(1)"><img src="@/assets/dance/btn01.png">酒店预订</div>
      </el-col>
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item" @click="popRemark(2)"><img src="@/assets/dance/btn02.png">车辆预订</div>
      </el-col>
      <!--      <el-col :sm="12" :lg="8" :xs="12">-->
      <!--        <div class="item" @click="popRemark(3)"><img src="@/assets/dance/btn03.png">餐饮预订</div>-->
      <!--      </el-col>-->
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item" @click="popRemark(8)"><img src="@/assets/dance/btn08.png">旅游服务</div>
      </el-col>
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item" @click="popRemark(0)"><img src="@/assets/dance/btn04.png">票务预订</div>
      </el-col>
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item" @click="popRemark(4)"><img src="@/assets/dance/btn05.png">化妆预约</div>
      </el-col>
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item" @click="popRemark(5)"><img src="@/assets/dance/btn06.png">拍照预约</div>
      </el-col>
    </el-row>
  </div>
  <div v-else class="itemBox_en">
    <el-row :gutter="20">
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item_en" @click="popRemark(1)"><img src="@/assets/dance/btn01.png">
          <p>HOTEL RESERVATION</p>
        </div>
      </el-col>
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item_en" @click="popRemark(2)"><img src="@/assets/dance/btn02.png">
          <p>TRANSPORTATION RESERVATION</p>
        </div>
      </el-col>
      <!--      <el-col :sm="12" :lg="8" :xs="12">-->
      <!--        <div class="item_en" @click="popRemark(3)"><img src="@/assets/dance/btn03.png">-->
      <!--          <p>DINING RESERVATION</p>-->
      <!--        </div>-->
      <!--      </el-col>-->
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item_en" @click="popRemark(8)"><img src="@/assets/dance/btn08.png">
          <p>TRAVEL SERVICE</p>
        </div>
      </el-col>
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item_en" @click="popRemark(0)">
          <img src="@/assets/dance/btn04.png">
          <p>TICKET BOOKING</p>
        </div>
      </el-col>
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item_en" @click="popRemark(4)"><img src="@/assets/dance/btn05.png">
          <p>MAKEUP APPOINTMENT</p>
        </div>
      </el-col>
      <el-col :lg="8" :sm="12" :xs="12">
        <div class="item_en" @click="popRemark(5)"><img src="@/assets/dance/btn06.png">
          <p>PHOTOGRAPHY APPOINTMENT</p>
        </div>
      </el-col>
    </el-row>
  </div>
  <order-remark ref="orderRemarkRef" @submit="goBooking" />

</template>

<script setup>
import { useRouter } from 'vue-router'

const router = useRouter()
import OrderRemark from '@/viewsPc/components/orderRemark'

const { proxy } = getCurrentInstance()
import { useStorage } from '@vueuse/core/index'
import { ElMessage } from 'element-plus'
import { getCurrentInstance } from '@vue/runtime-core'
import { computed, onMounted, watch } from 'vue'
import { getBaseInfoByActiveId } from '@/apiPc/booking'

const props = defineProps({
  matchId: {
    type: String,
    required: true,
    default: '0'
  },
  cptName: {
    type: String,
    required: true,
    default: ''
  }
})
const language = useStorage('language', 0)
const form = ref({})
const matchId = computed(() => props.matchId)

watch(matchId, (val) => {
  if (val && val != '0') {
    getBaseInfoByActiveId(props.matchId).then(res => {
      form.value = res.data || null
    }).catch(err => {
      console.log(err)
      form.value = null
    })
  }
})

onMounted(() => {
  
})

function building() {
  ElMessage.warning(language.value == 0 ? '感谢您对本次比赛的关注,该服务暂无可预订信息,敬请期待。' : 'Thank you for your attention to this competition. The service is currently unavailable for booking. Please stay tuned.')
}

function popRemark(type) {
  if (!form.value) {
    building()
    return
  }
  if ((form.value.isJdView == 0 && type == '1') ||
    (form.value.isCarView == 0 && type == '2') ||
    (form.value.isFoodView == 0 && type == '3') ||
    (form.value.isMealView == 0 && type == '4') ||
    (form.value.isPhotoView == 0 && type == '5') ||
    (form.value.isTicket == 0 && type == '0') ||
    (form.value.isScenicView == 0 && type == '8')
  ) {
    building()
    return
  }
  const params = {
    matchId: props.matchId,
    title: language.value == 0 ? '预订说明' : 'Booking Instructions',
    type: type,
    cptName: props.cptName
  }
  proxy.$refs['orderRemarkRef'].open(params)
}

function goBooking(n) {
  switch (n) {
    case 0:
      // 票务
      router.push({
        path: `/booking/ticket/${props.matchId}`
        // params: {id:props.matchId},
        // query: {id: props.matchId}
      })
      break
    case 1:
      // 酒店
      router.push({ path: `/booking/hotel/${props.matchId}` })
      break
    case 2:
      // 车辆
      router.push({ path: `/booking/car/${props.matchId}` })
      break
    case 3:
      // 餐饮
      router.push({ path: `/booking/dinner/${props.matchId}` })
      break
    case 4:
      // 化妆
      router.push({ path: `/booking/makeup/${props.matchId}` })
      break
    case 5:
      // 拍照
      router.push({ path: `/booking/photography/${props.matchId}` })
      break
    case 8:
      // 旅游
      router.push({ path: `/booking/travel/${props.matchId}` })
      break
  }
}
</script>

<style lang="scss" scoped>
.itemBox {
  padding: 20px 40px;
}

.itemBox_en {
  padding: 20px 40px;
  
  p {
    margin: 0;
    height: 40px;
    line-height: 20px;
    display: flex;
    align-items: center;
  }
}

.item {
  box-shadow: 0px 0px 21px 0px rgba(41, 23, 101, 0.14);
  margin: 10px 0;
  display: flex;
  align-items: center;
  font-size: 22px;
  background: url("@/assets/dance/btn_bg.png") no-repeat left #FFFFFF;
  background-size: 100% 100%;
  border-radius: 15px;
  
  img {
    margin: 0 5%;
  }
}

.item_en {
  box-shadow: 0px 0px 21px 0px rgba(41, 23, 101, 0.14);
  margin: 40px 0 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  text-align: center;
  color: #333;
  font-size: 18px;
  flex-direction: column;
  padding: 35px 10px 20px;
  background: url("@/assets/dance/znbb.png") no-repeat left #FFFFFF;
  background-size: cover;
  position: relative;
  border-radius: 15px;
  
  img {
    position: absolute;
    top: -30px;
    transition: all 0.2s;
  }
  
  &:hover {
    box-shadow: 0 0 10px #333;
    
    img {
      transform: rotateY(180deg);
    }
    
    p {
      color: #000;
    }
  }
}

@media screen and (max-width: 768px) {
  .itemBox, .itemBox_en {
    padding: 0 20px 20px
  }
  .item {
    font-size: 16px;
    
    img {
      width: 50px;
      height: 50px
    }
  }
}
</style>