-
-
-
-
-
-
-
-
-
+
{{site.siteUrl}}
diff --git a/src/core/features/login/pages/credentials/credentials.ts b/src/core/features/login/pages/credentials/credentials.ts
index 9ee00529a..fabf6d53b 100644
--- a/src/core/features/login/pages/credentials/credentials.ts
+++ b/src/core/features/login/pages/credentials/credentials.ts
@@ -57,8 +57,6 @@ export class CoreLoginCredentialsPage implements OnInit, OnDestroy {
credForm!: FormGroup;
site!: CoreUnauthenticatedSite;
- siteName?: string;
- logoUrl?: string;
authInstructions?: string;
canSignup?: boolean;
pageLoaded = false;
@@ -104,11 +102,9 @@ export class CoreLoginCredentialsPage implements OnInit, OnDestroy {
}
this.site = CoreSitesFactory.makeUnauthenticatedSite(siteUrl, this.siteConfig);
- this.logoUrl = this.site.getLogoUrl(this.siteConfig);
this.urlToOpen = CoreNavigator.getRouteParam('urlToOpen');
this.supportConfig = this.siteConfig && new CoreUserGuestSupportConfig(this.site, this.siteConfig);
this.displaySiteUrl = this.site.shouldDisplayInformativeLinks();
- this.siteName = await this.site.getSiteName();
} catch (error) {
CoreDomUtils.showErrorModal(error);
@@ -220,8 +216,6 @@ export class CoreLoginCredentialsPage implements OnInit, OnDestroy {
if (this.site.isDemoModeSite()) {
this.showScanQR = false;
} else {
- this.siteName = this.siteConfig.sitename;
- this.logoUrl = this.site.getLogoUrl(this.siteConfig);
this.showScanQR = await CoreLoginHelper.displayQRInCredentialsScreen(this.siteConfig.tool_mobile_qrcodetype);
}
diff --git a/src/core/features/login/pages/reconnect/reconnect.html b/src/core/features/login/pages/reconnect/reconnect.html
index 2a5c92b3a..cda292eb9 100644
--- a/src/core/features/login/pages/reconnect/reconnect.html
+++ b/src/core/features/login/pages/reconnect/reconnect.html
@@ -31,16 +31,8 @@
-
-
-
-
-
+
-
-
-
{{site.siteUrl}}
diff --git a/src/core/features/login/pages/reconnect/reconnect.ts b/src/core/features/login/pages/reconnect/reconnect.ts
index 684d36a1e..1db1c98f7 100644
--- a/src/core/features/login/pages/reconnect/reconnect.ts
+++ b/src/core/features/login/pages/reconnect/reconnect.ts
@@ -49,7 +49,6 @@ export class CoreLoginReconnectPage implements OnInit, OnDestroy {
credForm: FormGroup;
site!: CoreSite;
- logoUrl?: string;
displaySiteUrl = false;
showForgottenPassword = true;
showUserAvatar = false;
@@ -202,7 +201,6 @@ export class CoreLoginReconnectPage implements OnInit, OnDestroy {
}
this.isBrowserSSO = CoreLoginHelper.isSSOLoginNeeded(this.siteConfig.typeoflogin);
- this.logoUrl = this.site.getLogoUrl();
await CoreSites.checkApplication(this.siteConfig);
}
diff --git a/src/core/features/login/pages/site/site.scss b/src/core/features/login/pages/site/site.scss
index 0fc9e7a87..851904e50 100644
--- a/src/core/features/login/pages/site/site.scss
+++ b/src/core/features/login/pages/site/site.scss
@@ -48,7 +48,6 @@
.core-login-site-logo,
.core-login-site-list,
.core-login-site-list-found {
- transition-delay: 0s;
visibility: visible;
opacity: 1;
transition: all 0.7s ease-in-out;
@@ -61,6 +60,7 @@
margin-bottom: 0;
padding: 0;
max-height: 0;
+ display: block !important; /** Avoid breaking the animation */
}
}
diff --git a/src/core/features/login/tests/behat/snapshots/test-basic-usage-of-login-in-app-add-a-new-account-in-the-app--site-name-in-displayed-when-adding-a-new-account_9.png b/src/core/features/login/tests/behat/snapshots/test-basic-usage-of-login-in-app-add-a-new-account-in-the-app--site-name-in-displayed-when-adding-a-new-account_9.png
index dc3db50c8..6281d2e66 100644
Binary files a/src/core/features/login/tests/behat/snapshots/test-basic-usage-of-login-in-app-add-a-new-account-in-the-app--site-name-in-displayed-when-adding-a-new-account_9.png and b/src/core/features/login/tests/behat/snapshots/test-basic-usage-of-login-in-app-add-a-new-account-in-the-app--site-name-in-displayed-when-adding-a-new-account_9.png differ
diff --git a/src/core/features/login/tests/behat/snapshots/test-showloginform-setting-in-the-app-login_10.png b/src/core/features/login/tests/behat/snapshots/test-showloginform-setting-in-the-app-login_10.png
index c31717c64..609f45ef4 100644
Binary files a/src/core/features/login/tests/behat/snapshots/test-showloginform-setting-in-the-app-login_10.png and b/src/core/features/login/tests/behat/snapshots/test-showloginform-setting-in-the-app-login_10.png differ
diff --git a/src/core/features/login/tests/behat/snapshots/test-showloginform-setting-in-the-app-reconnect_10.png b/src/core/features/login/tests/behat/snapshots/test-showloginform-setting-in-the-app-reconnect_10.png
index 24599dab7..ec2242832 100644
Binary files a/src/core/features/login/tests/behat/snapshots/test-showloginform-setting-in-the-app-reconnect_10.png and b/src/core/features/login/tests/behat/snapshots/test-showloginform-setting-in-the-app-reconnect_10.png differ
diff --git a/src/core/features/mainmenu/components/user-menu/user-menu.html b/src/core/features/mainmenu/components/user-menu/user-menu.html
index ae58884dc..327c83bac 100644
--- a/src/core/features/mainmenu/components/user-menu/user-menu.html
+++ b/src/core/features/mainmenu/components/user-menu/user-menu.html
@@ -13,18 +13,14 @@
-
+
@@ -32,11 +28,7 @@
diff --git a/src/core/features/mainmenu/components/user-menu/user-menu.scss b/src/core/features/mainmenu/components/user-menu/user-menu.scss
index 1cfd248fd..9256a3ba5 100644
--- a/src/core/features/mainmenu/components/user-menu/user-menu.scss
+++ b/src/core/features/mainmenu/components/user-menu/user-menu.scss
@@ -22,23 +22,17 @@
}
}
-.core-usermenu-sitename {
- font: var(--mdl-typography-subtitle-font-lg);
-}
+core-site-logo {
+ --core-site-logo-margin-bottom: 8px;
+ --core-site-logo-max-height: var(--core-user-menu-site-logo-max-height);
-img.core-usermenu-site-logo {
- margin-bottom: 8px;
- max-height: var(--core-user-menu-site-logo-max-height);
+ --core-site-logo-sitename-font: var(--mdl-typography-subtitle-font-lg);
+ --core-site-logo-sitename-margin-bottom: 2px;
}
-img.image-not-found {
- display: none;
-}
-
-
@if ($core-user-hide-sitename) {
- .core-usermenu-sitename {
- display: none;
+ core-site-logo {
+ --core-site-logo-sitename-display: none;
}
}
diff --git a/src/core/features/mainmenu/components/user-menu/user-menu.ts b/src/core/features/mainmenu/components/user-menu/user-menu.ts
index 1aecec73f..6fbb49298 100644
--- a/src/core/features/mainmenu/components/user-menu/user-menu.ts
+++ b/src/core/features/mainmenu/components/user-menu/user-menu.ts
@@ -15,7 +15,6 @@
import { CoreConstants } from '@/core/constants';
import { CoreSharedModule } from '@/core/shared.module';
import { Component, OnDestroy, OnInit } from '@angular/core';
-import { CoreSite } from '@classes/sites/site';
import { CoreSiteInfo } from '@classes/sites/unauthenticated-site';
import { CoreFilter } from '@features/filter/services/filter';
import { CoreUserAuthenticatedSupportConfig } from '@features/user/classes/support/authenticated-support-config';
@@ -31,10 +30,10 @@ import { CoreModals } from '@services/modals';
import { CoreNavigator } from '@services/navigator';
import { CoreSites } from '@services/sites';
import { CoreDomUtils } from '@services/utils/dom';
-import { CorePromiseUtils } from '@singletons/promise-utils';
import { ModalController } from '@singletons';
import { Subscription } from 'rxjs';
import { CoreLoginHelper } from '@features/login/services/login-helper';
+import { CoreSiteLogoComponent } from '@/core/components/site-logo/site-logo';
/**
* Component to display a user menu.
@@ -46,6 +45,7 @@ import { CoreLoginHelper } from '@features/login/services/login-helper';
standalone: true,
imports: [
CoreSharedModule,
+ CoreSiteLogoComponent,
],
})
export class CoreMainMenuUserMenuComponent implements OnInit, OnDestroy {
@@ -53,8 +53,6 @@ export class CoreMainMenuUserMenuComponent implements OnInit, OnDestroy {
siteId?: string;
siteInfo?: CoreSiteInfo;
siteName?: string;
- siteLogo?: string;
- siteLogoLoaded = false;
siteUrl?: string;
displaySiteUrl = false;
handlers: CoreUserProfileHandlerData[] = [];
@@ -81,8 +79,6 @@ export class CoreMainMenuUserMenuComponent implements OnInit, OnDestroy {
this.removeAccountOnLogout = !!CoreConstants.CONFIG.removeaccountonlogout;
this.displaySiteUrl = currentSite.shouldDisplayInformativeLinks();
- this.loadSiteLogo(currentSite);
-
if (!this.siteInfo) {
return;
}
@@ -127,25 +123,6 @@ export class CoreMainMenuUserMenuComponent implements OnInit, OnDestroy {
});
}
- /**
- * Load site logo from current site public config.
- *
- * @param currentSite Current site object.
- * @returns Promise resolved when done.
- */
- protected async loadSiteLogo(currentSite: CoreSite): Promise {
- if (currentSite.forcesLocalLogo()) {
- this.siteLogo = currentSite.getLogoUrl();
- this.siteLogoLoaded = true;
-
- return;
- }
-
- const siteConfig = await CorePromiseUtils.ignoreErrors(currentSite.getPublicConfig());
- this.siteLogo = currentSite.getLogoUrl(siteConfig);
- this.siteLogoLoaded = true;
- }
-
/**
* Opens User profile page.
*
diff --git a/src/core/features/mainmenu/mainmenu-home-lazy.module.ts b/src/core/features/mainmenu/mainmenu-home-lazy.module.ts
index a05414831..5f18ed2d8 100644
--- a/src/core/features/mainmenu/mainmenu-home-lazy.module.ts
+++ b/src/core/features/mainmenu/mainmenu-home-lazy.module.ts
@@ -22,6 +22,7 @@ import { CoreMainMenuHomeHandlerService } from '@features/mainmenu/services/hand
import { CoreMainMenuComponentsModule } from '@features/mainmenu/components/components.module';
import { resolveHomeRoutes } from '@features/mainmenu/mainmenu-home-routing.module';
import { CoreMainMenuHomePage } from '@features/mainmenu/pages/home/home';
+import { CoreSiteLogoComponent } from '@/core/components/site-logo/site-logo';
/**
* Build module routes.
@@ -49,6 +50,7 @@ function buildRoutes(injector: Injector): Routes {
imports: [
CoreSharedModule,
CoreMainMenuComponentsModule,
+ CoreSiteLogoComponent,
],
providers: [
{ provide: ROUTES, multi: true, useFactory: buildRoutes, deps: [Injector] },
diff --git a/src/core/features/mainmenu/pages/home/home.html b/src/core/features/mainmenu/pages/home/home.html
index f1769431a..c2730d370 100644
--- a/src/core/features/mainmenu/pages/home/home.html
+++ b/src/core/features/mainmenu/pages/home/home.html
@@ -5,8 +5,7 @@
-
-
+
diff --git a/src/theme/components/ion-header.scss b/src/theme/components/ion-header.scss
index 8a82ca47d..e96870856 100644
--- a/src/theme/components/ion-header.scss
+++ b/src/theme/components/ion-header.scss
@@ -69,15 +69,8 @@ ion-header.header-md {
display: inline !important;
}
- h1 {
- .core-header-logo {
- max-height: var(--core-mainpage-headerlogo-maxheight);
- display: var( --core-mainpage-headerlogo-display);
- }
-
- .core-header-sitename {
- display: var(--core-mainpage-sitename-display);
- }
+ h1 core-site-logo {
+ --core-site-logo-max-height: var(--core-mainpage-headerlogo-maxheight);
}
h1, h2, .subheading {
diff --git a/src/theme/globals.variables.scss b/src/theme/globals.variables.scss
index 3cebbc93b..5cbcc7e77 100644
--- a/src/theme/globals.variables.scss
+++ b/src/theme/globals.variables.scss
@@ -84,7 +84,6 @@ $core-dd-question-colors: #FFFFFF, #B0C4DE, #DCDCDC, #D8BFD8, #87CEFA, #DAA520,
$core-text-hightlight-background-color: lighten($blue, 40%) !default;
$core-fixed-url: false !default;
-$core-dashboard-logo: false !default;
$core-always-show-main-menu: false !default;
$core-format-text-never-shorten: false !default;
diff --git a/src/theme/theme.design-system.scss b/src/theme/theme.design-system.scss
index ba3453db4..f9d37c015 100644
--- a/src/theme/theme.design-system.scss
+++ b/src/theme/theme.design-system.scss
@@ -231,15 +231,7 @@
--rotate-expandable: rotate(90deg);
- --core-mainpage-sitename-display: none;
- --core-mainpage-headerlogo-display: none;
--core-mainpage-headerlogo-maxheight: calc(var(--core-header-toolbar-height) - 16px);
-
- @if ($core-dashboard-logo) {
- --core-mainpage-headerlogo-display: inline;
- } @else {
- --core-mainpage-sitename-display: inline;
- }
}
/** @deprecated since 4.3 **/
diff --git a/src/types/config.d.ts b/src/types/config.d.ts
index 569bfaa40..6cca9c29d 100644
--- a/src/types/config.d.ts
+++ b/src/types/config.d.ts
@@ -53,6 +53,7 @@ export interface EnvironmentConfig {
enableonboarding: boolean;
forceColorScheme: CoreColorScheme;
forceLoginLogo: boolean;
+ showTopLogo: 'online' | 'offline' | 'hidden';
ioswebviewscheme: string;
appstores: Record;
displayqroncredentialscreen?: boolean;