diff --git a/angular.json b/angular.json index 242c7ad6..c77718cb 100644 --- a/angular.json +++ b/angular.json @@ -3,9 +3,7 @@ "version": 1, "cli": { "packageManager": "bun", - "schematicCollections": [ - "@angular-eslint/schematics" - ] + "schematicCollections": ["@angular-eslint/schematics"] }, "newProjectRoot": "projects", "projects": { @@ -13,7 +11,32 @@ "projectType": "application", "schematics": { "@schematics/angular:component": { - "style": "scss" + "style": "scss", + "skipTests": true, + "standalone": true + }, + "@schematics/angular:class": { + "skipTests": true + }, + "@schematics/angular:directive": { + "skipTests": true, + "standalone": true + }, + "@schematics/angular:guard": { + "skipTests": true + }, + "@schematics/angular:interceptor": { + "skipTests": true + }, + "@schematics/angular:pipe": { + "skipTests": true, + "standalone": true + }, + "@schematics/angular:resolver": { + "skipTests": true + }, + "@schematics/angular:service": { + "skipTests": true } }, "root": "", @@ -29,20 +52,11 @@ }, "index": "src/index.html", "browser": "src/main.ts", - "polyfills": [ - "zone.js" - ], + "polyfills": ["zone.js"], "tsConfig": "tsconfig.app.json", "inlineStyleLanguage": "scss", - "assets": [ - "src/favicon.ico", - "src/assets", - "src/manifest.webmanifest" - ], - "styles": [ - "./node_modules/@angular/material/prebuilt-themes/indigo-pink.css", - "src/styles.scss" - ], + "assets": ["src/favicon.ico", "src/assets", "src/manifest.webmanifest"], + "styles": ["./node_modules/@angular/material/prebuilt-themes/indigo-pink.css", "src/styles.scss"], "scripts": [] }, "configurations": { @@ -116,10 +130,7 @@ "lint": { "builder": "@angular-eslint/builder:lint", "options": { - "lintFilePatterns": [ - "src/**/*.ts", - "src/**/*.html" - ] + "lintFilePatterns": ["src/**/*.ts", "src/**/*.html"] } } } diff --git a/src/app/admin/admin.component.ts b/src/app/admin/admin.component.ts index a139a9e2..3ec65bad 100644 --- a/src/app/admin/admin.component.ts +++ b/src/app/admin/admin.component.ts @@ -4,9 +4,10 @@ import { LoginService } from './login.service'; import { MatSnackBar } from '@angular/material/snack-bar'; @Component({ - selector: 'app-admin', - templateUrl: './admin.component.html', - styleUrls: ['./admin.component.scss'], + selector: 'app-admin', + templateUrl: './admin.component.html', + styleUrls: ['./admin.component.scss'], + standalone: true, }) export class AdminComponent { constructor(private router: Router, private loginService: LoginService, private _snackBar: MatSnackBar) {} diff --git a/src/app/admin/auth-guard.ts b/src/app/admin/auth-guard.ts index 08be7096..a83ab8f4 100644 --- a/src/app/admin/auth-guard.ts +++ b/src/app/admin/auth-guard.ts @@ -1,16 +1,14 @@ -import { Injectable } from '@angular/core'; -import { Router } from '@angular/router'; +import { inject } from '@angular/core'; +import { CanActivateFn, Router } from '@angular/router'; import { LoginService } from './login.service'; -import { CanActivate } from '@angular/router'; -@Injectable() -export class AuthGuard implements CanActivate { - constructor(private loginService: LoginService, private router: Router) {} - canActivate() { - if (!this.loginService.isLoggedIn()) { - this.router.navigate(['admin']); - return false; - } - return true; +export const authGuard: CanActivateFn = () => { + const loginService = inject(LoginService); + const router = inject(Router); + + if (!loginService.isLoggedIn()) { + router.navigate(['admin']); + return false; } -} + return true; +}; diff --git a/src/app/admin/dialog-template/dialog-template.component.ts b/src/app/admin/dialog-template/dialog-template.component.ts index d4f7f313..66e72547 100644 --- a/src/app/admin/dialog-template/dialog-template.component.ts +++ b/src/app/admin/dialog-template/dialog-template.component.ts @@ -1,5 +1,6 @@ import { Component, Inject } from '@angular/core'; -import { MAT_DIALOG_DATA } from '@angular/material/dialog'; +import { MAT_DIALOG_DATA, MatDialogContent, MatDialogTitle } from '@angular/material/dialog'; +import { CdkScrollable } from '@angular/cdk/scrolling'; export interface DialogData { iterationName: string; @@ -8,9 +9,15 @@ export interface DialogData { } @Component({ - selector: 'app-dialog-template', - templateUrl: './dialog-template.component.html', - styleUrls: ['./dialog-template.component.scss'], + selector: 'app-dialog-template', + templateUrl: './dialog-template.component.html', + styleUrls: ['./dialog-template.component.scss'], + standalone: true, + imports: [ + CdkScrollable, + MatDialogContent, + MatDialogTitle, + ], }) export class DialogTemplateComponent { constructor(@Inject(MAT_DIALOG_DATA) public data: DialogData) {} diff --git a/src/app/admin/info-dialog/info-dialog.component.ts b/src/app/admin/info-dialog/info-dialog.component.ts index 7ec18742..89684797 100644 --- a/src/app/admin/info-dialog/info-dialog.component.ts +++ b/src/app/admin/info-dialog/info-dialog.component.ts @@ -9,9 +9,10 @@ export interface DialogData { } @Component({ - selector: 'app-info-dialog', - templateUrl: './info-dialog.component.html', - styleUrls: ['./info-dialog.component.scss'], + selector: 'app-info-dialog', + templateUrl: './info-dialog.component.html', + styleUrls: ['./info-dialog.component.scss'], + standalone: true, }) export class InfoDialogComponent { constructor(public dialog: MatDialog) {} diff --git a/src/app/admin/info/info.component.ts b/src/app/admin/info/info.component.ts index 011c9658..66387b2e 100644 --- a/src/app/admin/info/info.component.ts +++ b/src/app/admin/info/info.component.ts @@ -4,11 +4,14 @@ import { LoginService } from '../login.service'; import { MatSnackBar } from '@angular/material/snack-bar'; import { InfoDialogComponent } from './../info-dialog/info-dialog.component'; import { PairingService } from '../../game/game-multiplayer/services/pairing.service'; +import { MatButton } from '@angular/material/button'; @Component({ - selector: 'app-info', - templateUrl: './info.component.html', - styleUrls: ['./info.component.scss'], + selector: 'app-info', + templateUrl: './info.component.html', + styleUrls: ['./info.component.scss'], + standalone: true, + imports: [MatButton], }) export class InfoComponent { datasetString = 'Nullstill treningssett til originalen'; diff --git a/src/app/app.component.ts b/src/app/app.component.ts index 23af807a..d5ad8d50 100644 --- a/src/app/app.component.ts +++ b/src/app/app.component.ts @@ -1,64 +1,66 @@ -import { Component, HostListener, OnInit } from '@angular/core'; -import { Subject } from 'rxjs'; -import { Router } from '@angular/router'; -import { MatDialog } from '@angular/material/dialog'; -import { RouterOutlet } from '@angular/router'; - -import { IdleTimeoutComponent } from './idle-timeout/idle-timeout.component'; -import { routeTransitionAnimations } from './route-transition-animations'; -import { environment } from '../environments/environment'; - -@Component({ - selector: 'app-root', - templateUrl: './app.component.html', - styleUrls: ['./app.component.scss'], - animations: [routeTransitionAnimations], -}) -export class AppComponent implements OnInit { - title = 'Teknisk Museum'; - - userActivity = 0; - userInactive = new Subject(); - - isDialogOpen = false; - inactivityTime = environment.inactivityTime; - - constructor(private router: Router, public dialog: MatDialog) {} - - ngOnInit(): void { - this.setDialogTimeout(); - this.userInactive.subscribe(() => { - if (this.router.url !== '/' && this.router.url !== '/admin') { - this.openDialog(); - } - }); - } - - openDialog() { - if (!this.isDialogOpen) { - this.dialog - .open(IdleTimeoutComponent) - .afterClosed() - .subscribe(() => { - this.isDialogOpen = false; - }); - this.isDialogOpen = true; - } - } - - setDialogTimeout() { - this.userActivity = window.setTimeout(() => this.userInactive.next(undefined), this.inactivityTime); - } - - prepareRoute(outlet: RouterOutlet) { - const animationState = 'animationState'; - return outlet && outlet.activatedRouteData && outlet.activatedRouteData[animationState]; - } - - @HostListener('window:mousemove') - @HostListener('document:touchmove') - refreshUserState() { - clearTimeout(this.userActivity); - this.setDialogTimeout(); - } -} +import { Component, HostListener, OnInit } from '@angular/core'; +import { Subject } from 'rxjs'; +import { Router } from '@angular/router'; +import { MatDialog } from '@angular/material/dialog'; +import { RouterOutlet } from '@angular/router'; + +import { IdleTimeoutComponent } from './idle-timeout/idle-timeout.component'; +import { routeTransitionAnimations } from './route-transition-animations'; +import { environment } from '../environments/environment'; + +@Component({ + selector: 'app-root', + templateUrl: './app.component.html', + styleUrls: ['./app.component.scss'], + animations: [routeTransitionAnimations], + standalone: true, + imports: [RouterOutlet], +}) +export class AppComponent implements OnInit { + title = 'Teknisk Museum'; + + userActivity = 0; + userInactive = new Subject(); + + isDialogOpen = false; + inactivityTime = environment.inactivityTime; + + constructor(private router: Router, public dialog: MatDialog) {} + + ngOnInit(): void { + this.setDialogTimeout(); + this.userInactive.subscribe(() => { + if (this.router.url !== '/' && this.router.url !== '/admin') { + this.openDialog(); + } + }); + } + + openDialog() { + if (!this.isDialogOpen) { + this.dialog + .open(IdleTimeoutComponent) + .afterClosed() + .subscribe(() => { + this.isDialogOpen = false; + }); + this.isDialogOpen = true; + } + } + + setDialogTimeout() { + this.userActivity = window.setTimeout(() => this.userInactive.next(undefined), this.inactivityTime); + } + + prepareRoute(outlet: RouterOutlet) { + const animationState = 'animationState'; + return outlet && outlet.activatedRouteData && outlet.activatedRouteData[animationState]; + } + + @HostListener('window:mousemove') + @HostListener('document:touchmove') + refreshUserState() { + clearTimeout(this.userActivity); + this.setDialogTimeout(); + } +} diff --git a/src/app/app.module.ts b/src/app/app.module.ts deleted file mode 100644 index f7ee790a..00000000 --- a/src/app/app.module.ts +++ /dev/null @@ -1,52 +0,0 @@ -import { BrowserModule } from '@angular/platform-browser'; -import { HttpClientModule } from '@angular/common/http'; -import { NgModule } from '@angular/core'; -import { MatDialogModule } from '@angular/material/dialog'; -import { ServiceWorkerModule } from '@angular/service-worker'; -import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; -import { AppRoutingModule } from './app-routing.module'; -import { AppComponent } from './app.component'; -import { WelcomeModule } from './welcome/welcome.module'; -import { GameModule } from './game/game.module'; -import { MultiplayerModule } from '../app/game/game-multiplayer/multiplayer.module'; -import { environment } from '../environments/environment'; -import { MaterialImportsModule } from './shared/material-imports/material-imports.module'; -import { IdleTimeoutComponent } from './idle-timeout/idle-timeout.component'; -import { AdminComponent } from './admin/admin.component'; -import { InfoComponent } from './admin/info/info.component'; -import { MatSnackBarModule } from '@angular/material/snack-bar'; -import { InfoDialogComponent } from './admin/info-dialog/info-dialog.component'; -import { MAT_DIALOG_DATA } from '@angular/material/dialog'; -import { AuthGuard } from './admin/auth-guard'; -import { DialogTemplateComponent } from './admin/dialog-template/dialog-template.component'; -import { CommonModule } from '@angular/common'; - -@NgModule({ - declarations: [ - AppComponent, - AdminComponent, - InfoComponent, - IdleTimeoutComponent, - InfoDialogComponent, - DialogTemplateComponent, - ], - - imports: [ - BrowserModule, - HttpClientModule, - AppRoutingModule, - WelcomeModule, - GameModule, - MultiplayerModule, - ServiceWorkerModule.register('ngsw-worker.js', { enabled: environment.production }), - MatSnackBarModule, - MatDialogModule, - MaterialImportsModule, - BrowserAnimationsModule, - CommonModule, - ], - providers: [HttpClientModule, InfoDialogComponent, AuthGuard, { provide: MAT_DIALOG_DATA, useValue: {} }], - - bootstrap: [AppComponent], -}) -export class AppModule {} diff --git a/src/app/game/game-draw/game-draw.component.ts b/src/app/game/game-draw/game-draw.component.ts index a5053a90..c44a5dc1 100644 --- a/src/app/game/game-draw/game-draw.component.ts +++ b/src/app/game/game-draw/game-draw.component.ts @@ -6,11 +6,21 @@ import { DrawingService } from './services/drawing.service'; import { MultiplayerService, GAMELEVEL } from '../game-multiplayer/services/multiplayer.service'; import { Result } from '../../shared/models/interfaces'; import { SoundService } from './services/sound.service'; +import { NgIf, UpperCasePipe } from '@angular/common'; +import { MatIconButton } from '@angular/material/button'; +import { MatIcon } from '@angular/material/icon'; @Component({ - selector: 'app-drawing', - templateUrl: './game-draw.component.html', - styleUrls: ['./game-draw.component.scss'], + selector: 'app-drawing', + templateUrl: './game-draw.component.html', + styleUrls: ['./game-draw.component.scss'], + standalone: true, + imports: [ + MatIcon, + MatIconButton, + NgIf, + UpperCasePipe, + ], }) export class GameDrawComponent implements OnInit, OnDestroy { canvas = viewChild.required>('canvas'); diff --git a/src/app/game/game-info/game-info.component.ts b/src/app/game/game-info/game-info.component.ts index c729974c..d87e2015 100644 --- a/src/app/game/game-info/game-info.component.ts +++ b/src/app/game/game-info/game-info.component.ts @@ -4,11 +4,20 @@ import { routes } from '../../shared/models/routes'; import { MultiplayerService, GAMELEVEL } from '../game-multiplayer/services/multiplayer.service'; import { WebSocketService } from '../game-multiplayer/services/web-socket.service'; import { SocketEndpoints } from '../../shared/models/websocketEndpoints'; +import { MatButton } from '@angular/material/button'; +import { MatIcon } from '@angular/material/icon'; +import { NgIf } from '@angular/common'; @Component({ - selector: 'app-game-info', - templateUrl: './game-info.component.html', - styleUrls: ['./game-info.component.scss'], + selector: 'app-game-info', + templateUrl: './game-info.component.html', + styleUrls: ['./game-info.component.scss'], + standalone: true, + imports: [ + NgIf, + MatIcon, + MatButton, + ], }) export class GameInfoComponent implements OnInit { @Output() getDrawWord = new EventEmitter(); diff --git a/src/app/game/game-intermediate-result/game-intermediate-result.component.ts b/src/app/game/game-intermediate-result/game-intermediate-result.component.ts index 2cae6947..2c33f302 100644 --- a/src/app/game/game-intermediate-result/game-intermediate-result.component.ts +++ b/src/app/game/game-intermediate-result/game-intermediate-result.component.ts @@ -4,10 +4,20 @@ import { DrawingService } from '../game-draw/services/drawing.service'; import { MultiplayerService, GAMELEVEL } from '../game-multiplayer/services/multiplayer.service'; import { Router } from '@angular/router'; import { routes } from '../../shared/models/routes'; +import { MatProgressSpinner } from '@angular/material/progress-spinner'; +import { MatButton } from '@angular/material/button'; +import { NgIf, UpperCasePipe } from '@angular/common'; @Component({ - selector: 'app-game-intermediate-result', - templateUrl: './game-intermediate-result.component.html', - styleUrls: ['./game-intermediate-result.component.scss'], + selector: 'app-game-intermediate-result', + templateUrl: './game-intermediate-result.component.html', + styleUrls: ['./game-intermediate-result.component.scss'], + standalone: true, + imports: [ + NgIf, + MatButton, + MatProgressSpinner, + UpperCasePipe, + ], }) export class GameIntermediateResultComponent implements OnInit, OnDestroy { result: Result | undefined; diff --git a/src/app/game/game-multiplayer/lobby/lobby.component.ts b/src/app/game/game-multiplayer/lobby/lobby.component.ts index b8381fa5..cdd79808 100644 --- a/src/app/game/game-multiplayer/lobby/lobby.component.ts +++ b/src/app/game/game-multiplayer/lobby/lobby.component.ts @@ -1,11 +1,25 @@ import { Component, OnInit, OnDestroy } from '@angular/core'; import { MultiplayerService } from '../services/multiplayer.service'; import { Subscription } from 'rxjs'; +import { MatButton } from '@angular/material/button'; +import { RouterLink, RouterLinkActive } from '@angular/router'; +import { MatIcon } from '@angular/material/icon'; +import { MatProgressSpinner } from '@angular/material/progress-spinner'; +import { NgIf } from '@angular/common'; @Component({ - selector: 'app-lobby', - templateUrl: './lobby.component.html', - styleUrls: ['./lobby.component.scss'], + selector: 'app-lobby', + templateUrl: './lobby.component.html', + styleUrls: ['./lobby.component.scss'], + standalone: true, + imports: [ + NgIf, + MatProgressSpinner, + MatIcon, + RouterLink, + RouterLinkActive, + MatButton, + ], }) export class LobbyComponent implements OnInit, OnDestroy { waitingForOtherPlayer = true; diff --git a/src/app/game/game-multiplayer/multiplayer.component.ts b/src/app/game/game-multiplayer/multiplayer.component.ts index e11076ca..d6ba69b7 100644 --- a/src/app/game/game-multiplayer/multiplayer.component.ts +++ b/src/app/game/game-multiplayer/multiplayer.component.ts @@ -6,6 +6,13 @@ import { MultiplayerService, GAMELEVEL } from './services/multiplayer.service'; import { WebSocketService } from './services/web-socket.service'; import { routes } from '../../shared/models/routes'; import { Subscription } from 'rxjs'; +import { LobbyComponent } from './lobby/lobby.component'; +import { GameResultComponent } from '../game-result/game-result.component'; +import { GameIntermediateResultComponent } from '../game-intermediate-result/game-intermediate-result.component'; +import { GameDrawComponent } from '../game-draw/game-draw.component'; +import { GameWordToDrawComponent } from '../game-word-to-draw/game-word-to-draw.component'; +import { GameInfoComponent } from '../game-info/game-info.component'; +import { NgSwitch, NgSwitchCase, NgSwitchDefault } from '@angular/common'; @Component({ selector: 'app-multiplayer', @@ -36,6 +43,18 @@ import { Subscription } from 'rxjs'; ]), ]), ], + standalone: true, + imports: [ + NgSwitch, + NgSwitchCase, + GameInfoComponent, + GameWordToDrawComponent, + GameDrawComponent, + GameIntermediateResultComponent, + GameResultComponent, + NgSwitchDefault, + LobbyComponent, + ], }) export class MultiplayerComponent implements OnInit, OnDestroy { gameLevel: string | undefined; diff --git a/src/app/game/game-multiplayer/multiplayer.module.ts b/src/app/game/game-multiplayer/multiplayer.module.ts deleted file mode 100644 index 1c7c7b22..00000000 --- a/src/app/game/game-multiplayer/multiplayer.module.ts +++ /dev/null @@ -1,13 +0,0 @@ -import { NgModule } from '@angular/core'; -import { CommonModule } from '@angular/common'; -import { MaterialImportsModule } from '../../shared/material-imports/material-imports.module'; -import { LobbyComponent } from './lobby/lobby.component'; -import { MultiplayerComponent } from './multiplayer.component'; -import { AppRoutingModule } from '../../app-routing.module'; -import { GameModule } from '../game.module'; - -@NgModule({ - declarations: [LobbyComponent, MultiplayerComponent], - imports: [CommonModule, MaterialImportsModule, AppRoutingModule, GameModule], -}) -export class MultiplayerModule {} diff --git a/src/app/game/game-result/game-result.component.ts b/src/app/game/game-result/game-result.component.ts index 08e2f3de..e21bb1f8 100644 --- a/src/app/game/game-result/game-result.component.ts +++ b/src/app/game/game-result/game-result.component.ts @@ -3,11 +3,22 @@ import { DrawingService } from '../game-draw/services/drawing.service'; import { Result } from '../../shared/models/interfaces'; import { Router } from '@angular/router'; import { MultiplayerService } from '../game-multiplayer/services/multiplayer.service'; +import { MatButton } from '@angular/material/button'; +import { MatCardImage } from '@angular/material/card'; +import { NgIf, NgFor, TitleCasePipe } from '@angular/common'; @Component({ - selector: 'app-game-result', - templateUrl: './game-result.component.html', - styleUrls: ['./game-result.component.scss'], + selector: 'app-game-result', + templateUrl: './game-result.component.html', + styleUrls: ['./game-result.component.scss'], + standalone: true, + imports: [ + NgIf, + NgFor, + MatCardImage, + MatButton, + TitleCasePipe, + ], }) export class GameResultComponent implements OnInit { results: Result[] = []; diff --git a/src/app/game/game-word-to-draw/game-word-to-draw.component.ts b/src/app/game/game-word-to-draw/game-word-to-draw.component.ts index fda2f644..ffc9eb6f 100644 --- a/src/app/game/game-word-to-draw/game-word-to-draw.component.ts +++ b/src/app/game/game-word-to-draw/game-word-to-draw.component.ts @@ -5,11 +5,23 @@ import { DrawingService } from '../game-draw/services/drawing.service'; import { Router } from '@angular/router'; import { routes } from '../../shared/models/routes'; import { MultiplayerService, GAMELEVEL } from '../game-multiplayer/services/multiplayer.service'; +import { MatIcon } from '@angular/material/icon'; +import { MatButton } from '@angular/material/button'; +import { MatProgressSpinner } from '@angular/material/progress-spinner'; +import { NgIf, UpperCasePipe } from '@angular/common'; @Component({ - selector: 'app-game-word-to-draw', - templateUrl: './game-word-to-draw.component.html', - styleUrls: ['./game-word-to-draw.component.scss'], + selector: 'app-game-word-to-draw', + templateUrl: './game-word-to-draw.component.html', + styleUrls: ['./game-word-to-draw.component.scss'], + standalone: true, + imports: [ + NgIf, + MatProgressSpinner, + MatButton, + MatIcon, + UpperCasePipe, + ], }) export class GameWordToDrawComponent implements OnInit, OnDestroy { constructor( diff --git a/src/app/game/game.component.ts b/src/app/game/game.component.ts index 47b3e07b..55b2e843 100644 --- a/src/app/game/game.component.ts +++ b/src/app/game/game.component.ts @@ -2,36 +2,51 @@ import { Component, OnInit, OnDestroy } from '@angular/core'; import { trigger, style, animate, transition } from '@angular/animations'; import { DrawingService } from './game-draw/services/drawing.service'; +import { GameWordToDrawComponent } from './game-word-to-draw/game-word-to-draw.component'; +import { GameResultComponent } from './game-result/game-result.component'; +import { GameIntermediateResultComponent } from './game-intermediate-result/game-intermediate-result.component'; +import { GameDrawComponent } from './game-draw/game-draw.component'; +import { GameInfoComponent } from './game-info/game-info.component'; +import { NgIf } from '@angular/common'; @Component({ - selector: 'app-game', - templateUrl: './game.component.html', - styleUrls: ['./game.component.scss'], - animations: [ - trigger('enterAnimation', [ - transition(':enter', [ - style({ - position: 'absolute', - top: 0, - right: 0, - width: '100%', - height: '100%', - }), - style({ right: '-100%', opacity: 0 }), - animate('.4s ease-out', style({ right: '0%', opacity: 1 })), - ]), - transition(':leave', [ - style({ - position: 'absolute', - top: 0, - right: 0, - width: '100%', - height: '100%', - }), - animate('.4s ease-out', style({ transform: 'translateX(-100%)', opacity: 0 })), - ]), - ]), - ], + selector: 'app-game', + templateUrl: './game.component.html', + styleUrls: ['./game.component.scss'], + animations: [ + trigger('enterAnimation', [ + transition(':enter', [ + style({ + position: 'absolute', + top: 0, + right: 0, + width: '100%', + height: '100%', + }), + style({ right: '-100%', opacity: 0 }), + animate('.4s ease-out', style({ right: '0%', opacity: 1 })), + ]), + transition(':leave', [ + style({ + position: 'absolute', + top: 0, + right: 0, + width: '100%', + height: '100%', + }), + animate('.4s ease-out', style({ transform: 'translateX(-100%)', opacity: 0 })), + ]), + ]), + ], + standalone: true, + imports: [ + NgIf, + GameInfoComponent, + GameDrawComponent, + GameIntermediateResultComponent, + GameResultComponent, + GameWordToDrawComponent, + ], }) export class GameComponent implements OnInit, OnDestroy { newGame = false; diff --git a/src/app/game/game.module.ts b/src/app/game/game.module.ts deleted file mode 100644 index a23be1d9..00000000 --- a/src/app/game/game.module.ts +++ /dev/null @@ -1,28 +0,0 @@ -import { NgModule } from '@angular/core'; -import { CommonModule } from '@angular/common'; -import { GameInfoComponent } from './game-info/game-info.component'; -import { GameDrawComponent } from './game-draw/game-draw.component'; -import { GameComponent } from './game.component'; -import { MaterialImportsModule } from '../shared/material-imports/material-imports.module'; -import { GameIntermediateResultComponent } from './game-intermediate-result/game-intermediate-result.component'; -import { GameResultComponent } from './game-result/game-result.component'; -import { GameWordToDrawComponent } from './game-word-to-draw/game-word-to-draw.component'; -@NgModule({ - declarations: [ - GameInfoComponent, - GameDrawComponent, - GameComponent, - GameIntermediateResultComponent, - GameResultComponent, - GameWordToDrawComponent, - ], - exports: [ - GameInfoComponent, - GameWordToDrawComponent, - GameDrawComponent, - GameIntermediateResultComponent, - GameResultComponent, - ], - imports: [CommonModule, MaterialImportsModule], -}) -export class GameModule {} diff --git a/src/app/idle-timeout/idle-timeout.component.ts b/src/app/idle-timeout/idle-timeout.component.ts index a0584ccf..a148b2a6 100644 --- a/src/app/idle-timeout/idle-timeout.component.ts +++ b/src/app/idle-timeout/idle-timeout.component.ts @@ -1,14 +1,25 @@ import { Component, OnInit, OnDestroy } from '@angular/core'; import { Router } from '@angular/router'; -import { MatDialogRef } from '@angular/material/dialog'; +import { MatDialogRef, MatDialogContent, MatDialogActions } from '@angular/material/dialog'; import { ViewEncapsulation } from '@angular/core'; import { routes } from '../shared/models/routes'; +import { MatIcon } from '@angular/material/icon'; +import { MatButton } from '@angular/material/button'; +import { CdkScrollable } from '@angular/cdk/scrolling'; @Component({ - selector: 'app-idle-timeout', - templateUrl: './idle-timeout.component.html', - styleUrls: ['./idle-timeout.component.scss'], - encapsulation: ViewEncapsulation.None, + selector: 'app-idle-timeout', + templateUrl: './idle-timeout.component.html', + styleUrls: ['./idle-timeout.component.scss'], + encapsulation: ViewEncapsulation.None, + standalone: true, + imports: [ + CdkScrollable, + MatDialogContent, + MatDialogActions, + MatButton, + MatIcon, + ], }) export class IdleTimeoutComponent implements OnInit, OnDestroy { constructor(private router: Router, private dialogRef: MatDialogRef) {} diff --git a/src/app/route-transition-animations.ts b/src/app/route-transition-animations.ts index d438ddd6..0bc2f3f4 100644 --- a/src/app/route-transition-animations.ts +++ b/src/app/route-transition-animations.ts @@ -1,40 +1,40 @@ -import { trigger, transition, style, query, animateChild, group, animate } from '@angular/animations'; - -export const routeTransitionAnimations = trigger('triggerName', [ - transition('welcome => game', [ - style({ position: 'relative' }), - query(':enter, :leave', [ - style({ - position: 'absolute', - top: 0, - right: 0, - width: '100%', - }), - ]), - query(':enter', [style({ right: '-100%', opacity: 0 })]), - query(':leave', animateChild()), - group([ - query(':leave', [animate('0.4s ease-out', style({ right: '100%', opacity: 0 }))]), - query(':enter', [animate('0.4s ease-out', style({ right: '0%', opacity: 1 }))]), - ]), - query(':enter', animateChild()), - ]), - transition('game => welcome, game => game', [ - style({ position: 'relative' }), - query(':enter, :leave', [ - style({ - position: 'absolute', - top: 0, - left: 0, - width: '100%', - }), - ]), - query(':enter', [style({ left: '-100%', opacity: 0 })]), - query(':leave', animateChild()), - group([ - query(':leave', [animate('0.4s ease-out', style({ left: '100%', opacity: 0 }))]), - query(':enter', [animate('0.4s ease-out', style({ left: '0%', opacity: 1 }))]), - ]), - query(':enter', animateChild()), - ]), -]); +import { trigger, transition, style, query, animateChild, group, animate } from '@angular/animations'; + +export const routeTransitionAnimations = trigger('triggerName', [ + transition('welcome => game', [ + style({ position: 'relative' }), + query(':enter, :leave', [ + style({ + position: 'absolute', + top: 0, + right: 0, + width: '100%', + }), + ]), + query(':enter', [style({ right: '-100%', opacity: 0 })]), + query(':leave', animateChild()), + group([ + query(':leave', [animate('0.4s ease-out', style({ right: '100%', opacity: 0 }))]), + query(':enter', [animate('0.4s ease-out', style({ right: '0%', opacity: 1 }))]), + ]), + query(':enter', animateChild()), + ]), + transition('game => welcome, game => game', [ + style({ position: 'relative' }), + query(':enter, :leave', [ + style({ + position: 'absolute', + top: 0, + left: 0, + width: '100%', + }), + ]), + query(':enter', [style({ left: '-100%', opacity: 0 })]), + query(':leave', animateChild()), + group([ + query(':leave', [animate('0.4s ease-out', style({ left: '100%', opacity: 0 }))]), + query(':enter', [animate('0.4s ease-out', style({ left: '0%', opacity: 1 }))]), + ]), + query(':enter', animateChild()), + ]), +]); diff --git a/src/app/app-routing.module.ts b/src/app/routes.ts similarity index 72% rename from src/app/app-routing.module.ts rename to src/app/routes.ts index 6a122def..72b020ee 100644 --- a/src/app/app-routing.module.ts +++ b/src/app/routes.ts @@ -1,55 +1,48 @@ -import { NgModule } from '@angular/core'; -import { Routes, RouterModule } from '@angular/router'; -import { WelcomeComponent } from './welcome/welcome.component'; -import { GameComponent } from './game/game.component'; -import { routes as r } from './shared/models/routes'; -import { GameResultComponent } from './game/game-result/game-result.component'; -import { GameDrawComponent } from './game/game-draw/game-draw.component'; -import { AdminComponent } from './admin/admin.component'; -import { InfoComponent } from './admin/info/info.component'; -import { AuthGuard } from './admin/auth-guard'; -import { MultiplayerComponent } from '../app/game/game-multiplayer/multiplayer.component'; - -const routes: Routes = [ - { - path: r.LANDING, - component: WelcomeComponent, - data: { animationState: 'welcome' }, - }, - { - path: r.SINGLEPLAYER, - component: GameComponent, - data: { animationState: 'game' }, - }, - { - path: r.MULTIPLAYER, - component: MultiplayerComponent, - }, - { - path: 'summary', - component: GameResultComponent, - }, - { - path: 'summary/multiplayer', - component: GameResultComponent, - }, - { - path: 'drawing', - component: GameDrawComponent, - }, - { - path: 'admin', - component: AdminComponent, - }, - { - path: 'admin/info', - component: InfoComponent, - canActivate: [AuthGuard], - }, -]; - -@NgModule({ - imports: [RouterModule.forRoot(routes)], - exports: [RouterModule], -}) -export class AppRoutingModule {} +import { Routes } from '@angular/router'; +import { WelcomeComponent } from './welcome/welcome.component'; +import { GameComponent } from './game/game.component'; +import { routes as r } from './shared/models/routes'; +import { GameResultComponent } from './game/game-result/game-result.component'; +import { GameDrawComponent } from './game/game-draw/game-draw.component'; +import { AdminComponent } from './admin/admin.component'; +import { InfoComponent } from './admin/info/info.component'; +import { authGuard } from './admin/auth-guard'; +import { MultiplayerComponent } from './game/game-multiplayer/multiplayer.component'; + +export const routes: Routes = [ + { + path: r.LANDING, + component: WelcomeComponent, + data: { animationState: 'welcome' }, + }, + { + path: r.SINGLEPLAYER, + component: GameComponent, + data: { animationState: 'game' }, + }, + { + path: r.MULTIPLAYER, + component: MultiplayerComponent, + }, + { + path: 'summary', + component: GameResultComponent, + }, + { + path: 'summary/multiplayer', + component: GameResultComponent, + }, + { + path: 'drawing', + component: GameDrawComponent, + }, + { + path: 'admin', + component: AdminComponent, + }, + { + path: 'admin/info', + component: InfoComponent, + canActivate: [authGuard], + }, +]; diff --git a/src/app/shared/material-imports/material-imports.module.ts b/src/app/shared/material-imports/material-imports.module.ts deleted file mode 100644 index fc139d5c..00000000 --- a/src/app/shared/material-imports/material-imports.module.ts +++ /dev/null @@ -1,33 +0,0 @@ -import { NgModule } from '@angular/core'; -import { CommonModule } from '@angular/common'; - -import { MatButtonModule } from '@angular/material/button'; -import { MatIconModule } from '@angular/material/icon'; -import { MatToolbarModule } from '@angular/material/toolbar'; -import { MatProgressSpinnerModule } from '@angular/material/progress-spinner'; -import { MatSidenavModule } from '@angular/material/sidenav'; -import { MatMenuModule } from '@angular/material/menu'; -import { MatListModule } from '@angular/material/list'; -import { MatCardModule } from '@angular/material/card'; -import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; -import { MatInputModule } from '@angular/material/input'; - -const materialModules = [ - MatButtonModule, - MatIconModule, - MatToolbarModule, - MatProgressSpinnerModule, - MatSidenavModule, - MatListModule, - MatCardModule, - MatMenuModule, - BrowserAnimationsModule, - MatInputModule, -]; - -@NgModule({ - declarations: [], - imports: [CommonModule, ...materialModules], - exports: [...materialModules], -}) -export class MaterialImportsModule {} diff --git a/src/app/welcome/welcome.component.ts b/src/app/welcome/welcome.component.ts index e5deeed1..c32953fe 100644 --- a/src/app/welcome/welcome.component.ts +++ b/src/app/welcome/welcome.component.ts @@ -1,11 +1,20 @@ import { Component, OnInit } from '@angular/core'; import { MultiplayerService } from '../game/game-multiplayer/services/multiplayer.service'; import { DrawingService } from '../game/game-draw/services/drawing.service'; -import { Router } from '@angular/router'; +import { Router, RouterLink, RouterLinkActive } from '@angular/router'; +import { MatIcon } from '@angular/material/icon'; +import { MatButton } from '@angular/material/button'; @Component({ - selector: 'app-welcome', - templateUrl: './welcome.component.html', - styleUrls: ['./welcome.component.scss'], + selector: 'app-welcome', + templateUrl: './welcome.component.html', + styleUrls: ['./welcome.component.scss'], + standalone: true, + imports: [ + RouterLink, + RouterLinkActive, + MatButton, + MatIcon, + ], }) export class WelcomeComponent implements OnInit { private headerClicks = 0; diff --git a/src/app/welcome/welcome.module.ts b/src/app/welcome/welcome.module.ts deleted file mode 100644 index 97ae7995..00000000 --- a/src/app/welcome/welcome.module.ts +++ /dev/null @@ -1,11 +0,0 @@ -import { NgModule } from '@angular/core'; -import { CommonModule } from '@angular/common'; -import { WelcomeComponent } from './welcome.component'; -import { MaterialImportsModule } from '../shared/material-imports/material-imports.module'; -import { RouterModule } from '@angular/router'; - -@NgModule({ - declarations: [WelcomeComponent], - imports: [CommonModule, MaterialImportsModule, RouterModule], -}) -export class WelcomeModule {} diff --git a/src/environments/environment.computas.ts b/src/environments/environment.computas.ts index dd18bd73..92dd1a66 100644 --- a/src/environments/environment.computas.ts +++ b/src/environments/environment.computas.ts @@ -1,8 +1,8 @@ -export const environment = { - production: true, - WS_ENDPOINT: 'wss://teknisk-museum-backend.azurewebsites.net', - // TEKNISKBACKEND_ENDPOINT :'https://tekniskback.azurewebsites.net', - TEKNISKBACKEND_ENDPOINT: 'https://teknisk-museum-backend-singleplayer.azurewebsites.net', - inactivityTime: 60 * 1000, - PAIR_ID: 'f368b28b-4d39-4362-8c8c-c1f230c64fb0', -}; +export const environment = { + production: true, + WS_ENDPOINT: 'wss://teknisk-museum-backend.azurewebsites.net', + // TEKNISKBACKEND_ENDPOINT :'https://tekniskback.azurewebsites.net', + TEKNISKBACKEND_ENDPOINT: 'https://teknisk-museum-backend-singleplayer.azurewebsites.net', + inactivityTime: 60 * 1000, + PAIR_ID: 'f368b28b-4d39-4362-8c8c-c1f230c64fb0', +}; diff --git a/src/environments/environment.dev.ts b/src/environments/environment.dev.ts index f3427ca9..48486d5b 100644 --- a/src/environments/environment.dev.ts +++ b/src/environments/environment.dev.ts @@ -1,7 +1,7 @@ -export const environment = { - production: false, - WS_ENDPOINT: 'ws://localhost:8000', - TEKNISKBACKEND_ENDPOINT : 'http://localhost:8000', - inactivityTime: 60 * 1000, - PAIR_ID: 'dev-1' -}; +export const environment = { + production: false, + WS_ENDPOINT: 'ws://localhost:8000', + TEKNISKBACKEND_ENDPOINT: 'http://localhost:8000', + inactivityTime: 60 * 1000, + PAIR_ID: 'dev-1', +}; diff --git a/src/environments/environment.tekniskmuseumprod.ts b/src/environments/environment.tekniskmuseumprod.ts index 9d7052a5..20582715 100644 --- a/src/environments/environment.tekniskmuseumprod.ts +++ b/src/environments/environment.tekniskmuseumprod.ts @@ -1,8 +1,8 @@ -export const environment = { - production: true, - WS_ENDPOINT: 'wss://tekniskmuseumbackendmultiplayer.azurewebsites.net', - // TEKNISKBACKEND_ENDPOINT :'https://tekniskback.azurewebsites.net', - TEKNISKBACKEND_ENDPOINT :'https://tekniskmuseumbackendsingleplayer-dev.azurewebsites.net', - inactivityTime: 60 * 1000, - PAIR_ID: 'teknisk-1' -}; +export const environment = { + production: true, + WS_ENDPOINT: 'wss://tekniskmuseumbackendmultiplayer.azurewebsites.net', + // TEKNISKBACKEND_ENDPOINT :'https://tekniskback.azurewebsites.net', + TEKNISKBACKEND_ENDPOINT: 'https://tekniskmuseumbackendsingleplayer-dev.azurewebsites.net', + inactivityTime: 60 * 1000, + PAIR_ID: 'teknisk-1', +}; diff --git a/src/environments/environment.ts b/src/environments/environment.ts index 00dcb965..8e77b9a4 100644 --- a/src/environments/environment.ts +++ b/src/environments/environment.ts @@ -1,22 +1,22 @@ -// This file can be replaced during build by using the `fileReplacements` array. -// `ng build --prod` replaces `environment.ts` with `environment.prod.ts`. -// The list of file replacements can be found in `angular.json`. - -export const environment = { - production: false, - // WS_ENDPOINT: 'wss://tekniskback-mp.azurewebsites.net', - WS_ENDPOINT: 'ws://localhost:5000', - TEKNISKBACKEND_ENDPOINT: 'http://localhost:8000', - inactivityTime: 600 * 1000, - // Maximum length of value is 32 characters - PAIR_ID: 'local-1' -}; - -/* - * For easier debugging in development mode, you can import the following file - * to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`. - * - * This import should be commented out in production mode because it will have a negative impact - * on performance if an error is thrown. - */ -// import 'zone.js/dist/zone-error'; // Included with Angular CLI. +// This file can be replaced during build by using the `fileReplacements` array. +// `ng build --prod` replaces `environment.ts` with `environment.prod.ts`. +// The list of file replacements can be found in `angular.json`. + +export const environment = { + production: false, + // WS_ENDPOINT: 'wss://tekniskback-mp.azurewebsites.net', + WS_ENDPOINT: 'ws://localhost:5000', + TEKNISKBACKEND_ENDPOINT: 'http://localhost:8000', + inactivityTime: 600 * 1000, + // Maximum length of value is 32 characters + PAIR_ID: 'local-1', +}; + +/* + * For easier debugging in development mode, you can import the following file + * to ignore zone related error stack frames such as `zone.run`, `zoneDelegate.invokeTask`. + * + * This import should be commented out in production mode because it will have a negative impact + * on performance if an error is thrown. + */ +// import 'zone.js/dist/zone-error'; // Included with Angular CLI. diff --git a/src/main.ts b/src/main.ts index d9a2e7e4..3b09bf31 100644 --- a/src/main.ts +++ b/src/main.ts @@ -1,13 +1,25 @@ -import { enableProdMode } from '@angular/core'; -import { platformBrowserDynamic } from '@angular/platform-browser-dynamic'; +import { enableProdMode, importProvidersFrom } from '@angular/core'; -import { AppModule } from './app/app.module'; import { environment } from './environments/environment'; +import { AppComponent } from './app/app.component'; +import { provideAnimations } from '@angular/platform-browser/animations'; +import { ServiceWorkerModule } from '@angular/service-worker'; +import { routes } from './app/routes'; +import { bootstrapApplication } from '@angular/platform-browser'; +import { InfoDialogComponent } from './app/admin/info-dialog/info-dialog.component'; +import { withInterceptorsFromDi, provideHttpClient } from '@angular/common/http'; +import { provideRouter } from '@angular/router'; if (environment.production) { enableProdMode(); } -platformBrowserDynamic() - .bootstrapModule(AppModule) - .catch((err) => console.error(err)); +bootstrapApplication(AppComponent, { + providers: [ + importProvidersFrom(ServiceWorkerModule.register('ngsw-worker.js', { enabled: environment.production })), + InfoDialogComponent, + provideHttpClient(withInterceptorsFromDi()), + provideRouter(routes), + provideAnimations(), + ], +}).catch((err) => console.error(err));