aboutsummaryrefslogtreecommitdiff
path: root/ufund-ui/src/app/components/dashboard/dashboard.component.ts
diff options
context:
space:
mode:
authorGunther6070 <haydenhartman10@yahoo.com>2025-04-03 07:56:54 -0400
committerGunther6070 <haydenhartman10@yahoo.com>2025-04-03 07:56:54 -0400
commitcb6463630446503d441b37f3d62ec2d064b00269 (patch)
tree80915dff8eb27bc231c20386a222ccf867ca184e /ufund-ui/src/app/components/dashboard/dashboard.component.ts
parentf8641c164ddc3a0ae4e8e81aa8f5595ce751b17c (diff)
downloadJellySolutions-cb6463630446503d441b37f3d62ec2d064b00269.tar.gz
JellySolutions-cb6463630446503d441b37f3d62ec2d064b00269.tar.bz2
JellySolutions-cb6463630446503d441b37f3d62ec2d064b00269.zip
Added dashboard statistics
Diffstat (limited to '')
-rw-r--r--ufund-ui/src/app/components/dashboard/dashboard.component.ts37
1 files changed, 26 insertions, 11 deletions
diff --git a/ufund-ui/src/app/components/dashboard/dashboard.component.ts b/ufund-ui/src/app/components/dashboard/dashboard.component.ts
index c94b5c6..8c397ff 100644
--- a/ufund-ui/src/app/components/dashboard/dashboard.component.ts
+++ b/ufund-ui/src/app/components/dashboard/dashboard.component.ts
@@ -1,10 +1,10 @@
import {Component, OnInit} from '@angular/core';
import {AuthService} from '../../services/auth.service';
import {Router} from '@angular/router';
-import {Need} from '../../models/Need';
import {CupboardService} from '../../services/cupboard.service';
-import {firstValueFrom} from 'rxjs';
import {UsersService} from '../../services/users.service';
+import {BehaviorSubject} from 'rxjs';
+import {GoalType, Need} from '../../models/Need';
@Component({
selector: 'app-dashboard',
@@ -14,9 +14,10 @@ import {UsersService} from '../../services/users.service';
})
export class DashboardComponent implements OnInit{
- topNeeds?: Need[]
- almostThere?: Need[]
- inBasket?: Need[]
+ protected count = new BehaviorSubject<number | undefined>(undefined)
+ protected totalDonations = new BehaviorSubject<number | undefined>(undefined)
+ protected fulfilledNeeds = new BehaviorSubject<number | undefined>(undefined)
+ protected mostFulfilledNeeds = new BehaviorSubject<Need[] | undefined>(undefined)
constructor(
protected authService: AuthService,
@@ -32,14 +33,28 @@ export class DashboardComponent implements OnInit{
return
}
- firstValueFrom(this.cupboardService.getNeeds()).then(r => {
- this.topNeeds = r.sort((a, b) => b.current - a.current)
- this.almostThere = r.sort((a, b) => a.current/a.maxGoal - b.current/b.maxGoal)
- })
+ this.userService.getCount().subscribe(count => this.count.next(count))
+ this.cupboardService.getNeeds().subscribe(needs => {
+ let fulfilledNeeds = 0
+ let totalValue = 0
+ for (let need of needs) {
+ let needPercent = need.current / need.maxGoal
+ if (needPercent >= 1) {
+ fulfilledNeeds++
+ this.fulfilledNeeds.next(fulfilledNeeds)
+ }
+ if (need.type === GoalType.MONETARY) {
+ totalValue += need.current
+ this.totalDonations.next(totalValue)
+ }
- this.userService.getBasket().subscribe(r => {
- this.inBasket = r;
+ }
+ needs.sort((a, b) => b.current/b.maxGoal - a.current/a.maxGoal)
+ needs = needs.filter(a => a.current != 0)
+ this.mostFulfilledNeeds.next(needs.slice(0, 5))
})
+
+
}
}