diff --git a/static/src/app/app.component.html b/static/src/app/app.component.html index 46e1d09..04b8a4f 100644 --- a/static/src/app/app.component.html +++ b/static/src/app/app.component.html @@ -21,25 +21,8 @@
  • Armeeübersicht
  • -
  • + Statistiken
  • Teilnehmer diff --git a/static/src/app/app.component.ts b/static/src/app/app.component.ts index 7dcd522..c033920 100644 --- a/static/src/app/app.component.ts +++ b/static/src/app/app.component.ts @@ -1,9 +1,7 @@ import {Component, Inject, Optional} from '@angular/core'; -import {Route, Router} from '@angular/router'; +import {Router} from '@angular/router'; import {LoginService} from './services/login-service/login-service'; import {AUTH_ENABLED} from './app.tokens'; -import {WarService} from "./services/war-service/war.service"; -import {War} from "./models/model-interfaces"; import {PromotionService} from "./services/promotion-service/promotion.service"; import {AwardingService} from "./services/awarding-service/awarding.service"; import {RouteConfig} from "./app.config"; @@ -15,13 +13,10 @@ import {RouteConfig} from "./app.config"; }) export class AppComponent { - wars: War[] = []; - config = RouteConfig; constructor(@Optional() @Inject(AUTH_ENABLED) public authEnabled, private loginService: LoginService, - private warService: WarService, private promotionService: PromotionService, private awardingService: AwardingService, private router: Router) { @@ -29,9 +24,6 @@ export class AppComponent { ngOnInit() { - this.warService.getAllWars().subscribe((wars) => { - this.wars = wars; - }); if (this.loginService.hasPermission(2)) { const fraction = this.loginService.getCurrentUser().squad.fraction; this.promotionService.checkUnconfirmedPromotions(fraction); diff --git a/static/src/app/app.config.ts b/static/src/app/app.config.ts index 5310c57..d45a62f 100644 --- a/static/src/app/app.config.ts +++ b/static/src/app/app.config.ts @@ -28,7 +28,6 @@ export const RouteConfig = { statsPath: 'stats', userPath: 'users', overviewPath: 'overview', - warPath: 'war', requestAwardPath: 'request-award', requestPromotionPath: 'request-promotion', confirmAwardPath: 'confirm-award', diff --git a/static/src/app/app.module.ts b/static/src/app/app.module.ts index bf66e6c..b7f158b 100644 --- a/static/src/app/app.module.ts +++ b/static/src/app/app.module.ts @@ -5,7 +5,7 @@ import {HttpModule} from '@angular/http'; import {AppComponent} from './app.component'; import {LoginService} from "./services/login-service/login-service"; import {UserStore} from "./services/stores/user.store"; -import {ShowErrorComponent} from './show-error/show-error.component'; +import {ShowErrorComponent} from './common/show-error/show-error.component'; import {APPLICATION_VALIDATORS} from './models/app-validators'; import {appRouting, routingComponents, routingProviders} from './app.routing'; import {AUTH_ENABLED} from './app.tokens'; diff --git a/static/src/app/app.routing.ts b/static/src/app/app.routing.ts index e9b33ad..ed8e247 100644 --- a/static/src/app/app.routing.ts +++ b/static/src/app/app.routing.ts @@ -1,6 +1,6 @@ import {RouterModule, Routes} from "@angular/router"; import {LoginComponent} from "./login/index"; -import {NotFoundComponent} from "./not-found/not-found.component"; +import {NotFoundComponent} from "./common/not-found/not-found.component"; import {LoginGuardAdmin, LoginGuardHL, LoginGuardMT, LoginGuardSQL} from "./login/login.guard"; import {usersRoutes, usersRoutingComponents} from "./users/users.routing"; import {squadsRoutes, squadsRoutingComponents} from "./squads/squads.routing"; @@ -13,17 +13,15 @@ import {RequestAwardComponent} from "./request/award/req-award.component"; import {RequestPromotionComponent} from "./request/promotion/req-promotion.component"; import {ConfirmPromotionComponent} from "./request/confirm-promotion/confirm-promotion.component"; import {ConfirmAwardComponent} from "./request/confirm-award/confirm-award.component"; -import {warRoutes, warsRoutingComponents} from "./wars/wars.routing"; -import {StatisticComponent} from "./statistic/statistic.component"; import {RouteConfig} from "./app.config"; +import {statsRoutes, statsRoutingComponents} from "./statistic/stats.routing"; export const appRoutes: Routes = [ {path: RouteConfig.overviewPath, children: armyRoutes}, {path: '', redirectTo: RouteConfig.overviewPath, pathMatch: 'full'}, - {path: RouteConfig.warPath, children: warRoutes}, - {path: RouteConfig.statsPath, component: StatisticComponent}, + {path: RouteConfig.statsPath, children: statsRoutes}, {path: RouteConfig.loginPath, component: LoginComponent}, {path: RouteConfig.signUpPath, component: SignupComponent}, @@ -48,7 +46,7 @@ export const appRoutes: Routes = [ export const appRouting = RouterModule.forRoot(appRoutes); export const routingComponents = [LoginComponent, SignupComponent, RequestAwardComponent, RequestPromotionComponent, ConfirmAwardComponent, - ConfirmPromotionComponent, StatisticComponent, AdminComponent, ...armyRoutingComponents, NotFoundComponent, ...usersRoutingComponents, - ...squadsRoutingComponents, ...decorationsRoutingComponents, ...ranksRoutingComponents, ...warsRoutingComponents]; + ConfirmPromotionComponent, AdminComponent, ...armyRoutingComponents, NotFoundComponent, ...usersRoutingComponents, + ...squadsRoutingComponents, ...decorationsRoutingComponents, ...ranksRoutingComponents, ...statsRoutingComponents]; export const routingProviders = [LoginGuardSQL, LoginGuardHL, LoginGuardMT, LoginGuardAdmin]; diff --git a/static/src/app/not-found/index.ts b/static/src/app/common/not-found/index.ts similarity index 100% rename from static/src/app/not-found/index.ts rename to static/src/app/common/not-found/index.ts diff --git a/static/src/app/not-found/not-found.component.css b/static/src/app/common/not-found/not-found.component.css similarity index 100% rename from static/src/app/not-found/not-found.component.css rename to static/src/app/common/not-found/not-found.component.css diff --git a/static/src/app/not-found/not-found.component.html b/static/src/app/common/not-found/not-found.component.html similarity index 100% rename from static/src/app/not-found/not-found.component.html rename to static/src/app/common/not-found/not-found.component.html diff --git a/static/src/app/not-found/not-found.component.ts b/static/src/app/common/not-found/not-found.component.ts similarity index 100% rename from static/src/app/not-found/not-found.component.ts rename to static/src/app/common/not-found/not-found.component.ts diff --git a/static/src/app/show-error/show-error.component.ts b/static/src/app/common/show-error/show-error.component.ts similarity index 100% rename from static/src/app/show-error/show-error.component.ts rename to static/src/app/common/show-error/show-error.component.ts diff --git a/static/src/app/statistic/statistic.component.css b/static/src/app/statistic/overview/stats-overview.component.css similarity index 60% rename from static/src/app/statistic/statistic.component.css rename to static/src/app/statistic/overview/stats-overview.component.css index 4f5d11d..68d4fa9 100644 --- a/static/src/app/statistic/statistic.component.css +++ b/static/src/app/statistic/overview/stats-overview.component.css @@ -1,9 +1,9 @@ h3 { width: 920px; - margin-left: 25%; + margin-left: 5%; } .chart-container { width: 1200px; - margin-left: 25%; + margin-left: 5%; } diff --git a/static/src/app/statistic/statistic.component.html b/static/src/app/statistic/overview/stats-overview.component.html similarity index 100% rename from static/src/app/statistic/statistic.component.html rename to static/src/app/statistic/overview/stats-overview.component.html diff --git a/static/src/app/statistic/statistic.component.ts b/static/src/app/statistic/overview/stats-overview.component.ts similarity index 73% rename from static/src/app/statistic/statistic.component.ts rename to static/src/app/statistic/overview/stats-overview.component.ts index ae3d3a6..a762ee0 100644 --- a/static/src/app/statistic/statistic.component.ts +++ b/static/src/app/statistic/overview/stats-overview.component.ts @@ -1,14 +1,13 @@ import {Component} from "@angular/core"; -import {AppComponent} from "../app.component"; -import {WarService} from "../services/war-service/war.service"; +import {WarService} from "../../services/war-service/war.service"; @Component({ - selector: 'statistic', - templateUrl: './statistic.component.html', - styleUrls: ['./statistic.component.css'] + selector: 'stats-overview', + templateUrl: './stats-overview.component.html', + styleUrls: ['./stats-overview.component.css'] }) -export class StatisticComponent { +export class StatisticOverviewComponent { pointData: any[] = []; playerData: any[] = []; @@ -17,18 +16,13 @@ export class StatisticComponent { domain: ['#0000FF', '#B22222'] }; - constructor(private appComponent: AppComponent, - private warService: WarService) { + constructor(private warService: WarService) { } ngOnInit() { - let wars = this.appComponent.wars; - if (wars.length === 0) { - this.warService.getAllWars().subscribe(items => { - this.initChart(items); - }) - } - this.initChart(wars); + this.warService.getAllWars().subscribe(items => { + this.initChart(items); + }) } initChart(wars: any[]) { diff --git a/static/src/app/statistic/stats.component.css b/static/src/app/statistic/stats.component.css new file mode 100644 index 0000000..d9e6a0b --- /dev/null +++ b/static/src/app/statistic/stats.component.css @@ -0,0 +1,9 @@ +#left { + width: 320px; + float: left; + padding-right: 10px; +} + +#right { + overflow: hidden +} diff --git a/static/src/app/statistic/stats.component.html b/static/src/app/statistic/stats.component.html new file mode 100644 index 0000000..0680b43 --- /dev/null +++ b/static/src/app/statistic/stats.component.html @@ -0,0 +1 @@ + diff --git a/static/src/app/statistic/stats.component.ts b/static/src/app/statistic/stats.component.ts new file mode 100644 index 0000000..b571159 --- /dev/null +++ b/static/src/app/statistic/stats.component.ts @@ -0,0 +1,11 @@ +import {Component} from "@angular/core"; + +@Component({ + selector: 'stats', + templateUrl: './stats.component.html', + styleUrls: ['./stats.component.css'] +}) +export class StatisticComponent { + constructor() { + } +} diff --git a/static/src/app/statistic/stats.routing.ts b/static/src/app/statistic/stats.routing.ts new file mode 100644 index 0000000..53d09dc --- /dev/null +++ b/static/src/app/statistic/stats.routing.ts @@ -0,0 +1,37 @@ +import {Routes} from "@angular/router"; +import {StatisticComponent} from "./stats.component"; +import {WarDetailComponent} from "./war-detail/war-detail.component"; +import {WarSubmitComponent} from "./war-submit/war-submit.component"; +import {WarListComponent} from "./war-list/war-list.component"; +import {StatisticOverviewComponent} from "./overview/stats-overview.component"; +import {WarItemComponent} from "./war-list/war-item.component"; + + +export const statsRoutes: Routes = [{ + path: '', component: StatisticComponent, + children: [ + { + path: '', + component: WarListComponent + } + ] +}, + { + path: 'overview', + component: StatisticOverviewComponent, + outlet: 'right' + }, + { + path: 'new', + component: WarSubmitComponent, + outlet: 'right' + }, + { + path: 'war/:id', + component: WarDetailComponent, + outlet: 'right' + }]; + +export const statsRoutingComponents = [StatisticComponent, StatisticOverviewComponent, WarListComponent, + WarSubmitComponent, WarDetailComponent, WarItemComponent]; + diff --git a/static/src/app/wars/war-detail.component.css b/static/src/app/statistic/war-detail/war-detail.component.css similarity index 100% rename from static/src/app/wars/war-detail.component.css rename to static/src/app/statistic/war-detail/war-detail.component.css diff --git a/static/src/app/wars/war-detail.component.html b/static/src/app/statistic/war-detail/war-detail.component.html similarity index 93% rename from static/src/app/wars/war-detail.component.html rename to static/src/app/statistic/war-detail/war-detail.component.html index 83759d4..604789f 100644 --- a/static/src/app/wars/war-detail.component.html +++ b/static/src/app/statistic/war-detail/war-detail.component.html @@ -1,6 +1,6 @@
    -
    +

    {{war.title}} - vom {{war.date | date: 'dd.MM.yyyy'}}

    Endpunktestand:

    @@ -26,9 +26,6 @@
    Logfile anzeigen -
    -
    +
    diff --git a/static/src/app/wars/war-detail.component.ts b/static/src/app/statistic/war-detail/war-detail.component.ts similarity index 65% rename from static/src/app/wars/war-detail.component.ts rename to static/src/app/statistic/war-detail/war-detail.component.ts index 6fd9b86..861b7a0 100644 --- a/static/src/app/wars/war-detail.component.ts +++ b/static/src/app/statistic/war-detail/war-detail.component.ts @@ -1,8 +1,8 @@ import {Component} from "@angular/core"; -import {Player, War} from "../models/model-interfaces"; -import {WarService} from "../services/war-service/war.service"; import {ActivatedRoute, Router} from "@angular/router"; -import {LoginService} from "../services/login-service/login-service"; +import {WarService} from "../../services/war-service/war.service"; +import {LoginService} from "../../services/login-service/login-service"; +import {Player, War} from "../../models/model-interfaces"; @Component({ @@ -24,10 +24,8 @@ export class WarDetailComponent { playerChart: any[] = []; - constructor(private router: Router, - private route: ActivatedRoute, - private warService: WarService, - private loginService: LoginService) { + constructor(private route: ActivatedRoute, + private warService: WarService) { Object.assign(this, this.playerChart) } @@ -62,13 +60,4 @@ export class WarDetailComponent { } } - delete() { - if (confirm('Soll die Schlacht "' + this.war.title + '" wirklich gelöscht werden?')) { - this.warService.deleteWar(this.war._id) - .subscribe((res) => { - this.router.navigate(['../..'], {relativeTo: this.route}); - }) - } - } - } diff --git a/static/src/app/statistic/war-list/war-item.component.css b/static/src/app/statistic/war-list/war-item.component.css new file mode 100644 index 0000000..e69de29 diff --git a/static/src/app/statistic/war-list/war-item.component.html b/static/src/app/statistic/war-list/war-item.component.html new file mode 100644 index 0000000..f62c441 --- /dev/null +++ b/static/src/app/statistic/war-list/war-item.component.html @@ -0,0 +1,17 @@ +
    + +
    +
    + + {{war.title}} + +
    + vom {{war.date | date: 'dd.MM.yyyy'}} +
    + +
    + +
    + +
    +
    diff --git a/static/src/app/statistic/war-list/war-item.component.ts b/static/src/app/statistic/war-list/war-item.component.ts new file mode 100644 index 0000000..a475a13 --- /dev/null +++ b/static/src/app/statistic/war-list/war-item.component.ts @@ -0,0 +1,38 @@ +import {ChangeDetectionStrategy, Component, EventEmitter} from "@angular/core"; +import {War} from "../../models/model-interfaces"; +import {LoginService} from "../../services/login-service/login-service"; + +@Component({ + selector: 'pjm-war-item', + templateUrl: './war-item.component.html', + styleUrls: ['./war-item.component.css', '../../style/list-entry.css'], + changeDetection: ChangeDetectionStrategy.OnPush, + inputs: ['war', 'selected'], + outputs: ['warSelected', 'warDelete'] +}) +export class WarItemComponent { + + selected: boolean; + + war: War; + + warSelected = new EventEmitter(); + + warDelete = new EventEmitter(); + + constructor(private loginService: LoginService) { + } + + ngOnInit() { + } + + select() { + this.warSelected.emit(this.war._id) + } + + delete() { + this.warDelete.emit(this.war); + } + +} + diff --git a/static/src/app/statistic/war-list/war-list.component.css b/static/src/app/statistic/war-list/war-list.component.css new file mode 100644 index 0000000..c072fcd --- /dev/null +++ b/static/src/app/statistic/war-list/war-list.component.css @@ -0,0 +1,8 @@ +.search-bar { + padding-top: 20px; + padding-bottom: 20px; +} + +.rank-list { + width: 100%; +} diff --git a/static/src/app/statistic/war-list/war-list.component.html b/static/src/app/statistic/war-list/war-list.component.html new file mode 100644 index 0000000..47bd42f --- /dev/null +++ b/static/src/app/statistic/war-list/war-list.component.html @@ -0,0 +1,24 @@ +
    + + +
    +
    +
    + + Zusammenfassung + +
    +
    +
    + + + +
    diff --git a/static/src/app/statistic/war-list/war-list.component.ts b/static/src/app/statistic/war-list/war-list.component.ts new file mode 100644 index 0000000..a551d8f --- /dev/null +++ b/static/src/app/statistic/war-list/war-list.component.ts @@ -0,0 +1,57 @@ +import {Component, OnInit} from "@angular/core"; +import {ActivatedRoute, Router} from "@angular/router"; +import {War} from "../../models/model-interfaces"; +import {WarService} from "../../services/war-service/war.service"; +import {LoginService} from "../../services/login-service/login-service"; + +@Component({ + selector: 'war-list', + templateUrl: './war-list.component.html', + styleUrls: ['./war-list.component.css', '../../style/list-entry.css'] +}) +export class WarListComponent implements OnInit { + + selectedWarId: string | number = '0'; + + wars: War[] = []; + + constructor(private warService: WarService, + private loginService: LoginService, + private router: Router, + private route: ActivatedRoute) { + } + + ngOnInit() { + this.warService.getAllWars().subscribe((items) => { + this.wars = items; + this.router.navigate([{outlets: {'right': ['overview']}}], {relativeTo: this.route}); + }); + } + + selectNewWar() { + this.selectedWarId = null; + this.router.navigate([{outlets: {'right': ['new']}}], {relativeTo: this.route}); + } + + selectWar(warId: string | number) { + this.selectedWarId = warId; + this.router.navigate([{outlets: {'right': ['war', warId]}}], {relativeTo: this.route}); + } + + selectOverview() { + this.selectedWarId = '0'; + this.router.navigate([{outlets: {'right': ['overview']}}], {relativeTo: this.route}); + } + + deleteWar(war: War) { + if (confirm('Soll die Schlacht ' + war.title + ' wirklich gelöscht werden?')) { + this.warService.deleteWar(war._id) + .subscribe((res) => { + if (this.selectedWarId === war._id) { + this.selectOverview(); + } + this.wars.splice(this.wars.indexOf(war), 1); + }) + } + } +} diff --git a/static/src/app/wars/war-submit.component.css b/static/src/app/statistic/war-submit/war-submit.component.css similarity index 87% rename from static/src/app/wars/war-submit.component.css rename to static/src/app/statistic/war-submit/war-submit.component.css index be57875..dd7472c 100644 --- a/static/src/app/wars/war-submit.component.css +++ b/static/src/app/statistic/war-submit/war-submit.component.css @@ -8,7 +8,7 @@ } .load-arrow { - background: url(../../assets/loading.png) no-repeat; + background: url(../../../assets/loading.png) no-repeat; display: block; width: 120px; height: 120px; diff --git a/static/src/app/wars/war-submit.component.html b/static/src/app/statistic/war-submit/war-submit.component.html similarity index 100% rename from static/src/app/wars/war-submit.component.html rename to static/src/app/statistic/war-submit/war-submit.component.html diff --git a/static/src/app/wars/war-submit.component.ts b/static/src/app/statistic/war-submit/war-submit.component.ts similarity index 93% rename from static/src/app/wars/war-submit.component.ts rename to static/src/app/statistic/war-submit/war-submit.component.ts index 0270c4b..da33ba7 100644 --- a/static/src/app/wars/war-submit.component.ts +++ b/static/src/app/statistic/war-submit/war-submit.component.ts @@ -1,8 +1,8 @@ import {Component, ViewChild} from "@angular/core"; -import {Player, War} from "../models/model-interfaces"; -import {WarService} from "../services/war-service/war.service"; import {ActivatedRoute, Router} from "@angular/router"; import {NgForm} from "@angular/forms"; +import {WarService} from "../../services/war-service/war.service"; +import {War} from "../../models/model-interfaces"; @Component({ diff --git a/static/src/app/wars/wars.routing.ts b/static/src/app/wars/wars.routing.ts deleted file mode 100644 index 70085c8..0000000 --- a/static/src/app/wars/wars.routing.ts +++ /dev/null @@ -1,19 +0,0 @@ -import {Routes} from "@angular/router"; -import {WarSubmitComponent} from "./war-submit.component"; -import {WarDetailComponent} from "./war-detail.component"; -import {LoginGuardMT} from "../login/login.guard"; - - -export const warRoutes: Routes = [ - { - path: '', - component: WarSubmitComponent, - canActivate: [LoginGuardMT] - }, - { - path: ':id', - component: WarDetailComponent, - }]; - -export const warsRoutingComponents = [WarSubmitComponent, WarDetailComponent]; -