Browse Source

feat: CloudUser & CloudQuery & CloudObject crud

未来全栈 3 months ago
parent
commit
5e82783a69
41 changed files with 181 additions and 1404 deletions
  1. 0 3
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217163938.html
  2. 0 0
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217163938.scss
  3. 0 15
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217163938.ts
  4. 0 39
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217164909.scss
  5. 0 39
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217164930.scss
  6. 0 14
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217164931.html
  7. 0 27
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217165144.ts
  8. 0 27
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217165208.ts
  9. 0 53
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218183550.scss
  10. 0 41
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218183617.html
  11. 0 20
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218183929.html
  12. 0 29
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218184007.html
  13. 0 27
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218184013.ts
  14. 0 27
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218184057.ts
  15. 0 40
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218184947.html
  16. 0 36
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218193359.html
  17. 0 30
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218193717.ts
  18. 0 36
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218193720.html
  19. 0 36
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218193742.html
  20. 0 36
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218194414.html
  21. 0 30
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218194849.ts
  22. 0 53
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218195200.scss
  23. 0 36
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218203144.html
  24. 0 30
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218205727.ts
  25. 0 30
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241219161716.ts
  26. 0 35
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223214953.html
  27. 0 68
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223214958.ts
  28. 0 66
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223232115.ts
  29. 0 66
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223232614.ts
  30. 0 67
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223233228.ts
  31. 0 67
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223235522.ts
  32. 0 67
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223235734.ts
  33. 0 36
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241224003203.html
  34. 0 35
      .history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241224003220.html
  35. 2 2
      soul-app/src/app/page-psysurvey/page-psysurvey.component.html
  36. 8 17
      soul-app/src/app/page-psysurvey/page-psysurvey.component.ts
  37. 9 9
      soul-app/src/app/page-publishsurvey/page-publishsurvey.component.ts
  38. 2 1
      soul-app/src/app/user-evaluate/user-evaluate.component.ts
  39. 6 7
      soul-app/src/app/user.service.ts
  40. 52 0
      soul-app/src/lib/cloud.evaluate.ts
  41. 102 107
      soul-app/src/lib/ncloud.ts

+ 0 - 3
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217163938.html

@@ -1,3 +0,0 @@
-<p>
-  page-psysurvey works!
-</p>

+ 0 - 0
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217163938.scss


+ 0 - 15
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217163938.ts

@@ -1,15 +0,0 @@
-import { Component, OnInit } from '@angular/core';
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-})
-export class PagePsysurveyComponent  implements OnInit {
-
-  constructor() { }
-
-  ngOnInit() {}
-
-}

+ 0 - 39
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217164909.scss

@@ -1,39 +0,0 @@
-/* 设置页面背景色 */
-ion-content {
-    --background: #ffffff; /* 白色背景 */
-  }
-  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: 65px;
-  margin: auto;
-  top: 10px;
-  }
-  

+ 0 - 39
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217164930.scss

@@ -1,39 +0,0 @@
-/* 设置页面背景色 */
-ion-content {
-    --background: #ffffff; /* 白色背景 */
-  }
-  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: 125px;
-  margin: auto;
-  top: 10px;
-  }
-  

+ 0 - 14
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217164931.html

@@ -1,14 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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>

+ 0 - 27
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217165144.ts

@@ -1,27 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader, IonTitle, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,ExploreContainerComponent,
-      IonList,IonListHeader,IonItem,
-      IonLabel,IonIcon,IonButton,
-      IonInput,IonSearchbar,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-
-  constructor(private router: Router) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-  ngOnInit() {}
-
-}

+ 0 - 27
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241217165208.ts

@@ -1,27 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader, IonTitle, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,
-      IonLabel,IonIcon,IonButton,
-      IonInput,IonSearchbar,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-
-  constructor(private router: Router) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-  ngOnInit() {}
-
-}

+ 0 - 53
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218183550.scss

@@ -1,53 +0,0 @@
-/* 设置页面背景色 */
-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;
-  }
-  
-  /* 设置列表项的样式 */
-  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: 125px;
-  margin: auto;
-  top: 10px;
-  }
-  

+ 0 - 41
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218183617.html

@@ -1,41 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [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>{{ topic.description }}</p>
-            </ion-label>
-            <ion-buttons slot="end">
-            <ion-button color="primary" 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-content>

+ 0 - 20
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218183929.html

@@ -1,20 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [fullscreen]="true">
-
-  
-
-</ion-content>

+ 0 - 29
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218184007.html

@@ -1,29 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [fullscreen]="true">
-
-  <section>
-    <ion-card>
-      <ion-card-header>
-        <ion-card-title>热门话题</ion-card-title>
-      </ion-card-header>
-      <ion-card-content>
-        
-      </ion-card-content>
-    </ion-card>
-  </section>
-
-</ion-content>

+ 0 - 27
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218184013.ts

@@ -1,27 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-
-  constructor(private router: Router) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-  ngOnInit() {}
-
-}

+ 0 - 27
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218184057.ts

@@ -1,27 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardTitle,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,IonCardTitle,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-
-  constructor(private router: Router) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-  ngOnInit() {}
-
-}

+ 0 - 40
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218184947.html

@@ -1,40 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [fullscreen]="true">
-
-  <section>
-    <ion-card>
-      <ion-card-header>
-        <ion-card-title>问卷通知</ion-card-title>
-      </ion-card-header>
-      <ion-card-content>
-        
-      </ion-card-content>
-    </ion-card>
-  </section>
-
-  <section>
-    <ion-card>
-      <ion-card-header>
-        <ion-card-title>发布问卷</ion-card-title>
-      </ion-card-header>
-      <ion-card-content>
-        
-      </ion-card-content>
-    </ion-card>
-  </section>
-
-</ion-content>

+ 0 - 36
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218193359.html

@@ -1,36 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [fullscreen]="true">
-
-  <section>
-    <ion-card>
-      <ion-card-header>
-        <ion-card-title>心理问卷调查通知</ion-card-title>
-      </ion-card-header>
-      <ion-card-content>
-        
-      </ion-card-content>
-    </ion-card>
-  </section>
-
-  <div  style="display: flex; justify-content: center; margin-top: auto;">
-    <ion-button  expand="full">
-      发布问卷
-    </ion-button>
-  </div>
-
-
-</ion-content>

+ 0 - 30
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218193717.ts

@@ -1,30 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardTitle,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,IonCardTitle,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-
-  constructor(private router: Router) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-   goPublishSurvey(){
-    this.router.navigate(['tabs/publishsurvey'])
-   }
-  ngOnInit() {}
-
-}

+ 0 - 36
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218193720.html

@@ -1,36 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [fullscreen]="true">
-
-  <section>
-    <ion-card>
-      <ion-card-header>
-        <ion-card-title>心理问卷调查通知</ion-card-title>
-      </ion-card-header>
-      <ion-card-content>
-        
-      </ion-card-content>
-    </ion-card>
-  </section>
-
-  <div  style="display: flex; justify-content: center; margin-top: auto;">
-    <ion-button (click)="goPublishSurvey()" expand="full">
-      发布问卷
-    </ion-button>
-  </div>
-
-
-</ion-content>

+ 0 - 36
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218193742.html

@@ -1,36 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [fullscreen]="true">
-
-  <section>
-    <ion-card>
-      <ion-card-header>
-        <ion-card-title>心理问卷调查通知</ion-card-title>
-      </ion-card-header>
-      <ion-card-content>
-        
-      </ion-card-content>
-    </ion-card>
-  </section>
-
-  <div  style="display: flex; justify-content: center; margin-top: auto;">
-    <ion-button (click)="goPublishSurvey()" expand="full">
-      发布问卷
-    </ion-button>
-  </div>
-
-
-</ion-content>

+ 0 - 36
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218194414.html

@@ -1,36 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [fullscreen]="true">
-
-  <section>
-    <ion-card>
-      <ion-card-header>
-        <ion-card-title>心理问卷调查通知</ion-card-title>
-      </ion-card-header>
-      <ion-card-content>
-        
-      </ion-card-content>
-    </ion-card>
-  </section>
-
-  
-    <ion-button class="publish" (click)="goPublishSurvey()" expand="full">
-      发布问卷
-    </ion-button>
-  
-
-
-</ion-content>

+ 0 - 30
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218194849.ts

@@ -1,30 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardTitle,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,IonCardTitle,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-
-  constructor(private router: Router) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-   goPublishSurvey(){
-    this.router.navigate(['tabs/page-publishsurvey'])
-   }
-  ngOnInit() {}
-
-}

+ 0 - 53
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218195200.scss

@@ -1,53 +0,0 @@
-/* 设置页面背景色 */
-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;
-  }
-  
-  /* 设置列表项的样式 */
-  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: 125px;
-  margin: auto;
-  top: 10px;
-  }
-  

+ 0 - 36
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218203144.html

@@ -1,36 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [fullscreen]="true">
-
-  <section>
-    <ion-card>
-      <ion-card-header>
-        <ion-card-title>心理问卷调查通知</ion-card-title>
-      </ion-card-header>
-      <ion-card-content>
-        
-      </ion-card-content>
-    </ion-card>
-  </section>
-
-  <div  style="display: flex; justify-content: center; margin-top: auto;">
-    <ion-button (click)="goPublishSurvey()" expand="full">
-      发布问卷
-    </ion-button>
-  </div>
-
-
-</ion-content>

+ 0 - 30
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241218205727.ts

@@ -1,30 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardTitle,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,IonCardTitle,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-
-  constructor(private router: Router) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-   goPublishSurvey(){
-    this.router.navigate(['tabs/publishsurvey'])
-   }
-  ngOnInit() {}
-
-}

+ 0 - 30
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241219161716.ts

@@ -1,30 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardTitle,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,IonCardTitle,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-
-  constructor(private router: Router) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-   goPublishSurvey(){
-    this.router.navigate(['tabs/page-publishsurvey'])
-   }
-  ngOnInit() {}
-
-}

+ 0 - 35
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223214953.html

@@ -1,35 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [fullscreen]="true">
-<section *ngIf="filteredSurveys.length > 0">
-  <ion-card *ngFor="let survey of filteredSurveys">
-    <ion-card-header>
-      <ion-card-title>{{ survey.title }}</ion-card-title>
-    </ion-card-header>
-    <ion-card-content>
-      <p>链接: <a [href]="survey.link" target="_blank">{{ survey.link }}</a></p>
-    </ion-card-content>
-  </ion-card>
-</section>
-
-  <div  style="display: flex; justify-content: center; margin-top: auto;">
-    <ion-button (click)="goPublishSurvey()" expand="full">
-      发布问卷
-    </ion-button>
-  </div>
-
-
-</ion-content>

+ 0 - 68
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223214958.ts

@@ -1,68 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit, Injectable } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardTitle,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-  import { HttpClient } from '@angular/common/http';
-  import { UserService } from '../user.service'; // 确保路径正确
-
-
-  @Injectable({
-    providedIn: 'root'
-  })
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,IonCardTitle,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule,HttpClient,Injectable
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-  surveys: any[] = []; // 存储问卷通知
-  filteredSurveys: any[] = []; // 存储过滤后的问卷
-  userApartment: string = '' ; // 当前用户的学院
-
-  constructor(private router: Router,private http: HttpClient,private userService: UserService) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-   goPublishSurvey(){
-    this.router.navigate(['tabs/page-publishsurvey'])
-   }
-
-   ngOnInit() {
-    // 动态获取当前用户的学院信息
-    this.userService.getCurrentUser().subscribe(user => {
-      this.userApartment = user.apartment; // 从用户数据中获取学院
-      this.getSurveys(); // 在获取到用户信息后获取问卷
-    }, error => {
-      console.error('获取用户信息时出错:', error);
-      // 可以设置一个默认值或处理错误
-    });
-  }
-
-  getSurveys() {
-    this.http.get('http://127.0.0.1:4040/apps/DevServer/browser/survey').subscribe(
-      (response: any) => {
-        this.surveys = response; // 假设响应是问卷数组
-        this.filterSurveys(); // 过滤问卷
-      },
-      error => {
-        console.error('获取问卷时出错:', error);
-      }
-    );
-  }
-  filterSurveys() {
-    this.filteredSurveys = this.surveys.filter(survey => {
-      return survey.audience === this.userApartment || survey.audience === 'all';
-    });
-  }
-  
-  
-}

+ 0 - 66
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223232115.ts

@@ -1,66 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardTitle,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-  import { HttpClient } from '@angular/common/http';
-  import { UserService } from '../user.service'; // 确保路径正确
-
-
-  
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,IonCardTitle,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule,HttpClient
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-  surveys: any[] = []; // 存储问卷通知
-  filteredSurveys: any[] = []; // 存储过滤后的问卷
-  userApartment: string = '' ; // 当前用户的学院
-
-  constructor(private router: Router,private http: HttpClient,private userService: UserService) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-   goPublishSurvey(){
-    this.router.navigate(['tabs/page-publishsurvey'])
-   }
-
-   ngOnInit() {
-    // 动态获取当前用户的学院信息
-    this.userService.getCurrentUser().subscribe(user => {
-      this.userApartment = user.apartment; // 从用户数据中获取学院
-      this.getSurveys(); // 在获取到用户信息后获取问卷
-    }, error => {
-      console.error('获取用户信息时出错:', error);
-      // 可以设置一个默认值或处理错误
-    });
-  }
-
-  getSurveys() {
-    this.http.get('http://127.0.0.1:4040/apps/DevServer/browser/survey').subscribe(
-      (response: any) => {
-        this.surveys = response; // 假设响应是问卷数组
-        this.filterSurveys(); // 过滤问卷
-      },
-      error => {
-        console.error('获取问卷时出错:', error);
-      }
-    );
-  }
-  filterSurveys() {
-    this.filteredSurveys = this.surveys.filter(survey => {
-      return survey.audience === this.userApartment || survey.audience === 'all';
-    });
-  }
-  
-  
-}

+ 0 - 66
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223232614.ts

@@ -1,66 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardTitle,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-  import { HttpClient } from '@angular/common/http';
-  import { UserService } from '../user.service'; // 确保路径正确
-
-
-  
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,IonCardTitle,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-  surveys: any[] = []; // 存储问卷通知
-  filteredSurveys: any[] = []; // 存储过滤后的问卷
-  userApartment: string = '' ; // 当前用户的学院
-
-  constructor(private router: Router,private http: HttpClient,private userService: UserService) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-   goPublishSurvey(){
-    this.router.navigate(['tabs/page-publishsurvey'])
-   }
-
-   ngOnInit() {
-    // 动态获取当前用户的学院信息
-    this.userService.getCurrentUser().subscribe(user => {
-      this.userApartment = user.apartment; // 从用户数据中获取学院
-      this.getSurveys(); // 在获取到用户信息后获取问卷
-    }, error => {
-      console.error('获取用户信息时出错:', error);
-      // 可以设置一个默认值或处理错误
-    });
-  }
-
-  getSurveys() {
-    this.http.get('http://127.0.0.1:4040/apps/DevServer/browser/survey').subscribe(
-      (response: any) => {
-        this.surveys = response; // 假设响应是问卷数组
-        this.filterSurveys(); // 过滤问卷
-      },
-      error => {
-        console.error('获取问卷时出错:', error);
-      }
-    );
-  }
-  filterSurveys() {
-    this.filteredSurveys = this.surveys.filter(survey => {
-      return survey.audience === this.userApartment || survey.audience === 'all';
-    });
-  }
-  
-  
-}

+ 0 - 67
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223233228.ts

@@ -1,67 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardTitle,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-  import { HttpClient } from '@angular/common/http';
-  import { UserService } from '../user.service'; // 确保路径正确
-  import { FormsModule } from '@angular/forms'; // 导入 FormsModule
-
-
-  
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,IonCardTitle,FormsModule,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-  surveys: any[] = []; // 存储问卷通知
-  filteredSurveys: any[] = []; // 存储过滤后的问卷
-  userApartment: string = '' ; // 当前用户的学院
-
-  constructor(private router: Router,private http: HttpClient,private userService: UserService) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-   goPublishSurvey(){
-    this.router.navigate(['tabs/page-publishsurvey'])
-   }
-
-   ngOnInit() {
-    // 动态获取当前用户的学院信息
-    this.userService.getCurrentUser().subscribe(user => {
-      this.userApartment = user.apartment; // 从用户数据中获取学院
-      this.getSurveys(); // 在获取到用户信息后获取问卷
-    }, error => {
-      console.error('获取用户信息时出错:', error);
-      // 可以设置一个默认值或处理错误
-    });
-  }
-
-  getSurveys() {
-    this.http.get('http://127.0.0.1:4040/apps/DevServer/browser/survey').subscribe(
-      (response: any) => {
-        this.surveys = response; // 假设响应是问卷数组
-        this.filterSurveys(); // 过滤问卷
-      },
-      error => {
-        console.error('获取问卷时出错:', error);
-      }
-    );
-  }
-  filterSurveys() {
-    this.filteredSurveys = this.surveys.filter(survey => {
-      return survey.audience === this.userApartment || survey.audience === 'all';
-    });
-  }
-  
-  
-}

+ 0 - 67
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223235522.ts

@@ -1,67 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardTitle,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-  import { HttpClient } from '@angular/common/http';
-  import { UserService } from '../user.service'; // 确保路径正确
-  import { FormsModule } from '@angular/forms'; // 导入 FormsModule
-
-
-  
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,IonCardTitle,FormsModule,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-  surveys: any[] = []; // 存储问卷通知
-  filteredSurveys: any[] = []; // 存储过滤后的问卷
-  userApartment: string = '' ; // 当前用户的学院
-
-  constructor(private router: Router,private http: HttpClient,private userService: UserService) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-   goPublishSurvey(){
-    this.router.navigate(['tabs/page-publishsurvey'])
-   }
-
-   ngOnInit() {
-    // 动态获取当前用户的学院信息
-    this.userService.getCurrentUser().subscribe(user => {
-      this.userApartment = user.apartment; // 从用户数据中获取学院
-      this.getSurveys(); // 在获取到用户信息后获取问卷
-    }, error => {
-      console.error('获取用户信息时出错:', error);
-      // 可以设置一个默认值或处理错误
-    });
-  }
-
-  getSurveys() {
-    this.http.get('http://127.0.0.1:4040/apps/DevServer/browser/survey').subscribe(
-      (response: any) => {
-        this.surveys = response; // 假设响应是问卷数组
-        this.filterSurveys(); // 过滤问卷
-      },
-      error => {
-        console.error('获取问卷时出错:', error);
-      }
-    );
-  }
-  filterSurveys() {
-    this.filteredSurveys = this.surveys.filter(survey => {
-      return survey.audience === this.userApartment || survey.audience === 'all';
-    });
-  }
-  
-  
-}

+ 0 - 67
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241223235734.ts

@@ -1,67 +0,0 @@
-import { CommonModule } from '@angular/common';
-import { Component, OnInit } from '@angular/core';
-import { Router } from '@angular/router';
-import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList, 
-  IonListHeader,IonCardHeader,IonCardTitle,IonCardContent, IonTitle,IonCard, IonToolbar,IonInput,IonSearchbar } from '@ionic/angular/standalone';
-  import { HttpClient } from '@angular/common/http';
-  import { UserService } from '../user.service'; // 确保路径正确
-  import { FormsModule } from '@angular/forms'; // 导入 FormsModule
-
-
-  
-
-@Component({
-  selector: 'app-page-psysurvey',
-  templateUrl: './page-psysurvey.component.html',
-  styleUrls: ['./page-psysurvey.component.scss'],
-  standalone: true,
-  imports: [IonHeader,IonToolbar,IonTitle,IonContent,
-      IonList,IonListHeader,IonItem,IonCardTitle,FormsModule,
-      IonLabel,IonIcon,IonButton,IonCardContent,
-      IonInput,IonSearchbar,IonCard,IonCardHeader,
-      CommonModule
-    ]
-})
-export class PagePsysurveyComponent  implements OnInit {
-  surveys: any[] = []; // 存储问卷通知
-  filteredSurveys: any[] = []; // 存储过滤后的问卷
-  userApartment: string = '' ; // 当前用户的学院
-
-  constructor(private router: Router,private http: HttpClient,private userService: UserService) { }
-  goTab1(){
-    this.router.navigate(['tabs/tab1']);
-   }
-   goPublishSurvey(){
-    this.router.navigate(['tabs/page-publishsurvey'])
-   }
-
-   ngOnInit() {
-    // 动态获取当前用户的学院信息
-    this.userService.getCurrentUser().subscribe(user => {
-      this.userApartment = user.apartment; // 从用户数据中获取学院
-      this.getSurveys(); // 在获取到用户信息后获取问卷
-    }, error => {
-      console.error('获取用户信息时出错:', error);
-      // 可以设置一个默认值或处理错误
-    });
-  }
-
-  getSurveys() {
-    this.http.get('http://127.0.0.1:4040/').subscribe(
-      (response: any) => {
-        this.surveys = response; // 假设响应是问卷数组
-        this.filterSurveys(); // 过滤问卷
-      },
-      error => {
-        console.error('获取问卷时出错:', error);
-      }
-    );
-  }
-  filterSurveys() {
-    this.filteredSurveys = this.surveys.filter(survey => {
-      return survey.audience === this.userApartment || survey.audience === 'all';
-    });
-  }
-  
-  
-}

+ 0 - 36
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241224003203.html

@@ -1,36 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [fullscreen]="true">
-<section *ngIf="filteredSurveys.length > 0">
-  <ion-card *ngFor="let survey of filteredSurveys">
-    <ion-card-header>
-      <ion-card-title>问卷通知</ion-card-title>
-      <ion-card-title>{{ survey.title }}</ion-card-title>
-    </ion-card-header>
-    <ion-card-content>
-      <p>链接: <a [href]="survey.link" target="_blank">{{ survey.link }}</a></p>
-    </ion-card-content>
-  </ion-card>
-</section>
-
-  <div  style="display: flex; justify-content: center; margin-top: auto;">
-    <ion-button (click)="goPublishSurvey()" expand="full">
-      发布问卷
-    </ion-button>
-  </div>
-
-
-</ion-content>

+ 0 - 35
.history/soul-app/src/app/page-psysurvey/page-psysurvey.component_20241224003220.html

@@ -1,35 +0,0 @@
-<ion-header>
-  <ion-toolbar>
-    <div class="toolbar-content">
-      <div class="button-container">
-        <ion-button (click)="goTab1()" 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 [fullscreen]="true">
-<section *ngIf="filteredSurveys.length > 0">
-  <ion-card *ngFor="let survey of filteredSurveys">
-    <ion-card-header>
-      <ion-card-title>{{ survey.title }}</ion-card-title>
-    </ion-card-header>
-    <ion-card-content>
-      <p>链接: <a [href]="survey.link" target="_blank">{{ survey.link }}</a></p>
-    </ion-card-content>
-  </ion-card>
-</section>
-
-  <div  style="display: flex; justify-content: center; margin-top: auto;">
-    <ion-button (click)="goPublishSurvey()" expand="full">
-      发布问卷
-    </ion-button>
-  </div>
-
-
-</ion-content>

+ 2 - 2
soul-app/src/app/page-psysurvey/page-psysurvey.component.html

@@ -17,10 +17,10 @@
 <section *ngIf="filteredSurveys.length > 0">
   <ion-card *ngFor="let survey of filteredSurveys">
     <ion-card-header>
-      <ion-card-title>{{ survey.title }}</ion-card-title>
+      <ion-card-title>{{ survey.get('title') }}</ion-card-title>
     </ion-card-header>
     <ion-card-content>
-      <p>链接: <a [href]="survey.link" target="_blank">{{ survey.link }}</a></p>
+      <p>链接: <a [href]="survey.get('link')" target="_blank">{{ survey.get('link') }}</a></p>
     </ion-card-content>
   </ion-card>
 </section>

+ 8 - 17
soul-app/src/app/page-psysurvey/page-psysurvey.component.ts

@@ -6,6 +6,7 @@ import { IonHeader,IonButton, IonContent, IonIcon, IonItem, IonLabel, IonList,
   import { HttpClient } from '@angular/common/http';
   import { UserService } from '../user.service'; // 确保路径正确
   import { FormsModule } from '@angular/forms'; // 导入 FormsModule
+import { CloudQuery } from 'src/lib/ncloud';
 
 
   
@@ -37,29 +38,19 @@ export class PagePsysurveyComponent  implements OnInit {
 
    ngOnInit() {
     // 动态获取当前用户的学院信息
-    this.userService.getCurrentUser().subscribe(user => {
-      this.userApartment = user.apartment; // 从用户数据中获取学院
+    let user = this.userService.getCurrentUser()
+      this.userApartment = user.get("apartment"); // 从用户数据中获取学院
       this.getSurveys(); // 在获取到用户信息后获取问卷
-    }, error => {
-      console.error('获取用户信息时出错:', error);
-      // 可以设置一个默认值或处理错误
-    });
   }
 
-  getSurveys() {
-    this.http.get('http://127.0.0.1:4040/').subscribe(
-      (response: any) => {
-        this.surveys = response; // 假设响应是问卷数组
-        this.filterSurveys(); // 过滤问卷
-      },
-      error => {
-        console.error('获取问卷时出错:', error);
-      }
-    );
+  async getSurveys() {
+      let query = new CloudQuery("Survey");
+      this.surveys = await query.find(); // 假设响应是问卷数组
+      this.filterSurveys(); // 过滤问卷
   }
   filterSurveys() {
     this.filteredSurveys = this.surveys.filter(survey => {
-      return survey.audience === this.userApartment || survey.audience === 'all';
+      return survey.get("audience") === this.userApartment || survey.get("audience") === 'all';
     });
   }
   

+ 9 - 9
soul-app/src/app/page-publishsurvey/page-publishsurvey.component.ts

@@ -4,6 +4,7 @@ import { IonHeader,IonButton, IonList, IonListHeader, IonItem,IonContent, IonIco
   import { CommonModule } from '@angular/common';
   import { FormsModule } from '@angular/forms'; // 导入 FormsModule
   import { HttpClient } from '@angular/common/http';
+import { CloudObject } from 'src/lib/ncloud';
 
 
 @Component({
@@ -45,15 +46,14 @@ export class PagePublishsurveyComponent  implements OnInit {
       audience: this.targetAudience,
     };
 
-    this.http.post('http://127.0.0.1:4040/', surveyData).subscribe(
-      response => {
-        console.log('问卷已成功发布:', response);
-        
-      },
-      error => {
-        console.error('发布问卷时出错:', error);
-      }
-    );
+    let survey = new CloudObject("Survey");
+    survey.set(surveyData)
+    survey.save().then(data=>{
+      console.log('问卷已成功发布',data);
+    }).catch(err=>{
+      console.error('发布问卷时出错');
+    })
+
   }
 
   publishSocietySurvey() {

+ 2 - 1
soul-app/src/app/user-evaluate/user-evaluate.component.ts

@@ -3,7 +3,8 @@ import { ModalController } from '@ionic/angular/standalone';
 import { IonButton, IonCard, IonCardContent, IonCardHeader, IonCardSubtitle, IonCardTitle, 
   IonContent, IonHeader, IonInput, IonItem, IonLabel, IonSegment, IonSegmentButton,
    IonTitle, IonToolbar } from '@ionic/angular/standalone';
-import { CloudEvaluate, CloudUser } from 'src/lib/ncloud';
+import { CloudUser } from 'src/lib/ncloud';
+import { CloudEvaluate } from 'src/lib/cloud.evaluate';
 
 @Component({
   selector: 'app-user-evaluate',

+ 6 - 7
soul-app/src/app/user.service.ts

@@ -1,17 +1,16 @@
 import { Injectable } from '@angular/core';
-import { HttpClient } from '@angular/common/http';
-import { Observable } from 'rxjs';
-
+import { CloudUser } from 'src/lib/ncloud';
+import { Observable } from "rxjs"
 @Injectable({
   providedIn: 'root'
 })
 export class UserService {
-  private apiUrl = 'http://127.0.0.1:4040/apps/DevServer/browser/survey'; // 替换为你的 API URL
 
-  constructor(private http: HttpClient) {}
+  constructor() {}
 
   // 获取当前用户信息
-  getCurrentUser(): Observable<any> {
-    return this.http.get(`${this.apiUrl}/current-user`); // 假设这个 API 返回当前用户的信息
+  getCurrentUser(): CloudUser {
+    let user = new CloudUser()
+    return user
   }
 }

+ 52 - 0
soul-app/src/lib/cloud.evaluate.ts

@@ -0,0 +1,52 @@
+import { CloudObject, CloudUser } from './ncloud';
+
+// CloudEvaluate.ts
+export class CloudEvaluate extends CloudObject {
+    userData: Record<string, any>;
+    currentUser: CloudUser; // 添加当前用户的引用
+    modalCtrl: any; // 假设 modalCtrl 是通过构造函数传入的
+
+    constructor(userData: Record<string, any>, currentUser: CloudUser,modalCtrl: any) {
+        super("_ChatEvaluate"); 
+        this.userData = userData; // 保存用户评价数据
+        this.currentUser = currentUser; // 保存当前用户
+        this.modalCtrl = modalCtrl; // 保存模态控制器
+    }
+
+    /** 保存评价 */
+    override async save() {
+        // 确保 rating 是数字类型
+        if (this.userData['rating']) {
+            this.userData['rating'] = Number(this.userData['rating']);
+        }
+        console.log('保存评价被调用'); // 调试日志
+
+        // 调用后端 API 保存评价
+        const response = await fetch(`http://dev.fmode.cn:1337/parse/classes/ChatEvaluate`, {
+            headers: {
+                "x-parse-application-id": "dev",
+                "Content-Type": "application/json"
+            },
+            body: JSON.stringify({
+                content: this.userData['content'],
+                rating: this.userData['rating'],
+                avatar: this.currentUser.data?.['avatar'], // 假设用户头像存储在 data.avatar 中
+                user: { __type: "Pointer", className: "_User", objectId: this.currentUser.id } // 添加用户指针
+            }),
+            method: "POST"
+        });
+
+        const result = await response.json();
+        console.log('保存结果:', result); // 输出保存结果
+
+        if (result?.error) {
+            console.error(result?.error);
+            console.error('评价保存失败');
+            return null;
+        }
+
+        console.log('评价保存成功:', result);
+        this.modalCtrl.dismiss(result, "confirm"); // 关闭模态框并传递结果
+        return result; // 返回保存的结果
+    }
+}

+ 102 - 107
soul-app/src/lib/ncloud.ts

@@ -1,10 +1,10 @@
 // CloudObject.ts
 export class CloudObject {
-    id: string | null = null; // 编号
-    className: string; // 名称
+    className: string;
+    id: string | null = null;
     createdAt:any;
     updatedAt:any;
-    data: Record<string, any> = {}; // 属性、内容
+    data: Record<string, any> = {};
 
     constructor(className: string) {
         this.className = className;
@@ -29,7 +29,7 @@ export class CloudObject {
 
     async save() {
         let method = "POST";
-        let url = `http://dev.fmode.cn:1337/parse/classes/${this.className}`;
+        let url = `https://dev.fmode.cn/parse/classes/${this.className}`;
 
         // 更新
         if (this.id) {
@@ -61,7 +61,7 @@ export class CloudObject {
 
     async destroy() {
         if (!this.id) return;
-        const response = await fetch(`http://dev.fmode.cn:1337/parse/classes/${this.className}/${this.id}`, {
+        const response = await fetch(`https://dev.fmode.cn/parse/classes/${this.className}/${this.id}`, {
             headers: {
                 "x-parse-application-id": "dev"
             },
@@ -88,7 +88,6 @@ export class CloudQuery {
         this.className = className;
     }
 
-    // 作用是将查询参数转换为对象
     include(...fileds:string[]) {
         this.queryParams["include"] = fileds;
     }
@@ -113,11 +112,12 @@ export class CloudQuery {
     }
 
     equalTo(key: string, value: any) {
+        if (!this.queryParams["where"]) this.queryParams["where"] = {};
         this.queryParams["where"][key] = value;
     }
 
     async get(id: string) {
-        const url = `http://dev.fmode.cn:1337/parse/classes/${this.className}/${id}?`;
+        const url = `https://dev.fmode.cn/parse/classes/${this.className}/${id}?`;
 
         const response = await fetch(url, {
             headers: {
@@ -131,34 +131,31 @@ export class CloudQuery {
         });
 
         const json = await response?.json();
-        // return json || {};
-        const exists = json?.results?.[0] || null;
-        if (exists) {
-            let existsObject = this.dataToObj(exists)
+        if (json) {
+            let existsObject = this.dataToObj(json)
             return existsObject;
         }
         return null
-
     }
 
-    async find() {
-        let url = `http://dev.fmode.cn:1337/parse/classes/${this.className}?`;
+    async find():Promise<Array<CloudObject>> {
+        let url = `https://dev.fmode.cn/parse/classes/${this.className}?`;
 
         let queryStr = ``
         Object.keys(this.queryParams).forEach(key=>{
-            let paramStr = JSON.stringify(this.queryParams[key]); // 作用是将对象转换为JSON字符串
+            let paramStr = JSON.stringify(this.queryParams[key]);
             if(key=="include"){
                 paramStr = this.queryParams[key]?.join(",")
             }
-            if(key=="where"){
-                paramStr = JSON.stringify(this.queryParams[key]);
-            }
             if(queryStr) {
                 url += `${key}=${paramStr}`;
             }else{
                 url += `&${key}=${paramStr}`;
             }
         })
+        // if (Object.keys(this.queryParams["where"]).length) {
+            
+        // }
 
         const response = await fetch(url, {
             headers: {
@@ -179,7 +176,7 @@ export class CloudQuery {
 
 
     async first() {
-        let url = `http://dev.fmode.cn:1337/parse/classes/${this.className}?`;
+        let url = `https://dev.fmode.cn/parse/classes/${this.className}?`;
 
         if (Object.keys(this.queryParams["where"]).length) {
             const whereStr = JSON.stringify(this.queryParams["where"]);
@@ -199,14 +196,11 @@ export class CloudQuery {
 
         const json = await response?.json();
         const exists = json?.results?.[0] || null;
-         if (exists) {
-             let existsObject = this.dataToObj(exists)
-             return existsObject;
-         }
-         return null
-        //let list = json?.results || []
-        //let objList = list.map((item:any)=>this.dataToObj(item))
-        //return objList || [];
+        if (exists) {
+            let existsObject = this.dataToObj(exists)
+            return existsObject;
+        }
+        return null
     }
 
     dataToObj(exists:any):CloudObject{
@@ -242,11 +236,25 @@ export class CloudUser extends CloudObject {
             return null;
         }
         return this;
+        // const response = await fetch(`https://dev.fmode.cn/parse/users/me`, {
+        //     headers: {
+        //         "x-parse-application-id": "dev",
+        //         "x-parse-session-token": this.sessionToken // 使用sessionToken进行身份验证
+        //     },
+        //     method: "GET"
+        // });
+
+        // const result = await response?.json();
+        // if (result?.error) {
+        //     console.error(result?.error);
+        //     return null;
+        // }
+        // return result;
     }
 
     /** 登录 */
     async login(username: string, password: string):Promise<CloudUser|null> {
-        const response = await fetch(`http://dev.fmode.cn:1337/parse/login`, {
+        const response = await fetch(`https://dev.fmode.cn/parse/login`, {
             headers: {
                 "x-parse-application-id": "dev",
                 "Content-Type": "application/json"
@@ -255,10 +263,9 @@ export class CloudUser extends CloudObject {
             method: "POST"
         });
 
-        const result = await response.json();
-        console.log("响应状态:", response.status, "响应数据:", result); // 打印响应状态和数据
-        if (result?.error||response.status !== 200) {//检查响应状态
-            console.error(result?.error|| '登录请求失败');
+        const result = await response?.json();
+        if (result?.error) {
+            console.error(result?.error);
             return null;
         }
         
@@ -272,15 +279,52 @@ export class CloudUser extends CloudObject {
         return this;
     }
 
+    /** 登出 */
+    async logout() {
+        if (!this.sessionToken) {
+            console.error("用户未登录");
+            return;
+        }
+
+        const response = await fetch(`https://dev.fmode.cn/parse/logout`, {
+            headers: {
+                "x-parse-application-id": "dev",
+                "x-parse-session-token": this.sessionToken
+            },
+            method: "POST"
+        });
+
+        let result = await response?.json();
+
+        if (result?.error) {
+            console.error(result?.error);
+            if(result?.error=="Invalid session token"){
+                this.clearUserCache()
+                return true;
+            }
+            return false;
+        }
+
+        this.clearUserCache()
+        return true;
+    }
+    clearUserCache(){
+        // 清除用户信息
+        localStorage.removeItem("NCloud/dev/User")
+        this.id = null;
+        this.sessionToken = null;
+        this.data = {};
+    }
+
     /** 注册 */
     async signUp(username: string, password: string, additionalData: Record<string, any> = {}) {
         const userData = {
             username,
-            password,   
+            password,
             ...additionalData // 合并额外的用户数据
         };
 
-        const response = await fetch(`http://dev.fmode.cn:1337/parse/users`, {
+        const response = await fetch(`https://dev.fmode.cn/parse/users`, {
             headers: {
                 "x-parse-application-id": "dev",
                 "Content-Type": "application/json"
@@ -296,45 +340,18 @@ export class CloudUser extends CloudObject {
         }
 
         // 设置用户信息
+        // 缓存用户信息
+        console.log(result)
+        localStorage.setItem("NCloud/dev/User",JSON.stringify(result))
         this.id = result?.objectId;
         this.sessionToken = result?.sessionToken;
         this.data = result; // 保存用户数据
         return this;
     }
-    
-    /** 登出 */
-    async logout() {
-
-        if (!this.sessionToken) {
-            console.error("用户未登录");
-            return;
-        }
-
-        const response = await fetch(`http://dev.fmode.cn:1337/parse/logout`, {
-            headers: {
-                "x-parse-application-id": "dev",
-                "x-parse-session-token": this.sessionToken
-            },
-            method: "POST"
-        });
-
-        const result = await response?.json();
-        if (result?.error) {
-            console.error(result?.error);
-            return false;
-        }
-
-        // 清除用户信息
-        localStorage.removeItem("NCloud/dev/User")
-        this.id = null;
-        this.sessionToken = null;
-        this.data = {};
-        return true;
-    }
 
     override async save() {
         let method = "POST";
-        let url = `http://dev.fmode.cn:1337/parse/users`;
+        let url = `https://dev.fmode.cn/parse/users`;
     
         // 更新用户信息
         if (this.id) {
@@ -373,53 +390,31 @@ export class CloudUser extends CloudObject {
     }
 }
 
-// CloudEvaluate.ts
-export class CloudEvaluate extends CloudObject {
-    userData: Record<string, any>;
-    currentUser: CloudUser; // 添加当前用户的引用
-    modalCtrl: any; // 假设 modalCtrl 是通过构造函数传入的
-
-    constructor(userData: Record<string, any>, currentUser: CloudUser,modalCtrl: any) {
-        super("_ChatEvaluate"); 
-        this.userData = userData; // 保存用户评价数据
-        this.currentUser = currentUser; // 保存当前用户
-        this.modalCtrl = modalCtrl; // 保存模态控制器
-    }
-
-    /** 保存评价 */
-    override async save() {
-        // 确保 rating 是数字类型
-        if (this.userData['rating']) {
-            this.userData['rating'] = Number(this.userData['rating']);
-        }
-        console.log('保存评价被调用'); // 调试日志
+export class CloudApi{
+    async fetch(path:string,body:any,options?:{
+        method:string
+        body:any
+    }){
 
-        // 调用后端 API 保存评价
-        const response = await fetch(`http://dev.fmode.cn:1337/parse/classes/ChatEvaluate`, {
+        let reqOpts:any =  {
             headers: {
                 "x-parse-application-id": "dev",
                 "Content-Type": "application/json"
             },
-            body: JSON.stringify({
-                content: this.userData['content'],
-                rating: this.userData['rating'],
-                avatar: this.currentUser.data?.['avatar'], // 假设用户头像存储在 data.avatar 中
-                user: { __type: "Pointer", className: "_User", objectId: this.currentUser.id } // 添加用户指针
-            }),
-            method: "POST"
-        });
-
-        const result = await response.json();
-        console.log('保存结果:', result); // 输出保存结果
-
-        if (result?.error) {
-            console.error(result?.error);
-            console.error('评价保存失败');
-            return null;
+            method: options?.method || "POST",
+            mode: "cors",
+            credentials: "omit"
         }
-
-        console.log('评价保存成功:', result);
-        this.modalCtrl.dismiss(result, "confirm"); // 关闭模态框并传递结果
-        return result; // 返回保存的结果
+        if(body||options?.body){
+            reqOpts.body = JSON.stringify(body || options?.body);
+            reqOpts.json = true;
+        }
+        let host = `https://dev.fmode.cn`
+        // host = `http://127.0.0.1:1337`
+        let url = `${host}/api/`+path
+        console.log(url,reqOpts)
+        const response = await fetch(url,reqOpts);
+        let json = await response.json();
+        return json
     }
 }