Compare commits
	
		
			No commits in common. "dddfeb947c1fa159edc1aada589e9a1c71b511a2" and "92bfb5d99969b47c056657cc0cc03a49157a1f41" have entirely different histories.
		
	
	
		
			dddfeb947c
			...
			92bfb5d999
		
	
		
| @ -4,7 +4,7 @@ import tmui from "./tmui"; | ||||
| import App from "./App.vue"; | ||||
| // @ts-ignore
 | ||||
| import api from "@/http"; | ||||
| import title from "./components/Title/index.vue"; | ||||
| import title from "./components/title/index.vue"; | ||||
| export function createApp() { | ||||
|   const app = createSSRApp(App); | ||||
|   app.config.globalProperties.$api = api; | ||||
|  | ||||
| @ -16,9 +16,8 @@ | ||||
| 		} | ||||
| 		}, | ||||
| 		{ | ||||
| 			"path": "pages/ticket/index", | ||||
| 			"path": "pages/ticket-details/index", | ||||
| 			"style": { | ||||
| 				"navigationStyle": "custom", | ||||
| 				"navigationBarTitleText": "", | ||||
| 				"enablePullDownRefresh": false, | ||||
| 				"app-plus": { | ||||
|  | ||||
| @ -47,8 +47,8 @@ | ||||
|                     <div class="name" style="color: #000000;border-right:1rpx solid #BBC5E0;">选择时间</div> | ||||
|                     <div class="time"> | ||||
|                         <span style="width: 300rpx;">2023年12月16日</span> | ||||
|                         <div style="display: flex;align-items: center;" @click="showHandle"> | ||||
|                             <span>选择</span> | ||||
|                         <div style="display: flex;align-items: center;"> | ||||
|                             选择 | ||||
|                             <tm-icon name="tmicon-angle-right" :font-size="24"></tm-icon> | ||||
|                         </div> | ||||
|                     </div> | ||||
| @ -59,29 +59,12 @@ | ||||
|                     <div style="margin-left: 20rpx;" class="stepper"> | ||||
|                         <div style="color: #B29E92;font-size: 24rpx">*单次最多可预约10人</div> | ||||
|                         <div> | ||||
|                             <tm-stepper v-model="formData.num" color="#ef952e" bgColor="primary" circular :defaultValue="0" | ||||
|                                 :max="10" :height="40" :width="160" @change="changeNum"></tm-stepper> | ||||
|                             <tm-stepper v-model="reactive.num" color="#ef952e" bgColor="primary" circular :defaultValue="0" | ||||
|                                 :max="10" :height="40" :width="160" class="itme-stepper"></tm-stepper> | ||||
|                         </div> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <div v-for="(item, index) in visitorsList" class="card" :key="index"> | ||||
|                 <div class="card-item"> | ||||
|                     <div class="name">姓名</div> | ||||
|                     <div style="margin-left: 20rpx; color: #000000;"> | ||||
|                         <input type="text" v-model="item.name" /> | ||||
|                     </div> | ||||
|                 </div> | ||||
|                 <tm-divider realColor></tm-divider> | ||||
|                 <div class="card-item"> | ||||
|                     <div class="name">身份证号</div> | ||||
|                     <div style="margin-left: 20rpx; color: #000000;"> | ||||
|                         <input type="idcard" v-model="item.idCard" /> | ||||
|                     </div> | ||||
|                 </div> | ||||
|             </div> | ||||
|             <tm-button @click="reservation" color="#000000" :width="436" :height="60" :round="25">预约</tm-button> | ||||
|             <select-day :show.sync="show"></select-day> | ||||
|         </div> | ||||
|     </div> | ||||
| </template> | ||||
| @ -89,22 +72,17 @@ | ||||
| <script setup> | ||||
| import { onMounted, ref, reactive, watch } from "vue"; | ||||
| import { useTimer } from '@/tmui/tool/useFun/useTimer' | ||||
| import selectDay from './select-day/index' | ||||
| const { start, stop, formattedTime, status, restart, timeObj, times, change } = useTimer({ | ||||
|     totalTime: 10, unit: 'ss', format: 'ss秒' | ||||
| }); | ||||
| let height = ref(0) | ||||
| let code = ref('获取验证码') | ||||
| let isCode = ref(true) | ||||
| let show = ref(false) | ||||
| const formData = reactive({ | ||||
|     phone: '', | ||||
|     code: '', | ||||
|     num: 0 | ||||
| }) | ||||
| let visitorsList = ref([]) | ||||
| const msg = ref(null) | ||||
| 
 | ||||
| onMounted(() => { | ||||
|     uni.createSelectorQuery().select('.title-block').boundingClientRect(data => { | ||||
|         let res = uni.getSystemInfoSync(); | ||||
| @ -119,49 +97,15 @@ const sendCode = () => { | ||||
|     } | ||||
| } | ||||
| watch(times, (newValue) => { | ||||
|     console.log(newValue) | ||||
|     if (newValue === 0) { | ||||
|         code.value = '重新获取'; | ||||
|         isCode.value = true; | ||||
|         stop() | ||||
|     } | ||||
| }) | ||||
| const changeNum = (value) => { | ||||
|     formData.num = value | ||||
| } | ||||
| watch(() => formData.num, (newValue, oldValue) => { | ||||
|     console.log(newValue, oldValue) | ||||
|     if (newValue > oldValue) { | ||||
|         for (let i = 0; i < newValue - oldValue; i++) { | ||||
|             visitorsList.value.push({ | ||||
|                 name: '', | ||||
|                 idCard: '' | ||||
|             }) | ||||
|         } | ||||
|     } | ||||
|     if (newValue < oldValue) { | ||||
|         visitorsList.value.splice(-(oldValue - newValue)) | ||||
|     } | ||||
| }) | ||||
| 
 | ||||
| const reservation = () => { | ||||
|     console.log(visitorsList.value) | ||||
|     const result = visitorsList.value.filter((item) => item.name && item.idCard) | ||||
|     if (result.map((item) => item.idCard).some((n, index, arr) => arr.indexOf(n) !== index)) { | ||||
|         return uni.showToast({ | ||||
|             title: '身份证不能重复', | ||||
|             icon: "error", | ||||
|         }); | ||||
|     } | ||||
|     if (Object.values(formData).some((item) => !item)) { | ||||
|         return uni.showToast({ | ||||
|             title: '信息填写完整', | ||||
|             icon: "error", | ||||
|         }); | ||||
|     } | ||||
| } | ||||
| const showHandle = () => { | ||||
|     show.value = false | ||||
| } | ||||
| 
 | ||||
| </script> | ||||
| 
 | ||||
| <style lang="scss" scoped> | ||||
| @ -196,30 +140,6 @@ const showHandle = () => { | ||||
|             color: #fff; | ||||
|         } | ||||
| 
 | ||||
|         .card { | ||||
|             margin-top: 20rpx; | ||||
|             width: 100%; | ||||
|             height: 190rpx; | ||||
|             background-color: #fff; | ||||
|             border-radius: 24rpx; | ||||
|             padding: 32rpx; | ||||
|             display: flex; | ||||
|             flex-direction: column; | ||||
|             box-sizing: border-box; | ||||
|             color: black; | ||||
| 
 | ||||
|             .card-item { | ||||
|                 display: flex; | ||||
|                 align-items: center; | ||||
|             } | ||||
| 
 | ||||
|             .name { | ||||
|                 width: 200rpx; | ||||
|                 border-right: 1rpx solid #BBC5E0; | ||||
|             } | ||||
| 
 | ||||
|         } | ||||
| 
 | ||||
|         .title-detail { | ||||
|             margin-top: 20rpx; | ||||
|             width: 100%; | ||||
|  | ||||
| @ -1,25 +0,0 @@ | ||||
| <template> | ||||
|     <div> | ||||
|         <tm-drawer placement="bottom" okText='确认' v-model:show="show" @close="close"> | ||||
|         </tm-drawer> | ||||
|     </div> | ||||
| </template> | ||||
| 
 | ||||
| <script setup> | ||||
| import { defineProps, onMounted, defineEmits, watch } from 'vue' | ||||
| const props = defineProps({ | ||||
|     show: { | ||||
|         type: Boolean, | ||||
|         default: false | ||||
|     } | ||||
| }) | ||||
| 
 | ||||
| const emits = defineEmits(["update:show"]); | ||||
| 
 | ||||
| 
 | ||||
| const close = () => { | ||||
|     emits("update:show", false); | ||||
| } | ||||
| </script> | ||||
| 
 | ||||
| <style lang="scss" scoped></style> | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user