浏览代码

Merge branch 'master' of http://git.fmode.cn:3000/4u/workspace

cainiao-hue 3 月之前
父节点
当前提交
238f0df9a7
共有 47 个文件被更改,包括 3472 次插入39 次删除
  1. 84 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228113703.ts
  2. 59 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228113704.html
  3. 67 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114058.scss
  4. 63 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114102.html
  5. 72 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114430.scss
  6. 63 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114506.html
  7. 73 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114556.scss
  8. 63 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114557.html
  9. 74 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114645.scss
  10. 78 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114858.scss
  11. 63 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114937.html
  12. 63 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115010.html
  13. 63 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115036.html
  14. 63 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115101.html
  15. 63 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115124.html
  16. 81 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115309.scss
  17. 63 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115317.html
  18. 81 0
      .history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115355.scss
  19. 85 0
      .history/soul-app/src/app/tab1/tab1.page_20241228115502.scss
  20. 85 0
      .history/soul-app/src/app/tab1/tab1.page_20241228115550.scss
  21. 96 0
      .history/soul-app/src/app/tab1/tab1.page_20241228115737.scss
  22. 95 0
      .history/soul-app/src/app/tab1/tab1.page_20241228120151.scss
  23. 76 0
      .history/soul-app/src/app/tab1/tab1.page_20241228120215.html
  24. 95 0
      .history/soul-app/src/app/tab1/tab1.page_20241228120257.scss
  25. 95 0
      .history/soul-app/src/app/tab1/tab1.page_20241228120315.scss
  26. 95 0
      .history/soul-app/src/app/tab1/tab1.page_20241228120327.scss
  27. 95 0
      .history/soul-app/src/app/tab1/tab1.page_20241228120341.scss
  28. 92 0
      .history/soul-app/src/app/tab1/tab1.page_20241228120505.scss
  29. 95 0
      .history/soul-app/src/app/tab1/tab1.page_20241228120542.scss
  30. 93 0
      .history/soul-app/src/app/tab1/tab1.page_20241228121121.scss
  31. 76 0
      .history/soul-app/src/app/tab1/tab1.page_20241228121144.html
  32. 95 0
      .history/soul-app/src/app/tab1/tab1.page_20241228121349.scss
  33. 96 0
      .history/soul-app/src/app/tab1/tab1.page_20241228121533.scss
  34. 96 0
      .history/soul-app/src/app/tab1/tab1.page_20241228121610.scss
  35. 76 0
      .history/soul-app/src/app/tab1/tab1.page_20241228121640.html
  36. 96 0
      .history/soul-app/src/app/tab1/tab1.page_20241228121852.scss
  37. 76 0
      .history/soul-app/src/app/tab1/tab1.page_20241228121935.html
  38. 76 0
      .history/soul-app/src/app/tab1/tab1.page_20241228122017.html
  39. 94 0
      .history/soul-app/src/app/tab1/tab1.page_20241228122213.scss
  40. 96 0
      .history/soul-app/src/app/tab1/tab1.page_20241228122232.scss
  41. 142 0
      .history/soul-app/src/app/tab1/tab1.page_20241228132832.ts
  42. 10 5
      soul-app/src/app/my-drift-bottle/my-drift-bottle.component.html
  43. 27 1
      soul-app/src/app/my-drift-bottle/my-drift-bottle.component.scss
  44. 33 20
      soul-app/src/app/my-drift-bottle/my-drift-bottle.component.ts
  45. 7 7
      soul-app/src/app/tab1/tab1.page.html
  46. 15 4
      soul-app/src/app/tab1/tab1.page.scss
  47. 28 2
      soul-app/src/app/tab1/tab1.page.ts

+ 84 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228113703.ts

@@ -0,0 +1,84 @@
+import { Component, OnInit } from '@angular/core';
+import { Router } from '@angular/router';
+import { CommonModule } from '@angular/common'; // 导入 CommonModule
+
+import { IonHeader, IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
+  IonListHeader, IonCardHeader, IonCardTitle, IonCardContent, IonTitle, IonCard, IonToolbar, IonInput, IonSearchbar } from '@ionic/angular/standalone';
+import { CloudQuery, CloudObject, CloudUser } from 'src/lib/ncloud';
+import { UserService } from 'src/app/user.service'; // 假设这是你的用户服务
+
+@Component({
+  selector: 'app-my-drift-bottle',
+  templateUrl: './my-drift-bottle.component.html',
+  styleUrls: ['./my-drift-bottle.component.scss'],
+  standalone: true,
+  imports: [
+    CommonModule, // 添加 CommonModule
+    
+    IonHeader, IonToolbar, IonTitle, IonContent,
+    IonList, IonListHeader, IonItem, IonCardTitle,
+    IonLabel, IonIcon, IonButton, IonCardContent,
+    IonInput, IonSearchbar, IonCard, IonCardHeader,
+  ]
+})
+export class MyDriftBottleComponent implements OnInit {
+  filteredDriftbottles2: any[] = [];
+  Driftbottles: any[] = [];
+  filteredDriftbottles: any[] = [];
+  username: string = '';
+
+  constructor(private router: Router, private userService: UserService) {}
+
+  ngOnInit() {
+    this.getDriftbottles(); // 获取所有漂流瓶并进行过滤
+  }
+
+  async getDriftbottles() {
+    let query = new CloudQuery("Driftbottle");
+    this.Driftbottles = await query.find();
+    this.filterDriftbottles();
+    this.filterDriftbottles2();
+  }
+
+  filterDriftbottles() {
+    let user = new CloudUser();
+    console.log(user);
+    this.filteredDriftbottles = this.Driftbottles.filter(driftbottle => {
+      console.log(driftbottle.get("username"), user.get("username"));
+      return driftbottle.get("username") === user.get("username") || driftbottle.get("username") === 'all';
+    });
+  }
+
+  filterDriftbottles2() {
+    let user = new CloudUser();
+    console.log(user);
+    this.filteredDriftbottles2 = this.Driftbottles.filter(driftbottle => {
+      console.log(driftbottle.get("catcher"), user.get("username"));
+      return driftbottle.get("catcher") === user.get("username") || driftbottle.get("catcher") === 'all';
+    });
+  }
+
+  goDriftbottle() {
+    this.router.navigate(['tabs/drift-bottle']);
+  }
+
+  gothrowNewDriftbottle() {
+    this.router.navigate(['tabs/drift-bottle']); // 假设这是投掷新漂流瓶的路由
+  }
+
+  async rethrowBottle(bottle: CloudObject) {
+    try {
+      bottle.set({
+        status: "drifting",
+        catcher: null,
+        catchtime: null
+      });
+
+      await bottle.save();
+      this.getDriftbottles(); // 刷新漂流瓶列表
+      console.log('漂流瓶扔回成功');
+    } catch (err) {
+      console.error('扔回漂流瓶时出错:', err);
+    }
+  }
+}

+ 59 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228113704.html

@@ -0,0 +1,59 @@
+<ion-header>
+  <ion-toolbar>
+    <div class="toolbar-content">
+      <div class="button-container">
+        <ion-button (click)="goDriftbottle()" fill="clear">
+          <ion-icon name="chevron-back" slot="start"></ion-icon>返回
+        </ion-button>
+      </div>
+      <ion-title class="title-text">
+        我的漂流瓶
+      </ion-title>
+    </div>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content>
+  <ion-list>
+    <ion-item>
+      <ion-label>
+        <h2>我扔出的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content>
+          <p>扔出时间: {{ bottle.get('throwtime') }}</p>
+        </ion-card-content>
+      </ion-card>
+    </section>
+
+    <ion-item>
+      <ion-label>
+        <h2>我捞上的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles2.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles2">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content>
+          <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+          <ion-button (click)="rethrowBottle(bottle)">扔回</ion-button>
+        </ion-card-content>
+      </ion-card>
+    </section>
+  </ion-list>
+
+  <div style="display: flex; justify-content: center; margin-top: auto;">
+    <ion-button (click)="gothrowNewDriftbottle()" expand="full">
+      投掷新的漂流瓶
+    </ion-button>
+  </div>
+</ion-content>

+ 67 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114058.scss

@@ -0,0 +1,67 @@
+/* 设置页面背景色 */
+ion-content {
+    --background: #ffffff; /* 白色背景 */
+  }
+
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  .card-content-with-button {
+    display: flex;
+    justify-content: space-between;
+    align-items: center;
+  }
+  
+  .content-section {
+    flex-grow: 1;
+  }
+  
+  .button-section {
+    margin-left: 10px;
+  }
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  ion-title {
+    font-size: 24px; /* 增大字体大小 */
+    font-weight: bold; /* 加粗 */
+  }
+  /* 设置卡片的样式 */
+  ion-list {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+  }
+  
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  
+  /* 设置按钮的样式(如果按钮不在顶部方框内) */
+  
+  ion-toolbar {
+  margin: auto;
+  }
+  .title-text{
+  position: absolute;
+  display: flex;
+  left: 105px;
+  margin: auto;
+  top: 10px;
+  color:rgb(69, 166, 180);
+  }
+
+  

+ 63 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114102.html

@@ -0,0 +1,63 @@
+<ion-header>
+  <ion-toolbar>
+    <div class="toolbar-content">
+      <div class="button-container">
+        <ion-button (click)="goDriftbottle()" fill="clear">
+          <ion-icon name="chevron-back" slot="start"></ion-icon>返回
+        </ion-button>
+      </div>
+      <ion-title class="title-text">
+        我的漂流瓶
+      </ion-title>
+    </div>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content>
+  <ion-list>
+    <ion-item>
+      <ion-label>
+        <h2>我扔出的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content>
+          <p>扔出时间: {{ bottle.get('throwtime') }}</p>
+        </ion-card-content>
+      </ion-card>
+    </section>
+
+    <ion-item>
+      <ion-label>
+        <h2>我捞上的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles2.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles2">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content class="card-content-with-button">
+          <div class="content-section">
+            <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+          </div>
+          <div class="button-section">
+            <ion-button (click)="rethrowBottle(bottle)" color="danger">扔回</ion-button>
+          </div>
+        </ion-card-content>
+      </ion-card>
+    </section>
+  </ion-list>
+
+  <div style="display: flex; justify-content: center; margin-top: auto;">
+    <ion-button (click)="gothrowNewDriftbottle()" expand="full">
+      投掷新的漂流瓶
+    </ion-button>
+  </div>
+</ion-content>

+ 72 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114430.scss

@@ -0,0 +1,72 @@
+/* 设置页面背景色 */
+ion-content {
+    --background: #ffffff; /* 白色背景 */
+  }
+
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  .card-content-with-button {
+    display: flex;
+    justify-content: space-between;
+    align-items: center;
+  }
+  
+  .content-section {
+    flex-grow: 1;
+  }
+  
+  .button-section {
+    margin-left: 10px;
+  }
+  
+  /* 确保按钮文本正常横排 */
+  ion-button {
+    white-space: nowrap;
+  }
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  ion-title {
+    font-size: 24px; /* 增大字体大小 */
+    font-weight: bold; /* 加粗 */
+  }
+  /* 设置卡片的样式 */
+  ion-list {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+  }
+  
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  
+  /* 设置按钮的样式(如果按钮不在顶部方框内) */
+  
+  ion-toolbar {
+  margin: auto;
+  }
+  .title-text{
+  position: absolute;
+  display: flex;
+  left: 105px;
+  margin: auto;
+  top: 10px;
+  color:rgb(69, 166, 180);
+  }
+
+  

+ 63 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114506.html

@@ -0,0 +1,63 @@
+<ion-header>
+  <ion-toolbar>
+    <div class="toolbar-content">
+      <div class="button-container">
+        <ion-button (click)="goDriftbottle()" fill="clear">
+          <ion-icon name="chevron-back" slot="start"></ion-icon>返回
+        </ion-button>
+      </div>
+      <ion-title class="title-text">
+        我的漂流瓶
+      </ion-title>
+    </div>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content>
+  <ion-list>
+    <ion-item>
+      <ion-label>
+        <h2>我扔出的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content>
+          <p>扔出时间: {{ bottle.get('throwtime') }}</p>
+        </ion-card-content>
+      </ion-card>
+    </section>
+
+    <ion-item>
+      <ion-label>
+        <h2>我捞上的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles2.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles2">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content class="card-content-with-button">
+          <div class="content-section">
+            <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+          </div>
+          <div class="button-section">
+            <ion-button (click)="rethrowBottle(bottle)" color="rgb(69, 166, 180)">扔回</ion-button>
+          </div>
+        </ion-card-content>
+      </ion-card>
+    </section>
+  </ion-list>
+
+  <div style="display: flex; justify-content: center; margin-top: auto;">
+    <ion-button (click)="gothrowNewDriftbottle()" expand="full">
+      投掷新的漂流瓶
+    </ion-button>
+  </div>
+</ion-content>

+ 73 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114556.scss

@@ -0,0 +1,73 @@
+/* 设置页面背景色 */
+ion-content {
+    --background: #ffffff; /* 白色背景 */
+  }
+
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  .card-content-with-button {
+    display: flex;
+    justify-content: space-between;
+    align-items: center;
+    color: rgb(69, 166, 180);
+  }
+  
+  .content-section {
+    flex-grow: 1;
+  }
+  
+  .button-section {
+    margin-left: 10px;
+  }
+  
+  /* 确保按钮文本正常横排 */
+  ion-button {
+    white-space: nowrap;
+  }
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  ion-title {
+    font-size: 24px; /* 增大字体大小 */
+    font-weight: bold; /* 加粗 */
+  }
+  /* 设置卡片的样式 */
+  ion-list {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+  }
+  
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  
+  /* 设置按钮的样式(如果按钮不在顶部方框内) */
+  
+  ion-toolbar {
+  margin: auto;
+  }
+  .title-text{
+  position: absolute;
+  display: flex;
+  left: 105px;
+  margin: auto;
+  top: 10px;
+  color:rgb(69, 166, 180);
+  }
+
+  

+ 63 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114557.html

@@ -0,0 +1,63 @@
+<ion-header>
+  <ion-toolbar>
+    <div class="toolbar-content">
+      <div class="button-container">
+        <ion-button (click)="goDriftbottle()" fill="clear">
+          <ion-icon name="chevron-back" slot="start"></ion-icon>返回
+        </ion-button>
+      </div>
+      <ion-title class="title-text">
+        我的漂流瓶
+      </ion-title>
+    </div>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content>
+  <ion-list>
+    <ion-item>
+      <ion-label>
+        <h2>我扔出的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content>
+          <p>扔出时间: {{ bottle.get('throwtime') }}</p>
+        </ion-card-content>
+      </ion-card>
+    </section>
+
+    <ion-item>
+      <ion-label>
+        <h2>我捞上的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles2.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles2">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content class="card-content-with-button">
+          <div class="content-section">
+            <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+          </div>
+          <div class="button-section">
+            <ion-button (click)="rethrowBottle(bottle)" >扔回</ion-button>
+          </div>
+        </ion-card-content>
+      </ion-card>
+    </section>
+  </ion-list>
+
+  <div style="display: flex; justify-content: center; margin-top: auto;">
+    <ion-button (click)="gothrowNewDriftbottle()" expand="full">
+      投掷新的漂流瓶
+    </ion-button>
+  </div>
+</ion-content>

+ 74 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114645.scss

@@ -0,0 +1,74 @@
+/* 设置页面背景色 */
+ion-content {
+    --background: #ffffff; /* 白色背景 */
+  }
+
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  .card-content-with-button {
+    display: flex;
+    justify-content: space-between;
+    align-items: center;
+    
+  }
+  
+  .content-section {
+    flex-grow: 1;
+  }
+  
+  .button-section {
+    margin-left: 10px;
+    color: rgb(69, 166, 180);
+  }
+  
+  /* 确保按钮文本正常横排 */
+  ion-button {
+    white-space: nowrap;
+  }
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  ion-title {
+    font-size: 24px; /* 增大字体大小 */
+    font-weight: bold; /* 加粗 */
+  }
+  /* 设置卡片的样式 */
+  ion-list {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+  }
+  
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  
+  /* 设置按钮的样式(如果按钮不在顶部方框内) */
+  
+  ion-toolbar {
+  margin: auto;
+  }
+  .title-text{
+  position: absolute;
+  display: flex;
+  left: 105px;
+  margin: auto;
+  top: 10px;
+  color:rgb(69, 166, 180);
+  }
+
+  

+ 78 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114858.scss

@@ -0,0 +1,78 @@
+/* 设置页面背景色 */
+ion-content {
+    --background: #ffffff; /* 白色背景 */
+  }
+
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  .card-content-with-button {
+    display: flex;
+    justify-content: space-between;
+    align-items: center;
+    
+  }
+  
+  .content-section {
+    flex-grow: 1;
+  }
+  
+  .button-section {
+    margin-left: 10px;
+    
+  }
+  
+  /* 确保按钮文本正常横排 */
+  ion-button {
+    white-space: nowrap;
+  }
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  ion-title {
+    font-size: 24px; /* 增大字体大小 */
+    font-weight: bold; /* 加粗 */
+  }
+  /* 设置卡片的样式 */
+  ion-list {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+  }
+  
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  
+  /* 设置按钮的样式(如果按钮不在顶部方框内) */
+  
+  ion-toolbar {
+  margin: auto;
+  }
+  .title-text{
+  position: absolute;
+  display: flex;
+  left: 105px;
+  margin: auto;
+  top: 10px;
+  color:rgb(69, 166, 180);
+  }
+  .custom-color {
+    --background: rgb(69, 166, 180);
+    --background-activated: rgba(69, 166, 180, 0.7);
+    --color: white;
+  }
+  

+ 63 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228114937.html

@@ -0,0 +1,63 @@
+<ion-header>
+  <ion-toolbar>
+    <div class="toolbar-content">
+      <div class="button-container">
+        <ion-button (click)="goDriftbottle()" fill="clear">
+          <ion-icon name="chevron-back" slot="start"></ion-icon>返回
+        </ion-button>
+      </div>
+      <ion-title class="title-text">
+        我的漂流瓶
+      </ion-title>
+    </div>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content>
+  <ion-list>
+    <ion-item>
+      <ion-label>
+        <h2>我扔出的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content>
+          <p>扔出时间: {{ bottle.get('throwtime') }}</p>
+        </ion-card-content>
+      </ion-card>
+    </section>
+
+    <ion-item>
+      <ion-label>
+        <h2>我捞上的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles2.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles2">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content class="card-content-with-button">
+          <div class="content-section">
+            <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+          </div>
+          <div class="button-section">
+            <ion-button (click)="rethrowBottle(bottle)" class="custom-color">扔回</ion-button>
+          </div>
+        </ion-card-content>
+      </ion-card>
+    </section>
+  </ion-list>
+
+  <div style="display: flex; justify-content: center; margin-top: auto;">
+    <ion-button (click)="gothrowNewDriftbottle()" expand="full">
+      投掷新的漂流瓶
+    </ion-button>
+  </div>
+</ion-content>

+ 63 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115010.html

@@ -0,0 +1,63 @@
+<ion-header>
+  <ion-toolbar>
+    <div class="toolbar-content">
+      <div class="button-container">
+        <ion-button (click)="goDriftbottle()" fill="clear">
+          <ion-icon name="chevron-back" slot="start"></ion-icon>返回
+        </ion-button>
+      </div>
+      <ion-title class="title-text">
+        我的漂流瓶
+      </ion-title>
+    </div>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content>
+  <ion-list>
+    <ion-item>
+      <ion-label>
+        <h2>我扔出的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content>
+          <p>扔出时间: {{ bottle.get('throwtime') }}</p>
+        </ion-card-content>
+      </ion-card>
+    </section>
+
+    <ion-item>
+      <ion-label>
+        <h2>我捞上的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles2.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles2">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content class="card-content-with-button">
+          <div class="content-section">
+            <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+          </div>
+          <div class="button-section">
+            <ion-button (click)="rethrowBottle(bottle)" class="custom-color">扔回</ion-button>
+          </div>
+        </ion-card-content>
+      </ion-card>
+    </section>
+  </ion-list>
+
+  <div style="display: flex; justify-content: center; margin-top: auto;">
+    <ion-button (click)="gothrowNewDriftbottle()" expand="full" class="custom-color">
+      投掷新的漂流瓶
+    </ion-button>
+  </div>
+</ion-content>

+ 63 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115036.html

@@ -0,0 +1,63 @@
+<ion-header>
+  <ion-toolbar>
+    <div class="toolbar-content">
+      <div class="button-container">
+        <ion-button (click)="goDriftbottle()" fill="clear">
+          <ion-icon name="chevron-back" slot="start" class="custom-color"></ion-icon>返回
+        </ion-button>
+      </div>
+      <ion-title class="title-text">
+        我的漂流瓶
+      </ion-title>
+    </div>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content>
+  <ion-list>
+    <ion-item>
+      <ion-label>
+        <h2>我扔出的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content>
+          <p>扔出时间: {{ bottle.get('throwtime') }}</p>
+        </ion-card-content>
+      </ion-card>
+    </section>
+
+    <ion-item>
+      <ion-label>
+        <h2>我捞上的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles2.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles2">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content class="card-content-with-button">
+          <div class="content-section">
+            <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+          </div>
+          <div class="button-section">
+            <ion-button (click)="rethrowBottle(bottle)" class="custom-color">扔回</ion-button>
+          </div>
+        </ion-card-content>
+      </ion-card>
+    </section>
+  </ion-list>
+
+  <div style="display: flex; justify-content: center; margin-top: auto;">
+    <ion-button (click)="gothrowNewDriftbottle()" expand="full" class="custom-color">
+      投掷新的漂流瓶
+    </ion-button>
+  </div>
+</ion-content>

+ 63 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115101.html

@@ -0,0 +1,63 @@
+<ion-header>
+  <ion-toolbar>
+    <div class="toolbar-content">
+      <div class="button-container">
+        <ion-button (click)="goDriftbottle()" fill="clear" class="custom-color">
+          <ion-icon name="chevron-back" slot="start" ></ion-icon>返回
+        </ion-button>
+      </div>
+      <ion-title class="title-text">
+        我的漂流瓶
+      </ion-title>
+    </div>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content>
+  <ion-list>
+    <ion-item>
+      <ion-label>
+        <h2>我扔出的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content>
+          <p>扔出时间: {{ bottle.get('throwtime') }}</p>
+        </ion-card-content>
+      </ion-card>
+    </section>
+
+    <ion-item>
+      <ion-label>
+        <h2>我捞上的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles2.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles2">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content class="card-content-with-button">
+          <div class="content-section">
+            <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+          </div>
+          <div class="button-section">
+            <ion-button (click)="rethrowBottle(bottle)" class="custom-color">扔回</ion-button>
+          </div>
+        </ion-card-content>
+      </ion-card>
+    </section>
+  </ion-list>
+
+  <div style="display: flex; justify-content: center; margin-top: auto;">
+    <ion-button (click)="gothrowNewDriftbottle()" expand="full" class="custom-color">
+      投掷新的漂流瓶
+    </ion-button>
+  </div>
+</ion-content>

+ 63 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115124.html

@@ -0,0 +1,63 @@
+<ion-header>
+  <ion-toolbar>
+    <div class="toolbar-content">
+      <div class="button-container">
+        <ion-button (click)="goDriftbottle()" class="custom-color"  fill="clear"> 
+          <ion-icon name="chevron-back" slot="start" ></ion-icon>返回
+        </ion-button>
+      </div>
+      <ion-title class="title-text">
+        我的漂流瓶
+      </ion-title>
+    </div>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content>
+  <ion-list>
+    <ion-item>
+      <ion-label>
+        <h2>我扔出的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content>
+          <p>扔出时间: {{ bottle.get('throwtime') }}</p>
+        </ion-card-content>
+      </ion-card>
+    </section>
+
+    <ion-item>
+      <ion-label>
+        <h2>我捞上的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles2.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles2">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content class="card-content-with-button">
+          <div class="content-section">
+            <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+          </div>
+          <div class="button-section">
+            <ion-button (click)="rethrowBottle(bottle)" class="custom-color">扔回</ion-button>
+          </div>
+        </ion-card-content>
+      </ion-card>
+    </section>
+  </ion-list>
+
+  <div style="display: flex; justify-content: center; margin-top: auto;">
+    <ion-button (click)="gothrowNewDriftbottle()" expand="full" class="custom-color">
+      投掷新的漂流瓶
+    </ion-button>
+  </div>
+</ion-content>

+ 81 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115309.scss

@@ -0,0 +1,81 @@
+/* 设置页面背景色 */
+ion-content {
+    --background: #ffffff; /* 白色背景 */
+  }
+
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  .card-content-with-button {
+    display: flex;
+    justify-content: space-between;
+    align-items: center;
+    
+  }
+  
+  .content-section {
+    flex-grow: 1;
+  }
+  
+  .button-section {
+    margin-left: 10px;
+    
+  }
+  
+  /* 确保按钮文本正常横排 */
+  ion-button {
+    white-space: nowrap;
+  }
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  ion-title {
+    font-size: 24px; /* 增大字体大小 */
+    font-weight: bold; /* 加粗 */
+  }
+  /* 设置卡片的样式 */
+  ion-list {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+  }
+  
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  
+  /* 设置按钮的样式(如果按钮不在顶部方框内) */
+  
+  ion-toolbar {
+  margin: auto;
+  }
+  .title-text{
+  position: absolute;
+  display: flex;
+  left: 105px;
+  margin: auto;
+  top: 10px;
+  color:rgb(69, 166, 180);
+  }
+  .custom-color {
+    --background: rgb(69, 166, 180);
+    --background-activated: rgba(69, 166, 180, 0.7);
+    --color: white;
+  }
+  .butcolor{
+    color: rgb(69, 166, 180);
+  }
+  

+ 63 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115317.html

@@ -0,0 +1,63 @@
+<ion-header>
+  <ion-toolbar>
+    <div class="toolbar-content">
+      <div class="button-container">
+        <ion-button (click)="goDriftbottle()" fill="clear" class="butcolor">
+          <ion-icon name="chevron-back" slot="start" ></ion-icon>返回
+        </ion-button>
+      </div>
+      <ion-title class="title-text">
+        我的漂流瓶
+      </ion-title>
+    </div>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content>
+  <ion-list>
+    <ion-item>
+      <ion-label>
+        <h2>我扔出的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content>
+          <p>扔出时间: {{ bottle.get('throwtime') }}</p>
+        </ion-card-content>
+      </ion-card>
+    </section>
+
+    <ion-item>
+      <ion-label>
+        <h2>我捞上的漂流瓶</h2>
+      </ion-label>
+    </ion-item>
+    
+    <section *ngIf="filteredDriftbottles2.length > 0">
+      <ion-card *ngFor="let bottle of filteredDriftbottles2">
+        <ion-card-header>
+          <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
+        </ion-card-header>
+        <ion-card-content class="card-content-with-button">
+          <div class="content-section">
+            <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+          </div>
+          <div class="button-section">
+            <ion-button (click)="rethrowBottle(bottle)" class="custom-color">扔回</ion-button>
+          </div>
+        </ion-card-content>
+      </ion-card>
+    </section>
+  </ion-list>
+
+  <div style="display: flex; justify-content: center; margin-top: auto;">
+    <ion-button (click)="gothrowNewDriftbottle()" expand="full" class="custom-color">
+      投掷新的漂流瓶
+    </ion-button>
+  </div>
+</ion-content>

+ 81 - 0
.history/soul-app/src/app/my-drift-bottle/my-drift-bottle.component_20241228115355.scss

@@ -0,0 +1,81 @@
+/* 设置页面背景色 */
+ion-content {
+    --background: #ffffff; /* 白色背景 */
+  }
+
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  .card-content-with-button {
+    display: flex;
+    justify-content: space-between;
+    align-items: center;
+    
+  }
+  
+  .content-section {
+    flex-grow: 1;
+  }
+  
+  .button-section {
+    margin-left: 10px;
+    
+  }
+  
+  /* 确保按钮文本正常横排 */
+  ion-button {
+    white-space: nowrap;
+  }
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  ion-title {
+    font-size: 24px; /* 增大字体大小 */
+    font-weight: bold; /* 加粗 */
+  }
+  /* 设置卡片的样式 */
+  ion-list {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+  }
+  
+  /* 设置列表项的样式 */
+  ion-item {
+    margin: 5px 0; /* 列表项之间的间距 */
+  }
+  
+  /* 设置按钮的样式(如果按钮不在顶部方框内) */
+  
+  ion-toolbar {
+  margin: auto;
+  }
+  .title-text{
+  position: absolute;
+  display: flex;
+  left: 105px;
+  margin: auto;
+  top: 10px;
+  color:rgb(69, 166, 180);
+  }
+  .custom-color {
+    --background: rgb(69, 166, 180);
+    --background-activated: rgba(69, 166, 180, 0.7);
+    --color: white;
+  }
+  .butcolor{
+    --color: rgb(69, 166, 180);
+  }
+  

+ 85 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228115502.scss

@@ -0,0 +1,85 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  // /* 设置列表项的样式 */
+  // ion-item {
+  //   margin: 5px 0; /* 列表项之间的间距 */
+  // }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: #f9dd94;
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 85 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228115550.scss

@@ -0,0 +1,85 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  // /* 设置列表项的样式 */
+  // ion-item {
+  //   margin: 5px 0; /* 列表项之间的间距 */
+  // }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 96 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228115737.scss

@@ -0,0 +1,96 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  // /* 设置列表项的样式 */
+  // ion-item {
+  //   margin: 5px 0; /* 列表项之间的间距 */
+  // }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+}
+/* 按钮颜色为暖色系 */
+.customer-service-button,
+ion-item ion-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  box-shadow: none; /* 移除按钮的阴影 */
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 95 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228120151.scss

@@ -0,0 +1,95 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  // /* 设置列表项的样式 */
+  // ion-item {
+  //   margin: 5px 0; /* 列表项之间的间距 */
+  // }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  box-shadow: none; /* 移除按钮的阴影 */
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 76 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228120215.html

@@ -0,0 +1,76 @@
+<ion-header [translucent]="true">
+  <ion-toolbar>
+    <ion-item lines="none">
+      <!-- 图片 -->
+      <ion-avatar slot="start" class="image-container">
+        <img src="assets/img/3.png" alt="Your Image" class="header-image">
+      </ion-avatar>
+ 
+      <!-- 搜索框 -->
+      <ion-searchbar slot="end" expand="with-icon"></ion-searchbar>
+    </ion-item>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content [fullscreen]="true">
+
+<section>
+  <ion-card>
+    <ion-card-header>
+      <ion-card-title>热门话题</ion-card-title>
+    </ion-card-header>
+    <ion-card-content>
+      <ion-list>
+        <ion-item *ngFor="let topic of topics">
+          <ion-label>
+            <h2>{{ topic.title }}</h2>
+            <p style="font-size: 16px;">{{ topic.description }}</p>
+          </ion-label>
+          <ion-buttons slot="end">
+          <ion-button class="custom-button" fill="solid" (click)="viewDetails(topic.id)">
+            <span class="button-text">查看详情</span>
+          </ion-button>
+        </ion-buttons>
+        </ion-item>
+      </ion-list>
+    </ion-card-content>
+  </ion-card>
+</section>
+
+<ion-toolbar color="light" class="button-toolbar" style="margin-top: 10px; padding: 0;">
+  <ion-buttons slot="start" class="button-container">
+    <ion-button expand="full" (click)="goPsysurvey()">心理普查</ion-button>
+    <ion-button expand="full" (click)="goDriftbottle()">漂流瓶</ion-button>
+    <ion-button expand="full" >心协</ion-button>
+    <ion-button expand="full" >更多</ion-button>
+  </ion-buttons>
+</ion-toolbar>
+
+<section>
+  <ion-card>
+    <ion-card-header>
+      <ion-toolbar>
+      <ion-card-title>用户评价</ion-card-title>
+      <ion-buttons slot="end">
+        <ion-button (click)="evaluate()" class="custom-button" fill="solid">
+          <span class="button-text">进入评价</span>
+        </ion-button>
+      </ion-buttons>
+    </ion-toolbar>
+    </ion-card-header>
+    <ion-card-content>
+      <ion-list>
+        <ion-item *ngFor="let chatevaluate of chatevaluateList">
+          <ion-avatar slot="start">
+            <img [src]="chatevaluate.get('avatar') || 'https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/HZFoDv7vkk-0.png'"/>
+          </ion-avatar>
+          <ion-label>
+            <p style="font-size: 16px;">{{ chatevaluate.get('content') }}</p>
+            <ion-icon name="star" *ngFor="let star of createFilledArray(chatevaluate.get('rating')); let i = index" [attr.aria-hidden]="true"></ion-icon>
+          </ion-label>
+        </ion-item>
+      </ion-list>
+    </ion-card-content>
+  </ion-card>
+</section>
+</ion-content>

+ 95 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228120257.scss

@@ -0,0 +1,95 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  // /* 设置列表项的样式 */
+  // ion-item {
+  //   margin: 5px 0; /* 列表项之间的间距 */
+  // }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f6c037; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  box-shadow: none; /* 移除按钮的阴影 */
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 95 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228120315.scss

@@ -0,0 +1,95 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  // /* 设置列表项的样式 */
+  // ion-item {
+  //   margin: 5px 0; /* 列表项之间的间距 */
+  // }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f6c957; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  box-shadow: none; /* 移除按钮的阴影 */
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 95 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228120327.scss

@@ -0,0 +1,95 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  // /* 设置列表项的样式 */
+  // ion-item {
+  //   margin: 5px 0; /* 列表项之间的间距 */
+  // }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  box-shadow: none; /* 移除按钮的阴影 */
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 95 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228120341.scss

@@ -0,0 +1,95 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  // /* 设置列表项的样式 */
+  // ion-item {
+  //   margin: 5px 0; /* 列表项之间的间距 */
+  // }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 92 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228120505.scss

@@ -0,0 +1,92 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  // /* 设置列表项的样式 */
+  // ion-item {
+  //   margin: 5px 0; /* 列表项之间的间距 */
+  // }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  
+
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 95 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228120542.scss

@@ -0,0 +1,95 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  // /* 设置列表项的样式 */
+  // ion-item {
+  //   margin: 5px 0; /* 列表项之间的间距 */
+  // }
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 93 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228121121.scss

@@ -0,0 +1,93 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+    background-color: transparent; /* 背景透明 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+    background-color: transparent; /* 背景透明 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 76 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228121144.html

@@ -0,0 +1,76 @@
+<ion-header [translucent]="true">
+  <ion-toolbar>
+    <ion-item lines="none">
+      <!-- 图片 -->
+      <ion-avatar slot="start" class="image-container">
+        <img src="assets/img/3.png" alt="Your Image" class="header-image">
+      </ion-avatar>
+ 
+      <!-- 搜索框 -->
+      <ion-searchbar slot="end" expand="with-icon"></ion-searchbar>
+    </ion-item>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content [fullscreen]="true">
+
+<section>
+  <ion-card>
+    <ion-card-header>
+      <ion-card-title>热门话题</ion-card-title>
+    </ion-card-header>
+    <ion-card-content>
+      <ion-list>
+        <ion-item *ngFor="let topic of topics">
+          <ion-label>
+            <h2>{{ topic.title }}</h2>
+            <p style="font-size: 16px;">{{ topic.description }}</p>
+          </ion-label>
+          <ion-buttons slot="end">
+          <ion-button class="custom-button" fill="solid" (click)="viewDetails(topic.id)">
+            <span class="button-text">查看详情</span>
+          </ion-button>
+        </ion-buttons>
+        </ion-item>
+      </ion-list>
+    </ion-card-content>
+  </ion-card>
+</section>
+
+<ion-toolbar  class="button-toolbar" style="margin-top: 10px; padding: 0;">
+  <ion-buttons slot="start" class="button-container">
+    <ion-button expand="full" (click)="goPsysurvey()">心理普查</ion-button>
+    <ion-button expand="full" (click)="goDriftbottle()">漂流瓶</ion-button>
+    <ion-button expand="full" >心协</ion-button>
+    <ion-button expand="full" >更多</ion-button>
+  </ion-buttons>
+</ion-toolbar>
+
+<section>
+  <ion-card>
+    <ion-card-header>
+      <ion-toolbar>
+      <ion-card-title>用户评价</ion-card-title>
+      <ion-buttons slot="end">
+        <ion-button (click)="evaluate()" class="custom-button" fill="solid">
+          <span class="button-text">进入评价</span>
+        </ion-button>
+      </ion-buttons>
+    </ion-toolbar>
+    </ion-card-header>
+    <ion-card-content>
+      <ion-list>
+        <ion-item *ngFor="let chatevaluate of chatevaluateList">
+          <ion-avatar slot="start">
+            <img [src]="chatevaluate.get('avatar') || 'https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/HZFoDv7vkk-0.png'"/>
+          </ion-avatar>
+          <ion-label>
+            <p style="font-size: 16px;">{{ chatevaluate.get('content') }}</p>
+            <ion-icon name="star" *ngFor="let star of createFilledArray(chatevaluate.get('rating')); let i = index" [attr.aria-hidden]="true"></ion-icon>
+          </ion-label>
+        </ion-item>
+      </ion-list>
+    </ion-card-content>
+  </ion-card>
+</section>
+</ion-content>

+ 95 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228121349.scss

@@ -0,0 +1,95 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+    background-color: transparent; /* 背景透明 */
+    color: transparent; /* 文字透明 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+    background-color: transparent; /* 背景透明 */
+    color: transparent; /* 文字透明 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 96 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228121533.scss

@@ -0,0 +1,96 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+    background-color: transparent; /* 背景透明 */
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+    background-color: transparent; /* 背景透明 */
+    color: transparent; /* 文字透明 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+    background-color: transparent; /* 背景透明 */
+    color: transparent; /* 文字透明 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 96 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228121610.scss

@@ -0,0 +1,96 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+    background-color:transparent; /* 背景透明 */
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+    background-color: transparent; /* 背景透明 */
+    color: transparent; /* 文字透明 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+    background-color: transparent; /* 背景透明 */
+    color: transparent; /* 文字透明 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 76 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228121640.html

@@ -0,0 +1,76 @@
+<ion-header [translucent]="true">
+  <ion-toolbar>
+    <ion-item lines="none">
+      <!-- 图片 -->
+      <ion-avatar slot="start" class="image-container">
+        <img src="assets/img/3.png" alt="Your Image" class="header-image">
+      </ion-avatar>
+ 
+      <!-- 搜索框 -->
+      <ion-searchbar slot="end" expand="with-icon"></ion-searchbar>
+    </ion-item>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content [fullscreen]="true">
+
+<section>
+  <ion-card>
+    <ion-card-header>
+      <ion-card-title>热门话题</ion-card-title>
+    </ion-card-header>
+    <ion-card-content>
+      <ion-list>
+        <ion-item *ngFor="let topic of topics">
+          <ion-label>
+            <h2>{{ topic.title }}</h2>
+            <p style="font-size: 16px;">{{ topic.description }}</p>
+          </ion-label>
+          <ion-buttons slot="end">
+          <ion-button class="custom-button" fill="solid" (click)="viewDetails(topic.id)">
+            <span class="button-text">查看详情</span>
+          </ion-button>
+        </ion-buttons>
+        </ion-item>
+      </ion-list>
+    </ion-card-content>
+  </ion-card>
+</section>
+
+<ion-toolbar  class="button-toolbar" >
+  <ion-buttons slot="start" class="button-container">
+    <ion-button expand="full" (click)="goPsysurvey()">心理普查</ion-button>
+    <ion-button expand="full" (click)="goDriftbottle()">漂流瓶</ion-button>
+    <ion-button expand="full" >心协</ion-button>
+    <ion-button expand="full" >更多</ion-button>
+  </ion-buttons>
+</ion-toolbar>
+
+<section>
+  <ion-card>
+    <ion-card-header>
+      <ion-toolbar>
+      <ion-card-title>用户评价</ion-card-title>
+      <ion-buttons slot="end">
+        <ion-button (click)="evaluate()" class="custom-button" fill="solid">
+          <span class="button-text">进入评价</span>
+        </ion-button>
+      </ion-buttons>
+    </ion-toolbar>
+    </ion-card-header>
+    <ion-card-content>
+      <ion-list>
+        <ion-item *ngFor="let chatevaluate of chatevaluateList">
+          <ion-avatar slot="start">
+            <img [src]="chatevaluate.get('avatar') || 'https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/HZFoDv7vkk-0.png'"/>
+          </ion-avatar>
+          <ion-label>
+            <p style="font-size: 16px;">{{ chatevaluate.get('content') }}</p>
+            <ion-icon name="star" *ngFor="let star of createFilledArray(chatevaluate.get('rating')); let i = index" [attr.aria-hidden]="true"></ion-icon>
+          </ion-label>
+        </ion-item>
+      </ion-list>
+    </ion-card-content>
+  </ion-card>
+</section>
+</ion-content>

+ 96 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228121852.scss

@@ -0,0 +1,96 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+    background-color:transparent; /* 背景透明 */
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+    background-color: transparent; /* 背景透明 */
+    color: transparent; /* 文字透明 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+    background-color: transparent; /* 背景透明 */
+    color: inherit; /* 继承父元素的颜色 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 76 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228121935.html

@@ -0,0 +1,76 @@
+<ion-header [translucent]="true">
+  <ion-toolbar>
+    <ion-item lines="none">
+      <!-- 图片 -->
+      <ion-avatar slot="start" class="image-container">
+        <img src="assets/img/3.png" alt="Your Image" class="header-image">
+      </ion-avatar>
+ 
+      <!-- 搜索框 -->
+      <ion-searchbar slot="end" expand="with-icon"></ion-searchbar>
+    </ion-item>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content [fullscreen]="true">
+
+<section>
+  <ion-card>
+    <ion-card-header>
+      <ion-card-title>热门话题</ion-card-title>
+    </ion-card-header>
+    <ion-card-content>
+      <ion-list>
+        <ion-item *ngFor="let topic of topics">
+          <ion-label>
+            <h2>{{ topic.title }}</h2>
+            <p style="font-size: 16px;">{{ topic.description }}</p>
+          </ion-label>
+          <ion-buttons slot="end">
+          <ion-button class="custom-button" fill="solid" (click)="viewDetails(topic.id)">
+            <span class="button-text">查看详情</span>
+          </ion-button>
+        </ion-buttons>
+        </ion-item>
+      </ion-list>
+    </ion-card-content>
+  </ion-card>
+</section>
+
+<ion-toolbar  class="button-toolbar" >
+  <ion-buttons slot="start" class="button-container">
+    <ion-button expand="clear" (click)="goPsysurvey()">心理普查</ion-button>
+    <ion-button expand="clear" (click)="goDriftbottle()">漂流瓶</ion-button>
+    <ion-button expand="clear" >心协</ion-button>
+    <ion-button expand="clear" >更多</ion-button>
+  </ion-buttons>
+</ion-toolbar>
+
+<section>
+  <ion-card>
+    <ion-card-header>
+      <ion-toolbar>
+      <ion-card-title>用户评价</ion-card-title>
+      <ion-buttons slot="end">
+        <ion-button (click)="evaluate()" class="custom-button" fill="solid">
+          <span class="button-text">进入评价</span>
+        </ion-button>
+      </ion-buttons>
+    </ion-toolbar>
+    </ion-card-header>
+    <ion-card-content>
+      <ion-list>
+        <ion-item *ngFor="let chatevaluate of chatevaluateList">
+          <ion-avatar slot="start">
+            <img [src]="chatevaluate.get('avatar') || 'https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/HZFoDv7vkk-0.png'"/>
+          </ion-avatar>
+          <ion-label>
+            <p style="font-size: 16px;">{{ chatevaluate.get('content') }}</p>
+            <ion-icon name="star" *ngFor="let star of createFilledArray(chatevaluate.get('rating')); let i = index" [attr.aria-hidden]="true"></ion-icon>
+          </ion-label>
+        </ion-item>
+      </ion-list>
+    </ion-card-content>
+  </ion-card>
+</section>
+</ion-content>

+ 76 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228122017.html

@@ -0,0 +1,76 @@
+<ion-header [translucent]="true">
+  <ion-toolbar>
+    <ion-item lines="none">
+      <!-- 图片 -->
+      <ion-avatar slot="start" class="image-container">
+        <img src="assets/img/3.png" alt="Your Image" class="header-image">
+      </ion-avatar>
+ 
+      <!-- 搜索框 -->
+      <ion-searchbar slot="end" expand="with-icon"></ion-searchbar>
+    </ion-item>
+  </ion-toolbar>
+</ion-header>
+
+<ion-content [fullscreen]="true">
+
+<section>
+  <ion-card>
+    <ion-card-header>
+      <ion-card-title>热门话题</ion-card-title>
+    </ion-card-header>
+    <ion-card-content>
+      <ion-list>
+        <ion-item *ngFor="let topic of topics">
+          <ion-label>
+            <h2>{{ topic.title }}</h2>
+            <p style="font-size: 16px;">{{ topic.description }}</p>
+          </ion-label>
+          <ion-buttons slot="end">
+          <ion-button class="custom-button" fill="solid" (click)="viewDetails(topic.id)">
+            <span class="button-text">查看详情</span>
+          </ion-button>
+        </ion-buttons>
+        </ion-item>
+      </ion-list>
+    </ion-card-content>
+  </ion-card>
+</section>
+
+<ion-toolbar  class="button-toolbar" >
+  <ion-buttons slot="start" class="button-container">
+    <ion-button fill="clear" (click)="goPsysurvey()">心理普查</ion-button>
+    <ion-button fill="clear" (click)="goDriftbottle()">漂流瓶</ion-button>
+    <ion-button fill="clear" >心协</ion-button>
+    <ion-button fill="clear" >更多</ion-button>
+  </ion-buttons>
+</ion-toolbar>
+
+<section>
+  <ion-card>
+    <ion-card-header>
+      <ion-toolbar>
+      <ion-card-title>用户评价</ion-card-title>
+      <ion-buttons slot="end">
+        <ion-button (click)="evaluate()" class="custom-button" fill="solid">
+          <span class="button-text">进入评价</span>
+        </ion-button>
+      </ion-buttons>
+    </ion-toolbar>
+    </ion-card-header>
+    <ion-card-content>
+      <ion-list>
+        <ion-item *ngFor="let chatevaluate of chatevaluateList">
+          <ion-avatar slot="start">
+            <img [src]="chatevaluate.get('avatar') || 'https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/HZFoDv7vkk-0.png'"/>
+          </ion-avatar>
+          <ion-label>
+            <p style="font-size: 16px;">{{ chatevaluate.get('content') }}</p>
+            <ion-icon name="star" *ngFor="let star of createFilledArray(chatevaluate.get('rating')); let i = index" [attr.aria-hidden]="true"></ion-icon>
+          </ion-label>
+        </ion-item>
+      </ion-list>
+    </ion-card-content>
+  </ion-card>
+</section>
+</ion-content>

+ 94 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228122213.scss

@@ -0,0 +1,94 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+    background-color:transparent; /* 背景透明 */
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+    background-color: transparent; /* 背景透明 */
+    color: transparent; /* 文字透明 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+    background-color: transparent; /* 背景透明 */
+    color: inherit; /* 继承父元素的颜色 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 96 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228122232.scss

@@ -0,0 +1,96 @@
+/* 整体ion-content背景 */
+ion-content {
+  --background: url('https://nova-cloud.obs.cn-south-1.myhuaweicloud.com/storage/aigc/imagine/4RHC2Jhp2l-0.png') no-repeat fixed!important;
+  --background-size: cover; /* 使背景图片覆盖整个屏幕 */
+}
+  /* 设置卡片的样式 */
+  ion-card {
+    margin: 10px; /* 卡片之间的间距 */
+    border-radius: 10px; /* 圆角效果 */
+    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); /* 阴影效果 */
+  }
+  ion-card-title {
+    font-weight:bold;
+  }
+  
+  ion-button {
+    font-size: 15px; /* 增大字体大小 */
+    margin-top: 8px; /* 上间距,仅在需要时添加 */
+    text-transform: none; /* 按钮文字不变形 */
+    height: 35px;
+    flex: 1; /* 每个按钮等分空间 */
+    margin: 1 7px; /* 按钮之间的间距 */
+    color: rgb(42, 50, 77);
+    background-color:transparent; /* 背景透明 */
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
+}
+  /* 设置搜索框的样式 */
+  ion-searchbar {
+    padding: 10px; /* 内边距 */
+    border-radius: 4px; /* 圆角 */
+    font-size: 16px; /* 字体大小 */
+  }
+  
+  /* 设置用户评价星星的样式 */
+  ion-icon[name="star"] {
+    color: gold; /* 星星颜色 */
+    font-size: 1.2rem; /* 星星大小 */
+  }
+  ion-card-header {
+    --background: #ffffff; /* 使用CSS变量设置背景颜色为白色 */
+    /* 或者,如果你不使用CSS变量,可以直接使用background-color属性 */
+    position: relative; /* 设置相对定位 */
+  }
+   
+  /* 实际上,ion-toolbar默认会继承ion-card-header的样式,但你可以显式地设置它以确保一致性 */
+  ion-toolbar {
+    --background: #ffffff; /* 同样使用CSS变量,但通常不是必需的 */
+  }
+   
+  /* 确保按钮的文本颜色是白色 */
+  .button-text {
+    color: #ffffff !important; /* 使用!important可以确保这个规则具有更高的优先级,但通常不推荐,除非确实需要 */
+  }
+
+  ion-avatar {
+    width: 50px; /* 或者你需要的任何尺寸 */
+    height: 50px; /* 保持宽高一致,避免变形 */
+  }
+   
+  ion-avatar img {
+    width: 100%; /* 让图片填满avatar */
+    height: auto; /* 保持图片比例 */
+  }
+  .header-image {
+    width: 100%;
+    height: auto; /* 保持图片比例 */
+    border-radius: 50%; /* 可选:将图片设置为圆形 */
+  }
+  .button-toolbar {
+    display: flex;
+    justify-content: space-between; /* 均匀分布按钮 */
+    background-color: transparent; /* 背景透明 */
+    color: transparent; /* 文字透明 */
+  }
+  
+  .button-container {
+    display: flex;
+    width: 100%; /* 使按钮容器占满整个宽度 */
+    background-color: transparent; /* 背景透明 */
+    color: inherit; /* 继承父元素的颜色 */
+  }
+  ion-item {
+    background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */
+    margin-bottom: 10px; /* 列表项之间的间距 */
+    padding: 0.5px; /* 内边距 */
+  }
+  

+ 142 - 0
.history/soul-app/src/app/tab1/tab1.page_20241228132832.ts

@@ -0,0 +1,142 @@
+import { Component,CUSTOM_ELEMENTS_SCHEMA } from '@angular/core';
+import { IonHeader, IonToolbar,IonContent, IonAvatar, IonButton, IonButtons, IonCard, IonCardContent, IonCardHeader, IonLabel, IonList,
+   IonItem,IonIcon,IonSearchbar} from '@ionic/angular/standalone';
+import { CommonModule } from '@angular/common';
+import { Router } from '@angular/router';
+import { CloudObject, CloudQuery, CloudUser } from 'src/lib/ncloud';
+import { ModalController } from '@ionic/angular/standalone';
+import { openUserEvaModal } from '../user-evaluate/user-evaluate.component';
+import { openUserLoginModal } from 'src/lib/user/modal-user-login/modal-user-login.component';
+@Component({
+  selector: 'app-tab1',
+  templateUrl: 'tab1.page.html',
+  styleUrls: ['tab1.page.scss'],
+  standalone: true,
+  imports: [IonHeader,IonToolbar,IonContent,
+    IonButtons,IonButton,IonIcon,
+    IonCard,IonCardContent,IonCardHeader,
+    IonLabel,IonList,IonItem,IonAvatar,IonSearchbar,
+    CommonModule,
+  ],
+  schemas: [CUSTOM_ELEMENTS_SCHEMA],
+})
+export class Tab1Page {
+  onSearch(event: any) {
+    const searchTerm = event.target.value; // 获取用户输入的搜索内容
+    console.log('搜索内容:', searchTerm);
+    // 在这里添加搜索逻辑,例如过滤列表或导航到搜索结果页面
+  }
+  topics = [
+    {
+      id: 1,
+      title: '如何管理焦虑情绪',
+      description: '了解焦虑的来源及应对策略',
+      detailRoute: 'topic-detail',
+    },
+    {
+      id: 2,
+      title: '克服抑郁的有效方法',
+      description: '探索抑郁症的应对技巧',
+      detailRoute: 'topic-detail2'
+    },
+    {
+      id: 3,
+      title: '提升自信心的技巧',
+      description: '学习如何建立自信',
+      detailRoute: 'topic-detail2'
+    }
+  ];
+  
+  async goPsysurvey() {
+    // 验证用户登录
+    let currentUser = new CloudUser();
+    if(!currentUser?.id){
+      console.log("用户未登录,请登录后重试")
+      let user = await openUserLoginModal(this.modalCtrl)
+      if(!user?.id){
+        console.log("用户登录失败");
+        return
+      } 
+      else { 
+        console.log("当前用户ID:", currentUser.id);
+      }    
+    }
+    this.router.navigate(['tabs/page-psysurvey'])
+  }
+  async goDriftbottle() {
+    // 验证用户登录
+    let currentUser = new CloudUser();
+    if(!currentUser?.id){
+      console.log("用户未登录,请登录后重试")
+      let user = await openUserLoginModal(this.modalCtrl)
+      if(!user?.id){
+        console.log("用户登录失败");
+        return
+      } 
+      else { 
+        console.log("当前用户ID:", currentUser.id);
+      }    
+    }
+    this.router.navigate(['tabs/drift-bottle'])
+  }
+  
+  viewDetails(topicId: number): void {
+    let route: string;
+    switch (topicId) {
+      case 1:
+        route = 'topic-detail';
+        break;
+      case 2:
+        route = 'topic-detail2';
+        break;
+      case 3:
+        route = 'topic-detail3';
+        break;
+      default:
+        route = 'topic-detail'; // 默认路由
+    }
+    // 导航到指定的路由,并可以传递参数
+    this.router.navigate([`tabs/${route}`, { id: topicId }]);
+  }
+  constructor(private router: Router,private modalCtrl: ModalController) {
+    // 其他构造函数代码
+  }
+  matchedCounselor: { content: string; rating: number } | null = null;
+  review: any = { rating: 5 };  // 示例数据
+  // 创建一个方法,用于生成填充了 null 的数组
+  createFilledArray(length: number): any[] {
+    // 确保返回的数组长度不超过5
+    const maxStars = 5;
+    return Array(Math.min(length, maxStars)).fill(null);
+  }
+  async evaluate() {
+    // 处理点击评价的逻辑
+    // 验证用户登录
+    let currentUser = new CloudUser();
+    if(!currentUser?.id){
+      console.log("用户未登录,请登录后重试")
+      let user = await openUserLoginModal(this.modalCtrl)
+      if(!user?.id){
+        console.log("用户登录失败");
+        return
+      } 
+      else { 
+        console.log("当前用户ID:", currentUser.id);
+      }    
+    }
+     // 打开评价模态框
+     const evaluationResult = await openUserEvaModal(this.modalCtrl);
+     // 如果评价成功,重新加载评价列表
+     if (evaluationResult) {
+         await this.loadChatEvaluateList(); // 重新加载评价列表
+     }
+  }
+  ngOnInit() {
+    this.loadChatEvaluateList()
+  }
+  chatevaluateList:Array<CloudObject>=[]
+  async loadChatEvaluateList(){
+    let query = new CloudQuery("ChatEvaluate");
+    this.chatevaluateList = await query.find()
+  }
+}

+ 10 - 5
soul-app/src/app/my-drift-bottle/my-drift-bottle.component.html

@@ -2,8 +2,8 @@
   <ion-toolbar>
     <div class="toolbar-content">
       <div class="button-container">
-        <ion-button (click)="goDriftbottle()" fill="clear">
-          <ion-icon name="chevron-back" slot="start"></ion-icon>返回
+        <ion-button (click)="goDriftbottle()" fill="clear" class="butcolor">
+          <ion-icon name="chevron-back" slot="start" ></ion-icon>返回
         </ion-button>
       </div>
       <ion-title class="title-text">
@@ -43,15 +43,20 @@
         <ion-card-header>
           <ion-card-title>{{ bottle.get('content') }}</ion-card-title>
         </ion-card-header>
-        <ion-card-content>
-          <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+        <ion-card-content class="card-content-with-button">
+          <div class="content-section">
+            <p>打捞时间: {{ bottle.get('catchtime') }}</p>
+          </div>
+          <div class="button-section">
+            <ion-button (click)="rethrowBottle(bottle)" class="custom-color">扔回</ion-button>
+          </div>
         </ion-card-content>
       </ion-card>
     </section>
   </ion-list>
 
   <div style="display: flex; justify-content: center; margin-top: auto;">
-    <ion-button (click)="gothrowNewDriftbottle()" expand="full">
+    <ion-button (click)="gothrowNewDriftbottle()" expand="full" class="custom-color">
       投掷新的漂流瓶
     </ion-button>
   </div>

+ 27 - 1
soul-app/src/app/my-drift-bottle/my-drift-bottle.component.scss

@@ -11,7 +11,26 @@ ion-content {
   ion-card-title {
     font-weight:bold;
   }
+  .card-content-with-button {
+    display: flex;
+    justify-content: space-between;
+    align-items: center;
+    
+  }
+  
+  .content-section {
+    flex-grow: 1;
+  }
+  
+  .button-section {
+    margin-left: 10px;
+    
+  }
   
+  /* 确保按钮文本正常横排 */
+  ion-button {
+    white-space: nowrap;
+  }
   /* 设置列表项的样式 */
   ion-item {
     margin: 5px 0; /* 列表项之间的间距 */
@@ -51,5 +70,12 @@ ion-content {
   top: 10px;
   color:rgb(69, 166, 180);
   }
-
+  .custom-color {
+    --background: rgb(69, 166, 180);
+    --background-activated: rgba(69, 166, 180, 0.7);
+    --color: white;
+  }
+  .butcolor{
+    --color: rgb(69, 166, 180);
+  }
   

+ 33 - 20
soul-app/src/app/my-drift-bottle/my-drift-bottle.component.ts

@@ -4,7 +4,7 @@ import { CommonModule } from '@angular/common'; // 导入 CommonModule
 
 import { IonHeader, IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
   IonListHeader, IonCardHeader, IonCardTitle, IonCardContent, IonTitle, IonCard, IonToolbar, IonInput, IonSearchbar } from '@ionic/angular/standalone';
-import { CloudQuery, CloudUser } from 'src/lib/ncloud';
+import { CloudQuery, CloudObject, CloudUser } from 'src/lib/ncloud';
 import { UserService } from 'src/app/user.service'; // 假设这是你的用户服务
 
 @Component({
@@ -22,11 +22,10 @@ import { UserService } from 'src/app/user.service'; // 假设这是你的用户
   ]
 })
 export class MyDriftBottleComponent implements OnInit {
-  filteredDriftbottles2:any[]=[];
-  Driftbottles: any[]=[];
-  filteredDriftbottles: any[]=[];
-  username: String='';
-  
+  filteredDriftbottles2: any[] = [];
+  Driftbottles: any[] = [];
+  filteredDriftbottles: any[] = [];
+  username: string = '';
 
   constructor(private router: Router, private userService: UserService) {}
 
@@ -35,32 +34,30 @@ export class MyDriftBottleComponent implements OnInit {
   }
 
   async getDriftbottles() {
-    let query=new CloudQuery("Driftbottle");
-    this.Driftbottles = await query.find(); 
-      this.filterDriftbottles(); 
-      this.filterDriftbottles2(); 
-
+    let query = new CloudQuery("Driftbottle");
+    this.Driftbottles = await query.find();
+    this.filterDriftbottles();
+    this.filterDriftbottles2();
   }
 
   filterDriftbottles() {
     let user = new CloudUser();
-    console.log(user)
+    console.log(user);
     this.filteredDriftbottles = this.Driftbottles.filter(driftbottle => {
-      console.log(driftbottle.get("username"), user.get("username"))
-      return (driftbottle.get("username") === user.get("username") || driftbottle.get("username") === 'all');
+      console.log(driftbottle.get("username"), user.get("username"));
+      return driftbottle.get("username") === user.get("username") || driftbottle.get("username") === 'all';
     });
   }
-  filterDriftbottles2(){
+
+  filterDriftbottles2() {
     let user = new CloudUser();
-    console.log(user)
+    console.log(user);
     this.filteredDriftbottles2 = this.Driftbottles.filter(driftbottle => {
-      console.log(driftbottle.get("catcher"), user.get("username"))
-      return (driftbottle.get("catcher") === user.get("username") || driftbottle.get("catcher") === 'all');
+      console.log(driftbottle.get("catcher"), user.get("username"));
+      return driftbottle.get("catcher") === user.get("username") || driftbottle.get("catcher") === 'all';
     });
   }
 
-  
-
   goDriftbottle() {
     this.router.navigate(['tabs/drift-bottle']);
   }
@@ -68,4 +65,20 @@ export class MyDriftBottleComponent implements OnInit {
   gothrowNewDriftbottle() {
     this.router.navigate(['tabs/drift-bottle']); // 假设这是投掷新漂流瓶的路由
   }
+
+  async rethrowBottle(bottle: CloudObject) {
+    try {
+      bottle.set({
+        status: "drifting",
+        catcher: null,
+        catchtime: null
+      });
+
+      await bottle.save();
+      this.getDriftbottles(); // 刷新漂流瓶列表
+      console.log('漂流瓶扔回成功');
+    } catch (err) {
+      console.error('扔回漂流瓶时出错:', err);
+    }
+  }
 }

+ 7 - 7
soul-app/src/app/tab1/tab1.page.html

@@ -27,7 +27,7 @@
             <p style="font-size: 16px;">{{ topic.description }}</p>
           </ion-label>
           <ion-buttons slot="end">
-          <ion-button color="primary" fill="solid" (click)="viewDetails(topic.id)">
+          <ion-button class="custom-button" fill="solid" (click)="viewDetails(topic.id)">
             <span class="button-text">查看详情</span>
           </ion-button>
         </ion-buttons>
@@ -37,12 +37,12 @@
   </ion-card>
 </section>
 
-<ion-toolbar color="light" class="button-toolbar" style="margin-top: 10px; padding: 0;">
+<ion-toolbar  class="button-toolbar" >
   <ion-buttons slot="start" class="button-container">
-    <ion-button expand="full" (click)="goPsysurvey()">心理普查</ion-button>
-    <ion-button expand="full" (click)="goDriftbottle()">漂流瓶</ion-button>
-    <ion-button expand="full" >心协</ion-button>
-    <ion-button expand="full" >更多</ion-button>
+    <ion-button fill="clear" (click)="goPsysurvey()">心理普查</ion-button>
+    <ion-button fill="clear" (click)="goDriftbottle()">漂流瓶</ion-button>
+    <ion-button fill="clear" >心协</ion-button>
+    <ion-button fill="clear" >更多</ion-button>
   </ion-buttons>
 </ion-toolbar>
 
@@ -52,7 +52,7 @@
       <ion-toolbar>
       <ion-card-title>用户评价</ion-card-title>
       <ion-buttons slot="end">
-        <ion-button (click)="evaluate()" color="primary" fill="solid">
+        <ion-button (click)="evaluate()" class="custom-button" fill="solid">
           <span class="button-text">进入评价</span>
         </ion-button>
       </ion-buttons>

+ 15 - 4
soul-app/src/app/tab1/tab1.page.scss

@@ -13,10 +13,6 @@ ion-content {
     font-weight:bold;
   }
   
-  // /* 设置列表项的样式 */
-  // ion-item {
-  //   margin: 5px 0; /* 列表项之间的间距 */
-  // }
   ion-button {
     font-size: 15px; /* 增大字体大小 */
     margin-top: 8px; /* 上间距,仅在需要时添加 */
@@ -25,6 +21,17 @@ ion-content {
     flex: 1; /* 每个按钮等分空间 */
     margin: 1 7px; /* 按钮之间的间距 */
     color: rgb(42, 50, 77);
+    background-color:transparent; /* 背景透明 */
+}
+/* 按钮颜色为暖色系 */
+.custom-button {
+  --background: #f9dd94; /* 浅粉色,作为示例的暖色系 */
+  --color: #FFFFFF; /* 白色文本 */
+  
+  font-size: 15px; /* 增大字体大小 */
+  margin-top: 8px; /* 上间距,仅在需要时添加 */
+  text-transform: none; /* 按钮文字不变形 */
+  height: 40px; /* 按钮高度 */
 }
   /* 设置搜索框的样式 */
   ion-searchbar {
@@ -71,11 +78,15 @@ ion-content {
   .button-toolbar {
     display: flex;
     justify-content: space-between; /* 均匀分布按钮 */
+    background-color: transparent; /* 背景透明 */
+    color: transparent; /* 文字透明 */
   }
   
   .button-container {
     display: flex;
     width: 100%; /* 使按钮容器占满整个宽度 */
+    background-color: transparent; /* 背景透明 */
+    color: inherit; /* 继承父元素的颜色 */
   }
   ion-item {
     background: rgba(18, 10, 0, 0.01); /* 列表项背景为半透明白色 */

+ 28 - 2
soul-app/src/app/tab1/tab1.page.ts

@@ -47,10 +47,36 @@ export class Tab1Page {
     }
   ];
   
-  goPsysurvey() {
+  async goPsysurvey() {
+    // 验证用户登录
+    let currentUser = new CloudUser();
+    if(!currentUser?.id){
+      console.log("用户未登录,请登录后重试")
+      let user = await openUserLoginModal(this.modalCtrl)
+      if(!user?.id){
+        console.log("用户登录失败");
+        return
+      } 
+      else { 
+        console.log("当前用户ID:", currentUser.id);
+      }    
+    }
     this.router.navigate(['tabs/page-psysurvey'])
   }
-  goDriftbottle() {
+  async goDriftbottle() {
+    // 验证用户登录
+    let currentUser = new CloudUser();
+    if(!currentUser?.id){
+      console.log("用户未登录,请登录后重试")
+      let user = await openUserLoginModal(this.modalCtrl)
+      if(!user?.id){
+        console.log("用户登录失败");
+        return
+      } 
+      else { 
+        console.log("当前用户ID:", currentUser.id);
+      }    
+    }
     this.router.navigate(['tabs/drift-bottle'])
   }