From 19b5f7c6a722a18463b3aa5d7b352ab5fd652902 Mon Sep 17 00:00:00 2001 From: Patrick Bassner Date: Fri, 20 Dec 2024 16:57:42 +0100 Subject: [PATCH] Iris: Fix the about page (#10016) --- src/main/webapp/app/app-routing.module.ts | 3 ++ .../iris/about-iris/about-iris.component.ts | 6 ++- .../iris/iris-logo/iris-logo.component.html | 2 +- .../app/iris/iris-logo/iris-logo.component.ts | 47 ++++++++++--------- src/main/webapp/app/iris/iris.module.ts | 6 +-- 5 files changed, 35 insertions(+), 29 deletions(-) diff --git a/src/main/webapp/app/app-routing.module.ts b/src/main/webapp/app/app-routing.module.ts index 6ab77a7e46d0..607fb3a3f6b8 100644 --- a/src/main/webapp/app/app-routing.module.ts +++ b/src/main/webapp/app/app-routing.module.ts @@ -182,6 +182,9 @@ const LAYOUT_ROUTES: Routes = [navbarRoute, ...errorRoute]; path: 'about-iris', pathMatch: 'full', loadComponent: () => import('./iris/about-iris/about-iris.component').then((m) => m.AboutIrisComponent), + data: { + pageTitle: 'artemisApp.exerciseChatbot.title', + }, }, ], { enableTracing: false, onSameUrlNavigation: 'reload' }, diff --git a/src/main/webapp/app/iris/about-iris/about-iris.component.ts b/src/main/webapp/app/iris/about-iris/about-iris.component.ts index e2dc8d39ac15..958c96120ce9 100644 --- a/src/main/webapp/app/iris/about-iris/about-iris.component.ts +++ b/src/main/webapp/app/iris/about-iris/about-iris.component.ts @@ -1,11 +1,15 @@ import { Component } from '@angular/core'; import { faRobot } from '@fortawesome/free-solid-svg-icons'; -import { IrisLogoSize } from '../iris-logo/iris-logo.component'; +import { IrisLogoComponent, IrisLogoSize } from '../iris-logo/iris-logo.component'; +import { ArtemisTranslatePipe } from 'app/shared/pipes/artemis-translate.pipe'; +import { TranslateDirective } from 'app/shared/language/translate.directive'; @Component({ selector: 'jhi-about-iris', templateUrl: './about-iris.component.html', styleUrls: ['about-iris.component.scss'], + standalone: true, + imports: [IrisLogoComponent, ArtemisTranslatePipe, TranslateDirective], }) export class AboutIrisComponent { faRobot = faRobot; diff --git a/src/main/webapp/app/iris/iris-logo/iris-logo.component.html b/src/main/webapp/app/iris/iris-logo/iris-logo.component.html index 61eb1f05ac99..adbcaf6c636b 100644 --- a/src/main/webapp/app/iris/iris-logo/iris-logo.component.html +++ b/src/main/webapp/app/iris/iris-logo/iris-logo.component.html @@ -1 +1 @@ -Iris Logo +Iris Logo diff --git a/src/main/webapp/app/iris/iris-logo/iris-logo.component.ts b/src/main/webapp/app/iris/iris-logo/iris-logo.component.ts index 4b9db489f19d..76f8d4bf8571 100644 --- a/src/main/webapp/app/iris/iris-logo/iris-logo.component.ts +++ b/src/main/webapp/app/iris/iris-logo/iris-logo.component.ts @@ -1,4 +1,4 @@ -import { Component, Input, OnInit } from '@angular/core'; +import { Component, computed, input } from '@angular/core'; export enum IrisLogoSize { FLUID = 'fluid', @@ -16,30 +16,31 @@ export enum IrisLogoLookDirection { selector: 'jhi-iris-logo', templateUrl: './iris-logo.component.html', styleUrls: ['./iris-logo.component.scss'], + standalone: true, }) -export class IrisLogoComponent implements OnInit { - @Input() - size: IrisLogoSize | number = IrisLogoSize.BIG; +export class IrisLogoComponent { + size = input(IrisLogoSize.BIG); + look = input(IrisLogoLookDirection.RIGHT); - @Input() - look: IrisLogoLookDirection = IrisLogoLookDirection.RIGHT; - - logoUrl: string; - classList: string; + logoUrl = computed(() => { + if (this.size() === IrisLogoSize.SMALL) { + return 'public/images/iris/iris-logo-small.png'; + } + return `public/images/iris/iris-logo-big-${this.look()}.png`; + }); - ngOnInit() { - if (this.size === IrisLogoSize.SMALL) { - this.logoUrl = 'public/images/iris/iris-logo-small.png'; - this.classList = 'small'; - } else if (this.size === IrisLogoSize.MEDIUM) { - this.logoUrl = `public/images/iris/iris-logo-big-${this.look}.png`; - this.classList = 'medium'; - } else if (this.size === IrisLogoSize.BIG) { - this.logoUrl = `public/images/iris/iris-logo-big-${this.look}.png`; - this.classList = 'big img-fluid'; - } else if (this.size === IrisLogoSize.FLUID) { - this.logoUrl = `public/images/iris/iris-logo-big-${this.look}.png`; - this.classList = 'fluid'; + classList = computed(() => { + switch (this.size()) { + case IrisLogoSize.SMALL: + return 'small'; + case IrisLogoSize.MEDIUM: + return 'medium'; + case IrisLogoSize.BIG: + return 'big img-fluid'; + case IrisLogoSize.FLUID: + return 'fluid'; + default: + return ''; } - } + }); } diff --git a/src/main/webapp/app/iris/iris.module.ts b/src/main/webapp/app/iris/iris.module.ts index aacdbd0b64cf..844b5d97c3af 100644 --- a/src/main/webapp/app/iris/iris.module.ts +++ b/src/main/webapp/app/iris/iris.module.ts @@ -5,7 +5,6 @@ import { FormsModule } from '@angular/forms'; import { FontAwesomeModule } from '@fortawesome/angular-fontawesome'; import { ArtemisSharedModule } from 'app/shared/shared.module'; import { ArtemisMarkdownModule } from 'app/shared/markdown.module'; -import { AboutIrisComponent } from 'app/iris/about-iris/about-iris.component'; import { RouterModule } from '@angular/router'; import { ArtemisSharedComponentModule } from 'app/shared/components/shared-component.module'; import { IrisSettingsUpdateComponent } from './settings/iris-settings-update/iris-settings-update.component'; @@ -13,7 +12,6 @@ import { IrisGlobalSettingsUpdateComponent } from './settings/iris-global-settin import { IrisCommonSubSettingsUpdateComponent } from './settings/iris-settings-update/iris-common-sub-settings-update/iris-common-sub-settings-update.component'; import { IrisCourseSettingsUpdateComponent } from 'app/iris/settings/iris-course-settings-update/iris-course-settings-update.component'; import { IrisExerciseSettingsUpdateComponent } from 'app/iris/settings/iris-exercise-settings-update/iris-exercise-settings-update.component'; -import { IrisLogoComponent } from './iris-logo/iris-logo.component'; import { IrisExerciseChatbotButtonComponent } from 'app/iris/exercise-chatbot/exercise-chatbot-button.component'; import { IrisChatbotWidgetComponent } from 'app/iris/exercise-chatbot/widget/chatbot-widget.component'; import { IrisEnabledComponent } from 'app/iris/settings/shared/iris-enabled.component'; @@ -22,19 +20,18 @@ import { FeatureToggleModule } from 'app/shared/feature-toggle/feature-toggle.mo import { IrisBaseChatbotComponent } from 'app/iris/base-chatbot/iris-base-chatbot.component'; import { ChatStatusBarComponent } from 'app/iris/base-chatbot/chat-status-bar/chat-status-bar.component'; import { CourseChatbotComponent } from 'app/iris/course-chatbot/course-chatbot.component'; +import { IrisLogoComponent } from 'app/iris/iris-logo/iris-logo.component'; @NgModule({ declarations: [ IrisBaseChatbotComponent, IrisChatbotWidgetComponent, IrisExerciseChatbotButtonComponent, - AboutIrisComponent, IrisSettingsUpdateComponent, IrisGlobalSettingsUpdateComponent, IrisCourseSettingsUpdateComponent, IrisExerciseSettingsUpdateComponent, IrisCommonSubSettingsUpdateComponent, - IrisLogoComponent, IrisEnabledComponent, ChatStatusBarComponent, IrisLogoButtonComponent, @@ -50,6 +47,7 @@ import { CourseChatbotComponent } from 'app/iris/course-chatbot/course-chatbot.c ArtemisSharedComponentModule, RouterModule, FeatureToggleModule, + IrisLogoComponent, ], exports: [IrisExerciseChatbotButtonComponent, IrisEnabledComponent, IrisLogoButtonComponent, IrisBaseChatbotComponent, CourseChatbotComponent], })