171 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			171 lines
		
	
	
		
			4.6 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
| <template>
 | |
| 	<view class="page flex-col">
 | |
| 		<view style="width: 100%;background: #f4f5f6;box-sizing: border-box;padding-top: 88px;">
 | |
| 			<headers titles="课程详情">
 | |
| 				<uni-icons type="left" color="#000000" size="22px"></uni-icons>
 | |
| 			</headers>
 | |
| 		</view>
 | |
| 		<scroll-view :style="{ height: scrollHeight + 'px' }" scroll-y="true" class="scroll-view">
 | |
| 			<view class="group_3 flex-col">
 | |
| 				<image style="width: 100%; height: 100%;" :src="imagesUrl + '/' + courseDetails.photo" />
 | |
| 			</view>
 | |
| 			<view class="group_4 flex-col">
 | |
| 				<view class="section_2 flex-row justify-between">
 | |
| 					<view class="text-wrapper_1">
 | |
| 						<text class="text_3">¥</text>
 | |
| 						<text class="text_4">{{ courseDetails.price ? courseDetails.price.toFixed(2) : '--' }}</text>
 | |
| 					</view>
 | |
| 					<!--        <text class="text_5">¥3000.00</text>-->
 | |
| 				</view>
 | |
| 				<text class="text_6">{{ courseDetails.name }}</text>
 | |
| 				<view class="section_3 flex-row justify-between">
 | |
| 					<view class="text-wrapper_2 flex-col">
 | |
| 						<text class="text_7">{{ courseDetails.tittle }}</text>
 | |
| 					</view>
 | |
| 					<view class="text-wrapper_3 flex-col">
 | |
| 						<text class="text_8">{{ courseDetails.type }}</text>
 | |
| 					</view>
 | |
| 				</view>
 | |
| 				<text class="text_9">周一至周日 08:00-18:00</text>
 | |
| 			</view>
 | |
| 			<view class="group_5 flex-col">
 | |
| 				<view class="section_4 flex-row justify-between">
 | |
| 					<view class="block_3 flex-col"></view>
 | |
| 					<text class="text_10">课程介绍</text>
 | |
| 				</view>
 | |
| 				<view class="u-content" v-if="courseDetails.remark">
 | |
| 					<u-parse :content="courseDetails.remark"></u-parse>
 | |
| 				</view>
 | |
| 				<view class="u-content" v-else>
 | |
| 					<u-empty mode="list" text="该课程没有简介...">
 | |
| 					</u-empty>
 | |
| 				</view>
 | |
| 			</view>
 | |
| 		</scroll-view>
 | |
| 		<view class="group_6 flex-row">
 | |
| 			<view class="image-text_1 flex-col justify-between" @click="zxkf()">
 | |
| 				<image class="label_2" referrerpolicy="no-referrer"
 | |
| 					src="/static/lanhu_kechengxiangqing/FigmaDDSSlicePNG283b4603035848d5dcc7209d10653327.png" />
 | |
| 				<text class="text-group_1">咨询客服</text>
 | |
| 			</view>
 | |
| 			<view class="text-wrapper_4 flex-col" @click="goRegisterNow()">
 | |
| 				<text class="text_11">立即报名</text>
 | |
| 			</view>
 | |
| 		</view>
 | |
| 	</view>
 | |
| </template>
 | |
| <script>
 | |
| 	import request from "@/utils/request";
 | |
| 	import config from "@/config.js"
 | |
| 	import {
 | |
| 		getLocalUserInfo,
 | |
| 		getUserInfo,
 | |
| 		getToken
 | |
| 	} from "@/utils/auth";
 | |
| 	import headers from "@/components/header/headers.vue";
 | |
| 
 | |
| 	export default {
 | |
| 		components: {
 | |
| 			headers
 | |
| 		},
 | |
| 		data() {
 | |
| 			return {
 | |
| 				courseId: undefined,
 | |
| 				tenantId: undefined,
 | |
| 				courseDetails: [],
 | |
| 				driveSchoolPhone: [],
 | |
| 				imagesUrl: config.imagesUrl,
 | |
| 				userDetails: [],
 | |
| 				scrollHeight: 0,
 | |
| 			};
 | |
| 		},
 | |
| 		onLoad(options) {
 | |
| 			this.courseId = options.courseId;
 | |
| 			this.tenantId = options.tenantId;
 | |
| 			this.getCourseDetails();
 | |
| 			this.userDetails = getLocalUserInfo();
 | |
| 			this.getServicePhone()
 | |
| 		},
 | |
| 		onReady() {
 | |
| 			// 动态计算滚动区域高度
 | |
| 			this.calculateScrollHeight();
 | |
| 		},
 | |
| 		methods: {
 | |
| 			goBack() {
 | |
| 				uni.navigateBack({
 | |
| 					delta: 1
 | |
| 				});
 | |
| 			},
 | |
| 			getCourseDetails() {
 | |
| 				request({
 | |
| 					url: '/app-api/dl-drive-school-course-small/get',
 | |
| 					method: 'GET',
 | |
| 					params: {
 | |
| 						id: this.courseId,
 | |
| 						tenantId: this.tenantId,
 | |
| 					},
 | |
| 					tenantIdFlag: false
 | |
| 				}).then(res => {
 | |
| 					this.courseDetails = res.data;
 | |
| 				})
 | |
| 			},
 | |
| 			zxkf() {
 | |
| 				uni.makePhoneCall({
 | |
| 					phoneNumber: this.driveSchoolPhone.phone
 | |
| 				});
 | |
| 			},
 | |
| 			getServicePhone() {
 | |
| 				request({
 | |
| 					url: '/app-api/dl-drive-school-course-small/getServicePhone',
 | |
| 					method: 'GET',
 | |
| 					params: {
 | |
| 						tenantId: this.tenantId,
 | |
| 					}
 | |
| 				}).then(res => {
 | |
| 					this.driveSchoolPhone = res.data
 | |
| 				})
 | |
| 			},
 | |
| 
 | |
| 			calculateScrollHeight() {
 | |
| 				// 获取屏幕高度
 | |
| 				const screenHeight = uni.getSystemInfoSync().windowHeight;
 | |
| 				// 获取顶部区域高度
 | |
| 				const topHeight = 166;
 | |
| 				// 计算滚动区域高度
 | |
| 				this.scrollHeight = screenHeight - topHeight;
 | |
| 			},
 | |
| 
 | |
| 			goRegisterNow() {
 | |
| 				console.log('token', getToken())
 | |
| 				if (!getToken()) {
 | |
| 					uni.showModal({
 | |
| 						title: '未登录',
 | |
| 						content: '请先登录',
 | |
| 						confirmText: '去登录',
 | |
| 						success: (res) => {
 | |
| 							if (res.confirm) {
 | |
| 								uni.navigateTo({
 | |
| 									url: '/pages/login/login'
 | |
| 								});
 | |
| 							}
 | |
| 						}
 | |
| 					});
 | |
| 					return;
 | |
| 				}
 | |
| 				uni.navigateTo({
 | |
| 					url: `/pagesA/register/index?courseId=${this.courseDetails.id}&userId=${this.userDetails.id}&tenantId=${this.tenantId}`,
 | |
| 					// url: '/pages/index/bmPage'
 | |
| 				});
 | |
| 			},
 | |
| 		}
 | |
| 	};
 | |
| </script>
 | |
| <style lang='scss'>
 | |
| 	@import '../common/common.scss';
 | |
| 	@import './assets/style/index.rpx.scss';
 | |
| 
 | |
| 	.u-content {
 | |
| 		margin-top: 20rpx;
 | |
| 		padding: 10rpx;
 | |
| 	}
 | |
| </style> |