浏览代码

Merge branch 'master' of http://git.fmode.cn:3000/19808003398/20222670105

18460000105 3 月之前
父节点
当前提交
1c578a0648

+ 76 - 50
novel-app/src/app/person/person.page.html

@@ -1,64 +1,90 @@
-<ion-header [translucent]="true">
-  <ion-toolbar>
+<ion-header>
+  <ion-toolbar class="header-toolbar">
+    <ion-buttons slot="start">
+      <ion-button (click)="goBack()">
+        <ion-icon name="arrow-back"></ion-icon>
+      </ion-button>
+    </ion-buttons>
     <ion-title>个人中心</ion-title>
     <ion-buttons slot="end">
-      <ion-button *ngIf="!isLoggedIn" (click)="goToRegister()">
-        注册
-      </ion-button>
-      <ion-button *ngIf="!isLoggedIn" (click)="goToLogin()">
-        登录
+      <ion-button>
+        <ion-icon name="settings"></ion-icon>
       </ion-button>
     </ion-buttons>
   </ion-toolbar>
 </ion-header>
 
-<ion-content [fullscreen]="true" class="ion-padding">
-  <div class="background-pattern"></div>
-
-  <!-- 用户信息卡片 -->
-  <ion-card class="user-card">
-    <div class="avatar-container">
-      <ion-avatar>
-        <img [src]="user.avatar" alt="avatar" />
-      </ion-avatar>
+<ion-content [fullscreen]="true" class="ion-padding" style="background-image: url('../../assets/images/background.jpg'); background-size: cover; background-position: center; background-repeat: no-repeat;">
+  <div class="profile-block">
+    <div class="profile-info">
+      <img src="../assets/images/background.jpg" alt="个人头像" class="profile-pic">
+      <div class="profile-info-content">
+        <h2>超级小猫</h2>
+        <p class="gender">性别: {{ gender }}</p>
+      </div>
+      <div class="button-container">
+        <ion-button fill="clear" class="navigate-button" (click)="navigateToTab4()">
+          <ion-icon name="chevron-forward"></ion-icon>
+        </ion-button>
+      </div>
     </div>
+  </div>
+
+  <ion-card>
     <ion-card-header>
-      <ion-card-title class="ion-text-center">{{user.username}}</ion-card-title>
+      <ion-card-title>个性签名</ion-card-title>
     </ion-card-header>
+    <ion-card-content>
+      <div class="completion">
+        <span>在此处填写个性签名</span>
+        <ion-button fill="clear" class="edit-button">立即填写</ion-button>
+      </div>
+    </ion-card-content>
   </ion-card>
 
-  <!-- 创作中心 -->
-  <ion-card class="feature-card" (click)="goToCreativeCenter()">
-    <ion-item lines="none">
-      <ion-icon name="create-outline" slot="start"></ion-icon>
-      <ion-label>创作中心</ion-label>
-      <ion-icon name="chevron-forward-outline" slot="end"></ion-icon>
-    </ion-item>
-  </ion-card>
-
-  <!-- 设置列表 -->
-  <ion-card class="settings-card">
-    <ion-list>
-      <ion-item (click)="changeAvatar()">
-        <ion-icon name="image-outline" slot="start"></ion-icon>
-        <ion-label>更换头像</ion-label>
-        <input type="file" #fileInput (change)="uploadAvatarFromFile($event)" accept="image/*" style="display: none">
-      </ion-item>
-
-      <ion-item (click)="changePassword()">
-        <ion-icon name="key-outline" slot="start"></ion-icon>
-        <ion-label>修改密码</ion-label>
-      </ion-item>
-
-      <ion-item (click)="switchAccount()">
-        <ion-icon name="swap-horizontal-outline" slot="start"></ion-icon>
-        <ion-label>切换账号</ion-label>
-      </ion-item>
-
-      <ion-item (click)="showLogoutConfirm()">
-        <ion-icon name="log-out-outline" slot="start" color="danger"></ion-icon>
-        <ion-label color="danger">注销账号</ion-label>
-      </ion-item>
-    </ion-list>
+  <ion-card>
+    <ion-card-header>
+      <ion-card-title>常用功能</ion-card-title>
+    </ion-card-header>
+    <ion-card-content>
+      <ion-list>
+        <ion-item>
+          <ion-icon slot="start" name="folder"></ion-icon>
+          设置
+        </ion-item>
+        <ion-item>
+          <ion-icon slot="start" name="folder"></ion-icon>
+          修改资料
+        </ion-item>
+        <ion-item>
+          <ion-icon slot="start" name="lock-closed"></ion-icon>
+          修改密码
+        </ion-item>
+        <ion-item>
+          <ion-icon slot="start" name="folder"></ion-icon>
+          注销账号
+        </ion-item>
+        <ion-item>
+          <ion-icon slot="start" name="folder"></ion-icon>
+          用户注册协议
+        </ion-item>
+        <ion-item>
+          <ion-icon slot="start" name="folder"></ion-icon>
+          用户隐私协议
+        </ion-item>
+        <ion-item>
+          <ion-icon slot="start" name="help-circle"></ion-icon>
+          使用帮助
+        </ion-item>
+        <ion-item>
+          <ion-icon slot="start" name="document-text"></ion-icon>
+          法律条款
+        </ion-item>
+        <ion-item>
+          <ion-icon slot="start" name="warning"></ion-icon>
+          意见反馈
+        </ion-item>
+      </ion-list>
+    </ion-card-content>
   </ion-card>
 </ion-content>

+ 98 - 62
novel-app/src/app/person/person.page.scss

@@ -1,69 +1,105 @@
-ion-content {
-  --background: linear-gradient(135deg, #f5f7fa 0%, #c3cfe2 100%);
-}
-
-.background-pattern {
-  position: fixed;
-  top: 0;
-  left: 0;
-  right: 0;
-  bottom: 0;
-  opacity: 0.1;
-  background-image: 
-    linear-gradient(30deg, #000000 12%, transparent 12.5%, transparent 87%, #000000 87.5%, #000000),
-    linear-gradient(150deg, #000000 12%, transparent 12.5%, transparent 87%, #000000 87.5%, #000000),
-    linear-gradient(30deg, #000000 12%, transparent 12.5%, transparent 87%, #000000 87.5%, #000000),
-    linear-gradient(150deg, #000000 12%, transparent 12.5%, transparent 87%, #000000 87.5%, #000000),
-    linear-gradient(60deg, #77777777 25%, transparent 25.5%, transparent 75%, #77777777 75%, #77777777);
-  background-size: 80px 140px;
-  background-position: 0 0, 0 0, 40px 70px, 40px 70px, 0 0;
-  pointer-events: none;
-}
-
-.user-card {
+/* 全局样式 */
+ion-app {
+  background: url('/assets/images/background.jpg') no-repeat center center fixed;
+  /* 添加背景图片 */
+  background-size: cover;
+  /* 背景图片覆盖整个内容区域 */
+  background-position: center;
+  /* 背景图片居中 */
+  height: 100vh;
+  /* 确保背景覆盖整个视口高度 */
+  margin: 0;
+  /* 移除默认的外边距 */
+  padding: 0;
+  /* 移除默认的内边距 */
+}
+
+/* 保持大部分样式不变,只添加必要的样式 */
+.buttons {
+  display: flex;
+  justify-content: space-between;
   margin-top: 20px;
-  background: rgba(255, 255, 255, 0.9);
-  border-radius: 16px;
-  
-  .avatar-container {
-    display: flex;
-    justify-content: center;
-    padding: 20px 0;
-    
-    ion-avatar {
-      width: 100px;
-      height: 100px;
-      border: 3px solid #fff;
-      box-shadow: 0 4px 12px rgba(0,0,0,0.1);
-    }
-  }
-}
-
-.feature-card, .settings-card {
-  margin-top: 16px;
-  background: rgba(255, 255, 255, 0.9);
-  border-radius: 16px;
-  
-  ion-item {
-    --background: transparent;
-    
-    ion-icon {
-      color: var(--ion-color-primary);
-    }
-  }
+}
+
+.modal-content {
+  --background: #fff;
+  padding: 20px;
+}
+
+ion-content {
+  --background: transparent;
+  /* 设置为透明,以便背景从 ion-app 继承 */
+  padding: 16px;
+}
+
+.profile-block {
+  background-color: rgba(255, 255, 255, 0.8); /* 半透明白色背景 */
+  padding: 20px; /* 内边距 */
+  border-radius: 20px; /* 圆角 */
+  margin: 20px; /* 外边距 */
+}
+
+.profile-info {
+  text-align: center; /* 可选:使内容居中 */
+}
+
+.profile-pic {
+  width: 60px; /* 头像宽度 */
+  height: 60px; /* 头像高度 */
+  border-radius: 50%; /* 圆形头像 */
+  border: 3px solid white; /* 白色边框 */
+  margin-right: 10px; /* 头像与用户名之间的间距 */
+}
+
+h2 {
+  font-size: 20px;
+  font-weight: bold;
+  color: #333;
+  margin-bottom: 5px; /* 添加下边距以分隔用户名和性别 */
+}
+
+.gender {
+  font-size: 16px;
+  color: #666;
+  margin-top: 5px; /* 添加上边距以确保与用户名之间有间隔 */
+}
+
+.navigate-button {
+  color: #333; /* 按钮颜色 */
+  margin-left: 10px; /* 添加左边距以确保与用户名之间有间隔 */
+}
+
+ion-card {
+  margin-top: 20px; /* 卡片上边距 */
+}
+
+ion-card-header {
+  background: rgba(105, 250, 255, 0.3); 
+  color: #333; /* 深色字体 */
+}
+
+ion-card-title {
+  font-size: 18px; /* 卡片标题字体大小 */
+}
+
+.completion {
+  display: flex;
+  justify-content: space-between; /* 左右对齐 */
+  align-items: center; /* 垂直居中 */
+}
+
+.edit-button {
+  color: #064351; /* 按钮颜色 */
+  font-size: 16px; /* 按钮字体大小 */
 }
 
 ion-list {
-  background: transparent;
-  padding: 0;
+  margin-top: 10px; /* 列表上边距 */
 }
 
 ion-item {
-  --padding-start: 16px;
-  --inner-padding-end: 16px;
-  --background: transparent;
-  
-  &:last-child {
-    --border-width: 0;
-  }
-} 
+  --background: #fff; /* 白色背景 */
+  --color: #333; /* 深色字体 */
+  border-radius: 5px; /* 圆角 */
+  margin: 5px 0; /* 项目间距 */
+}

+ 1 - 0
novel-app/src/app/person/person.page.spec.ts

@@ -3,6 +3,7 @@ import { ComponentFixture, TestBed } from '@angular/core/testing';
 import { PersonPage } from './person.page';
 
 describe('PersonPage', () => {
+  
   let component: PersonPage;
   let fixture: ComponentFixture<PersonPage>;
 

+ 20 - 308
novel-app/src/app/person/person.page.ts

@@ -1,316 +1,28 @@
-import { Component, ElementRef, OnInit, ViewChild } from '@angular/core';
-import { CommonModule } from '@angular/common';
-import { FormsModule, ReactiveFormsModule } from '@angular/forms';
-import { Router } from '@angular/router';
-import {
-  IonAvatar, IonBackButton, IonButton, IonButtons, IonContent, IonHeader, IonIcon,
-  IonItem, IonLabel, IonList, IonTitle, IonToolbar, ToastController, AlertController, IonCard, IonCardHeader, IonCardTitle
-} from '@ionic/angular/standalone';
-import { UserService } from '../services/user.service';
-import { ActionSheetController } from '@ionic/angular/standalone';
-import { Camera, CameraResultType, CameraSource } from '@capacitor/camera';
-
-interface User {
-  username: string;
-  avatar: string;
-}
+import { Component } from '@angular/core';
+import {  NavController } from '@ionic/angular';
+import { IonButton, IonButtons, IonHeader, IonToolbar ,IonIcon, IonTitle, IonContent, IonCard, IonCardHeader, IonCardTitle, IonCardContent, IonItem, IonList} from '@ionic/angular/standalone';
 
 @Component({
   selector: 'app-person',
-  templateUrl: './person.page.html',
-  styleUrls: ['./person.page.scss'],
-  standalone: true,
-  imports: [IonContent, IonHeader, IonToolbar, CommonModule, FormsModule,
-    IonAvatar, IonList, IonItem, IonLabel, IonButtons, IonCard, IonIcon, IonTitle, IonButton, IonCardHeader, IonCardTitle]
+  templateUrl: 'person.page.html',
+  styleUrls: ['person.page.scss'],
+  standalone:true,
+  imports: [IonHeader,IonToolbar,IonButtons,IonButton,IonIcon,IonTitle,
+    IonContent,IonCard,IonCardHeader,IonCardTitle,IonCardContent,IonItem,IonList
+  ]
 })
-export class PersonPage implements OnInit {
-  isLoggedIn: boolean = false;
-  user: User = {
-    username: 'User_123456',
-    avatar: 'assets/default-avatar.png'
-  };
-
-  @ViewChild('fileInput') fileInput!: ElementRef;
-
-  constructor(
-    private router: Router,
-    private alertController: AlertController,
-    private actionSheetController: ActionSheetController,
-    private userService: UserService
-  ) { }
-
-  ngOnInit() {
-    this.checkLoginStatus();
-    this.subscribeToUserChanges();
-  }
-
-  subscribeToUserChanges() {
-    this.userService.currentUser$.subscribe(user => {
-      if (user) {
-        this.user = user;
-      }
-    });
-  }
-
-  checkLoginStatus() {
-    this.userService.isLoggedIn$.subscribe(
-      isLoggedIn => {
-        this.isLoggedIn = isLoggedIn;
-        if (isLoggedIn) {
-          // 获取用户信息
-          this.userService.getCurrentUser().subscribe(user => {
-            if (user) {
-              this.user = user;
-            }
-          });
-        }
-      }
-    );
-  }
-
-  async changeAvatar() {
-    try {
-      const actionSheet = await this.actionSheetController.create({
-        header: '选择头像',
-        buttons: [
-          {
-            text: '拍照',
-            icon: 'camera',
-            handler: () => {
-              this.takePicture('camera');
-            }
-          },
-          {
-            text: '从相册选择',
-            icon: 'image',
-            handler: () => {
-              this.takePicture('photos');
-            }
-          },
-          {
-            text: '从电脑选择',
-            icon: 'desktop',
-            handler: () => {
-              this.fileInput.nativeElement.click();
-            }
-          },
-          {
-            text: '取消',
-            icon: 'close',
-            role: 'cancel'
-          }
-        ]
-      });
-      await actionSheet.present();
-    } catch (error) {
-      console.error('Error showing action sheet:', error);
-      this.showAlert('错误', '无法打开选择菜单');
-    }
-  }
-
-  private async takePicture(sourceType: 'camera' | 'photos') {
-    try {
-      const image = await Camera.getPhoto({
-        quality: 90,
-        allowEditing: true,
-        resultType: CameraResultType.DataUrl,
-        source: sourceType === 'camera' ? CameraSource.Camera : CameraSource.Photos
-      });
-
-      if (image && image.dataUrl) {
-        // 先更新本地显示
-        this.user.avatar = image.dataUrl;
-
-        // 然后保存到服务
-        this.userService.updateAvatar(image.dataUrl).subscribe(
-          response => {
-            if (response.success) {
-              this.showAlert('成功', '头像更新成功');
-            } else {
-              // 如果更新失败,恢复原来的头像
-              this.userService.getCurrentUser().subscribe(user => {
-                if (user) {
-                  this.user.avatar = user.avatar;
-                }
-              });
-              this.showAlert('错误', '头像更新失败');
-            }
-          },
-          error => {
-            console.error('Error updating avatar:', error);
-            this.showAlert('错误', '头像更新失败');
-          }
-        );
-      }
-    } catch (error) {
-      console.error('Error taking photo:', error);
-      this.showAlert('错误', '获取图片失败');
-    }
-  }
-
-  async changePassword() {
-    const alert = await this.alertController.create({
-      header: '修改密码',
-      inputs: [
-        {
-          name: 'oldPassword',
-          type: 'password',
-          placeholder: '请输入原密码'
-        },
-        {
-          name: 'newPassword',
-          type: 'password',
-          placeholder: '请输入新密码'
-        }
-      ],
-      buttons: [
-        {
-          text: '取消',
-          role: 'cancel'
-        },
-        {
-          text: '确定',
-          handler: (data) => {
-            this.userService.changePassword(data.oldPassword, data.newPassword).subscribe(
-              response => {
-                if (response.success) {
-                  this.showAlert('成功', '密码修改成功');
-                } else {
-                  this.showAlert('错误', response.message || '密码修改失败');
-                }
-              }
-            );
-          }
-        }
-      ]
-    });
-    await alert.present();
-  }
-
-  async switchAccount() {
-    const alert = await this.alertController.create({
-      header: '切换账号',
-      inputs: [
-        {
-          name: 'phone',
-          type: 'tel',
-          placeholder: '请输入手机号'
-        },
-        {
-          name: 'password',
-          type: 'password',
-          placeholder: '请输入密码'
-        }
-      ],
-      buttons: [
-        {
-          text: '取消',
-          role: 'cancel'
-        },
-        {
-          text: '确定',
-          handler: (data) => {
-            this.userService.switchAccount(data).subscribe(
-              response => {
-                if (response.success) {
-                  this.showAlert('成功', '账号切换成功');
-                  this.checkLoginStatus();
-                } else {
-                  this.showAlert('错误', '账号或密码错误');
-                }
-              }
-            );
-          }
-        }
-      ]
-    });
-    await alert.present();
-  }
-
-  async showLogoutConfirm() {
-    const alert = await this.alertController.create({
-      header: '确认注销账号',
-      message: '您确定要注销账号吗?此操作不可逆',
-      buttons: [
-        {
-          text: '取消',
-          role: 'cancel'
-        },
-        {
-          text: '确定',
-          handler: () => {
-            this.userService.deleteAccount().subscribe(
-              response => {
-                if (response.success) {
-                  this.userService.logout();
-                  this.router.navigate(['/login']);
-                }
-              }
-            );
-          }
-        }
-      ]
-    });
-    await alert.present();
-  }
+export class PersonPage {
+  constructor(private navCtrl: NavController) {}
 
-  private async showAlert(header: string, message: string) {
-    const alert = await this.alertController.create({
-      header,
-      message,
-      buttons: ['确定']
-    });
-    await alert.present();
-  }
-
-  goToCreativeCenter() {
-    this.router.navigate(['/tabs/home']);
-  }
+  gender: string = '女'; // 默认性别
 
-  goToLogin() {
-    this.router.navigate(['/login']);
+  goBack() {
+    this.navCtrl.back();
   }
-
-  goToRegister() {
-    this.router.navigate(['/register']);
-  }
-
-  async uploadAvatarFromFile(event: any) {
-    const file = event.target.files[0];
-    if (file) {
-      try {
-        const reader = new FileReader();
-        reader.onload = (e: any) => {
-          const imageData = e.target.result;
-          // 先更新本地显示
-          this.user.avatar = imageData;
-
-          // 然后保存到服务
-          this.userService.updateAvatar(imageData).subscribe(
-            response => {
-              if (response.success) {
-                this.showAlert('成功', '头像更新成功');
-              } else {
-                // 如果更新失败,恢复原来的头像
-                this.userService.getCurrentUser().subscribe(user => {
-                  if (user) {
-                    this.user.avatar = user.avatar;
-                  }
-                });
-                this.showAlert('错误', '头像更新失败');
-              }
-            },
-            error => {
-              console.error('Error updating avatar:', error);
-              this.showAlert('错误', '头像更新失败');
-            }
-          );
-        };
-        reader.readAsDataURL(file);
-      } catch (error) {
-        console.error('Error reading file:', error);
-        this.showAlert('错误', '文件读取失败');
-      }
-    }
+  
+  navigateToTab4() {
+    this.navCtrl.navigateForward('/tab4'); // 跳转到tab4
   }
-} 
+  
+  
+}

二进制
novel-app/src/assets/images/background.jpg