diff --git a/src/app/app.module.ts b/src/app/app.module.ts index c2e9128..c67e870 100644 --- a/src/app/app.module.ts +++ b/src/app/app.module.ts @@ -48,6 +48,8 @@ import {WebSocketService} from './websocket'; import { ChartTypeOfLoansComponent } from './chart-type-of-loans/chart-type-of-loans.component'; import { ChartAmountOfLoansComponent } from './chart-amount-of-loans/chart-amount-of-loans.component'; import { ChartPastYearMonthlyPerformanceComponent } from './chart-past-year-monthly-performance/chart-past-year-monthly-performance.component'; +import { ChartRecentTenLoansComponent } from './chart-recent-ten-loans/chart-recent-ten-loans.component'; +import { ChartTopBrokersComponent } from './chart-top-brokers/chart-top-brokers.component'; @@ -68,7 +70,9 @@ import { ChartPastYearMonthlyPerformanceComponent } from './chart-past-year-mont TransTailsComponent, ChartTypeOfLoansComponent, ChartAmountOfLoansComponent, - ChartPastYearMonthlyPerformanceComponent + ChartPastYearMonthlyPerformanceComponent, + ChartRecentTenLoansComponent, + ChartTopBrokersComponent ], imports: [ BrowserModule, diff --git a/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.html b/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.html new file mode 100644 index 0000000..b590021 --- /dev/null +++ b/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.html @@ -0,0 +1,60 @@ + + + + + + {{ dataItem.Amount | currency }} + + + + + + + {{dataItem.Settlement | date: 'yyyy-MM-dd'}} + + + + + + + + + + + {{ dataItem.Balance | currency }} + + + + + + {{ dataItem.OffsetBalance | currency }} + + + + + + + + + + + + + + + + diff --git a/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.scss b/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.scss new file mode 100644 index 0000000..efc1480 --- /dev/null +++ b/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.scss @@ -0,0 +1,23 @@ +.customer-name { + display: inline-block; + vertical-align: middle; + line-height: 32px; + padding-left: 10px; +} + +.red { + color: #d9534f; +} + +.green { + color: #06580f; +} + + +.text-bold { + font-weight: 600; +} + +.fullheight_grid { + height: calc(100vh - 48px) !important; +} diff --git a/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.spec.ts b/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.spec.ts new file mode 100644 index 0000000..604eb44 --- /dev/null +++ b/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.spec.ts @@ -0,0 +1,25 @@ +import { ComponentFixture, TestBed } from '@angular/core/testing'; + +import { ChartRecentTenLoansComponent } from './chart-recent-ten-loans.component'; + +describe('ChartRecentTenLoansComponent', () => { + let component: ChartRecentTenLoansComponent; + let fixture: ComponentFixture; + + beforeEach(async () => { + await TestBed.configureTestingModule({ + declarations: [ ChartRecentTenLoansComponent ] + }) + .compileComponents(); + }); + + beforeEach(() => { + fixture = TestBed.createComponent(ChartRecentTenLoansComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.ts b/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.ts new file mode 100644 index 0000000..26fdf0a --- /dev/null +++ b/src/app/chart-recent-ten-loans/chart-recent-ten-loans.component.ts @@ -0,0 +1,29 @@ +import { Component, OnInit } from '@angular/core'; +import {Observable} from 'rxjs'; +import {Recent10LoansData} from '../models/recent-ten-loans.model'; +import {HttpClient} from '@angular/common/http'; +import {AuthService} from '../service/auth.service'; +import {map} from 'rxjs/operators'; + +@Component({ + selector: 'app-chart-recent-ten-loans', + templateUrl: './chart-recent-ten-loans.component.html', + styleUrls: ['./chart-recent-ten-loans.component.scss'] +}) +export class ChartRecentTenLoansComponent implements OnInit { + + gridData: Observable; + constructor(private http: HttpClient, private auth: AuthService) { } + + ngOnInit(): void { + this.gridData = this.http.get(this.auth.getUrl('chart/recent-10-loans')).pipe(map( + data => { + data.forEach((value, index) => { + const strPercentage = (100 * value.OffsetBalance / value.Balance).toFixed(1); + value.Percentage = parseFloat(strPercentage); + }); + return data; + } + )); + } +} diff --git a/src/app/chart-top-brokers/chart-top-brokers.component.html b/src/app/chart-top-brokers/chart-top-brokers.component.html new file mode 100644 index 0000000..0d01813 --- /dev/null +++ b/src/app/chart-top-brokers/chart-top-brokers.component.html @@ -0,0 +1,26 @@ + + + + + +
+
{{ dataItem.First }} , {{ dataItem.Last }}
+
+
+ + + + + + + + + {{ dataItem.TotalReward | currency }} + + + + + {{ dataItem.TotalLoanValue | currency }} + + +
diff --git a/src/app/chart-top-brokers/chart-top-brokers.component.scss b/src/app/chart-top-brokers/chart-top-brokers.component.scss new file mode 100644 index 0000000..54cb6d6 --- /dev/null +++ b/src/app/chart-top-brokers/chart-top-brokers.component.scss @@ -0,0 +1,31 @@ +.customer-photo { + display: inline-block; + width: 32px; + height: 32px; + border-radius: 50%; + background-size: 32px 35px; + background-position: center center; + vertical-align: middle; + line-height: 32px; + box-shadow: inset 0 0 1px #999, inset 0 0 10px rgba(0,0,0,.2); + margin-left: 5px; +} + +.customer-name { + display: inline-block; + vertical-align: middle; + line-height: 32px; + padding-left: 10px; +} + +.red { + color: #d9534f; +} + +.text-bold { + font-weight: 600; +} + +.fullheight_grid { + height: calc(100vh - 48px) !important; +} diff --git a/src/app/chart-top-brokers/chart-top-brokers.component.spec.ts b/src/app/chart-top-brokers/chart-top-brokers.component.spec.ts new file mode 100644 index 0000000..100e332 --- /dev/null +++ b/src/app/chart-top-brokers/chart-top-brokers.component.spec.ts @@ -0,0 +1,25 @@ +import { ComponentFixture, TestBed } from '@angular/core/testing'; + +import { ChartTopBrokersComponent } from './chart-top-brokers.component'; + +describe('ChartTopBrokersComponent', () => { + let component: ChartTopBrokersComponent; + let fixture: ComponentFixture; + + beforeEach(async () => { + await TestBed.configureTestingModule({ + declarations: [ ChartTopBrokersComponent ] + }) + .compileComponents(); + }); + + beforeEach(() => { + fixture = TestBed.createComponent(ChartTopBrokersComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/src/app/chart-top-brokers/chart-top-brokers.component.ts b/src/app/chart-top-brokers/chart-top-brokers.component.ts new file mode 100644 index 0000000..660aafe --- /dev/null +++ b/src/app/chart-top-brokers/chart-top-brokers.component.ts @@ -0,0 +1,24 @@ +import { Component, OnInit } from '@angular/core'; +import {Observable} from 'rxjs'; +import {TopBrokerModel} from '../models/top-broker.model'; +import {HttpClient} from '@angular/common/http'; +import {AuthService} from '../service/auth.service'; + +@Component({ + selector: 'app-chart-top-brokers', + templateUrl: './chart-top-brokers.component.html', + styleUrls: ['./chart-top-brokers.component.scss'] +}) +export class ChartTopBrokersComponent implements OnInit { + + gridData: Observable; + constructor(private http: HttpClient, private auth: AuthService) { } + + ngOnInit(): void { + this.gridData = this.http.get(this.auth.getUrl('chart/top-broker')); + } + + private photoURL(dataItem: any): string { + return "url('')"; + } +} diff --git a/src/app/dashboard/dashboard.component.html b/src/app/dashboard/dashboard.component.html index 8e63ad7..8c0d667 100644 --- a/src/app/dashboard/dashboard.component.html +++ b/src/app/dashboard/dashboard.component.html @@ -26,27 +26,11 @@   Recent - Transactions + Settlement
- - - - - - - - - - - - - - - - - +
@@ -55,23 +39,7 @@
- - - - - - - - - - - - - - - - - +
diff --git a/src/app/models/recent-ten-loans.model.ts b/src/app/models/recent-ten-loans.model.ts new file mode 100644 index 0000000..1fcb29e --- /dev/null +++ b/src/app/models/recent-ten-loans.model.ts @@ -0,0 +1,13 @@ + + +export class Recent10LoansData { + Rank: number; + Id: string; + Amount: number; + Item: string; + Settlement: Date; + Rating: number; + Balance: number; + OffsetBalance: number; + Percentage?:number; +} diff --git a/src/app/models/top-broker.model.ts b/src/app/models/top-broker.model.ts new file mode 100644 index 0000000..5ca64f7 --- /dev/null +++ b/src/app/models/top-broker.model.ts @@ -0,0 +1,15 @@ + + + +export class TopBrokerModel { + Rank: number; + Id: string; + First: string; + Last: string; + + NumOfLoans: number; + NumOfSettledLoans: number; + NumOfUnSettledLoans: number; + TotalReward: number; + TotalLoanValue: number; +}