|
@@ -1,5 +1,9 @@
|
|
|
import { Component, AfterViewInit } from '@angular/core';
|
|
|
import { Router } from '@angular/router';
|
|
|
+import { ModalController, NavController } from '@ionic/angular';
|
|
|
+import { HttpClient } from '@angular/common/http';
|
|
|
+import { Observable } from 'rxjs';
|
|
|
+import { map, catchError } from 'rxjs/operators';
|
|
|
|
|
|
@Component({
|
|
|
selector: 'app-tab1',
|
|
@@ -61,8 +65,6 @@ export class Tab1Page implements AfterViewInit {
|
|
|
cardWidth = 216; // 每个卡片的宽度加上间距 (200 + 16)
|
|
|
isCyclic: boolean = true; // 是否启用循环滑动
|
|
|
|
|
|
- constructor(private router: Router) {}
|
|
|
-
|
|
|
ngAfterViewInit() {
|
|
|
this.updateCarousel(); // 确保初始状态正确
|
|
|
this.calculateCardWidth(); // 动态计算卡片宽度
|
|
@@ -93,7 +95,6 @@ export class Tab1Page implements AfterViewInit {
|
|
|
|
|
|
// 触摸开始
|
|
|
onTouchStart(event: TouchEvent) {
|
|
|
- // event.preventDefault(); // 防止默认行为
|
|
|
this.startX = event.touches[0].clientX;
|
|
|
this.isDragging = true;
|
|
|
}
|
|
@@ -101,7 +102,6 @@ export class Tab1Page implements AfterViewInit {
|
|
|
// 触摸移动
|
|
|
onTouchMove(event: TouchEvent) {
|
|
|
if (this.isDragging) {
|
|
|
- // event.preventDefault(); // 防止默认行为
|
|
|
const touchX = event.touches[0].clientX;
|
|
|
const deltaX = touchX - this.startX;
|
|
|
this.currentTranslate = -this.currentIndex * this.cardWidth + deltaX; // 动态更新平移值
|
|
@@ -172,6 +172,18 @@ export class Tab1Page implements AfterViewInit {
|
|
|
this.currentIndex = Math.max(0, Math.min(cardIndex, this.doctors.length - 1));
|
|
|
this.updateCarousel();
|
|
|
}
|
|
|
+ // 在线咨询按钮点击事件
|
|
|
+ onConsultNow() {
|
|
|
+ console.log(`立即咨询`);
|
|
|
+ this.router.navigate(['/consultation']);
|
|
|
+ }
|
|
|
+
|
|
|
+ // 在线咨询按钮点击事件
|
|
|
+ onlineConsultNow(doctor: any) {
|
|
|
+ console.log(`在线咨询: ${doctor.name}`);
|
|
|
+ // 跳转到 ConsultationPage 并传递医生信息
|
|
|
+ this.router.navigate(['/consultation'], { state: { doctor: doctor } });
|
|
|
+ }
|
|
|
|
|
|
// 导航到指定路由
|
|
|
navigateTo(route: string) {
|
|
@@ -183,4 +195,100 @@ export class Tab1Page implements AfterViewInit {
|
|
|
// 这里可以添加发布求医信息的逻辑
|
|
|
console.log('发布求医信息');
|
|
|
}
|
|
|
+
|
|
|
+ isLoginModalOpen = false; // 声明 isLoginModalOpen 属性
|
|
|
+ user = {
|
|
|
+ username: '',
|
|
|
+ password: ''
|
|
|
+ };
|
|
|
+
|
|
|
+ constructor(
|
|
|
+ private router: Router,
|
|
|
+ private modalController: ModalController,
|
|
|
+ private navCtrl: NavController,
|
|
|
+ private http: HttpClient // 注入 HttpClient
|
|
|
+ ) {}
|
|
|
+
|
|
|
+ openLoginModal() {
|
|
|
+ this.isLoginModalOpen = true;
|
|
|
+ console.log('打开登录/注册模态框');
|
|
|
+ }
|
|
|
+
|
|
|
+ closeLoginModal() {
|
|
|
+ this.isLoginModalOpen = false;
|
|
|
+ console.log('关闭登录/注册模态框');
|
|
|
+ }
|
|
|
+
|
|
|
+ onLoginModalDismissed(event: any) {
|
|
|
+ this.isLoginModalOpen = false;
|
|
|
+ console.log('登录/注册模态框已关闭');
|
|
|
+ }
|
|
|
+
|
|
|
+ onLoginFormSubmit(formValue: any) {
|
|
|
+ // 处理登录逻辑
|
|
|
+ console.log('登录表单提交:', formValue);
|
|
|
+
|
|
|
+ // 发送登录请求
|
|
|
+ this.loginUser(formValue.username, formValue.password)
|
|
|
+ .subscribe(
|
|
|
+ (response) => {
|
|
|
+ console.log('登录成功:', response);
|
|
|
+ // 这里可以处理登录成功的逻辑,例如跳转到主页
|
|
|
+ this.closeLoginModal();
|
|
|
+ },
|
|
|
+ (error) => {
|
|
|
+ console.error('登录失败:', error);
|
|
|
+ // 这里可以处理登录失败的逻辑,例如显示错误消息
|
|
|
+ this.closeLoginModal();
|
|
|
+ }
|
|
|
+ );
|
|
|
+ }
|
|
|
+
|
|
|
+ registerUser() {
|
|
|
+ // 处理注册逻辑
|
|
|
+ console.log('注册用户:', this.user);
|
|
|
+
|
|
|
+ // 发送注册请求
|
|
|
+ this.registerNewUser(this.user.username, this.user.password)
|
|
|
+ .subscribe(
|
|
|
+ (response) => {
|
|
|
+ console.log('注册成功:', response);
|
|
|
+ // 这里可以处理注册成功的逻辑,例如跳转到登录页面
|
|
|
+ this.closeLoginModal();
|
|
|
+ },
|
|
|
+ (error) => {
|
|
|
+ console.error('注册失败:', error);
|
|
|
+ // 这里可以处理注册失败的逻辑,例如显示错误消息
|
|
|
+ this.closeLoginModal();
|
|
|
+ }
|
|
|
+ );
|
|
|
+ }
|
|
|
+
|
|
|
+ private loginUser(username: string, password: string): Observable<any> {
|
|
|
+ const loginUrl = 'YOUR_API_ENDPOINT/login'; // 替换为你的登录 API 端点
|
|
|
+ return this.http.post(loginUrl, { username, password })
|
|
|
+ .pipe(
|
|
|
+ map(response => response),
|
|
|
+ catchError(error => {
|
|
|
+ throw error;
|
|
|
+ })
|
|
|
+ );
|
|
|
+ }
|
|
|
+
|
|
|
+ private registerNewUser(username: string, password: string): Observable<any> {
|
|
|
+ const registerUrl = 'YOUR_API_ENDPOINT/register'; // 替换为你的注册 API 端点
|
|
|
+ return this.http.post(registerUrl, { username, password })
|
|
|
+ .pipe(
|
|
|
+ map(response => response),
|
|
|
+ catchError(error => {
|
|
|
+ throw error;
|
|
|
+ })
|
|
|
+ );
|
|
|
+ }
|
|
|
+
|
|
|
+ // 新增方法:处理“点击了解更多”按钮点击事件
|
|
|
+ onLearnMore() {
|
|
|
+ // 跳转到详情页面
|
|
|
+ this.navCtrl.navigateForward('/details');
|
|
|
+ }
|
|
|
}
|