From 576dbc937ccc281e1d318dca47b15605dff5c9db Mon Sep 17 00:00:00 2001 From: milanmajchrak Date: Mon, 11 Dec 2023 14:13:13 +0100 Subject: [PATCH 1/2] Fixed static page redirects. --- .../static-page/static-page-routing-paths.ts | 1 + src/app/static-page/static-page.component.ts | 28 +++++++++++++++---- 2 files changed, 23 insertions(+), 6 deletions(-) diff --git a/src/app/static-page/static-page-routing-paths.ts b/src/app/static-page/static-page-routing-paths.ts index 8df2e5bcd36..e6fd63cf4d2 100644 --- a/src/app/static-page/static-page-routing-paths.ts +++ b/src/app/static-page/static-page-routing-paths.ts @@ -3,4 +3,5 @@ */ export const STATIC_PAGE_PATH = 'static'; export const STATIC_FILES_PROJECT_PATH = 'static-files'; +export const HTML_SUFFIX = '.html'; export const STATIC_FILES_DEFAULT_ERROR_PAGE_PATH = STATIC_FILES_PROJECT_PATH + '/' + 'error.html'; diff --git a/src/app/static-page/static-page.component.ts b/src/app/static-page/static-page.component.ts index 63aac66bc3a..4af0bd09854 100644 --- a/src/app/static-page/static-page.component.ts +++ b/src/app/static-page/static-page.component.ts @@ -4,7 +4,11 @@ import { BehaviorSubject, firstValueFrom } from 'rxjs'; import { Router } from '@angular/router'; import { isEmpty, isNotEmpty } from '../shared/empty.util'; import { LocaleService } from '../core/locale/locale.service'; -import { STATIC_FILES_DEFAULT_ERROR_PAGE_PATH, STATIC_FILES_PROJECT_PATH } from './static-page-routing-paths'; +import { + HTML_SUFFIX, + STATIC_FILES_DEFAULT_ERROR_PAGE_PATH, + STATIC_FILES_PROJECT_PATH, STATIC_PAGE_PATH +} from './static-page-routing-paths'; import { APP_CONFIG, AppConfig } from '../../config/app-config.interface'; /** @@ -39,6 +43,8 @@ export class StaticPageComponent implements OnInit { // Compose url url = STATIC_FILES_PROJECT_PATH; url += isEmpty(language) ? '/' + this.htmlFileName : '/' + language + '/' + this.htmlFileName; + // Add `.html` suffix to get the current html file + url = url.includes(HTML_SUFFIX) ? url : url + HTML_SUFFIX; let potentialContent = await firstValueFrom(this.htmlContentService.fetchHtmlContent(url)); if (isNotEmpty(potentialContent)) { this.htmlContent.next(potentialContent); @@ -61,17 +67,27 @@ export class StaticPageComponent implements OnInit { const element: HTMLElement = e.target; if (element.nodeName === 'A') { e.preventDefault(); - const href = element.getAttribute('href')?.replace('/', ''); - let redirectUrl = window.location.origin + this.appConfig.ui.nameSpace + '/static/'; - // Start with `#` - redirect to the fragment + // Get attribute + const href = element.getAttribute('href'); + // Check if the DSpace instance has configured namespace and if so, add it to the redirect url + const namespace = this.appConfig.ui.nameSpace === '/' ? '' : this.appConfig.ui.nameSpace; + // Compose redirect url using static page path + let redirectUrl = window.location.origin + namespace + '/' + STATIC_PAGE_PATH + '/'; + + // Update redirect url based on the href value if (href.startsWith('#')) { + // Start with `#` - redirect to the fragment redirectUrl += this.htmlFileName + href; } else if (href.startsWith('.')) { // Redirect using namespace e.g. `./test.html` -> `/namespace/static/test.html` - redirectUrl += href.replace('.', '') + '.html'; + redirectUrl += href.replace('./', ''); + } else if (href.startsWith('http') || href.startsWith('www')) { + // Redirect to external url + window.location.replace(href); + return; } else { // Redirect without using namespace e.g. `/test.html` -> `/test.html` - redirectUrl = redirectUrl.replace(this.appConfig.ui.nameSpace, '') + href; + redirectUrl = redirectUrl.replace(namespace, '') + href.replace('/', ''); } // Call redirect window.location.href = redirectUrl; From 87ef5f2ec80f898f8962d2bfe2ebc51863cf538d Mon Sep 17 00:00:00 2001 From: milanmajchrak Date: Thu, 14 Dec 2023 10:44:20 +0100 Subject: [PATCH 2/2] Refactored processing links. --- src/app/static-page/static-page.component.ts | 93 ++++++++++++++------ 1 file changed, 64 insertions(+), 29 deletions(-) diff --git a/src/app/static-page/static-page.component.ts b/src/app/static-page/static-page.component.ts index 4af0bd09854..c44d5fb6ebd 100644 --- a/src/app/static-page/static-page.component.ts +++ b/src/app/static-page/static-page.component.ts @@ -44,7 +44,7 @@ export class StaticPageComponent implements OnInit { url = STATIC_FILES_PROJECT_PATH; url += isEmpty(language) ? '/' + this.htmlFileName : '/' + language + '/' + this.htmlFileName; // Add `.html` suffix to get the current html file - url = url.includes(HTML_SUFFIX) ? url : url + HTML_SUFFIX; + url = url.endsWith(HTML_SUFFIX) ? url : url + HTML_SUFFIX; let potentialContent = await firstValueFrom(this.htmlContentService.fetchHtmlContent(url)); if (isNotEmpty(potentialContent)) { this.htmlContent.next(potentialContent); @@ -63,35 +63,70 @@ export class StaticPageComponent implements OnInit { await this.loadErrorPage(); } - processLinks(e) { - const element: HTMLElement = e.target; - if (element.nodeName === 'A') { - e.preventDefault(); - // Get attribute - const href = element.getAttribute('href'); - // Check if the DSpace instance has configured namespace and if so, add it to the redirect url - const namespace = this.appConfig.ui.nameSpace === '/' ? '' : this.appConfig.ui.nameSpace; - // Compose redirect url using static page path - let redirectUrl = window.location.origin + namespace + '/' + STATIC_PAGE_PATH + '/'; - - // Update redirect url based on the href value - if (href.startsWith('#')) { - // Start with `#` - redirect to the fragment - redirectUrl += this.htmlFileName + href; - } else if (href.startsWith('.')) { - // Redirect using namespace e.g. `./test.html` -> `/namespace/static/test.html` - redirectUrl += href.replace('./', ''); - } else if (href.startsWith('http') || href.startsWith('www')) { - // Redirect to external url - window.location.replace(href); - return; - } else { - // Redirect without using namespace e.g. `/test.html` -> `/test.html` - redirectUrl = redirectUrl.replace(namespace, '') + href.replace('/', ''); - } - // Call redirect - window.location.href = redirectUrl; + /** + * Handle click on links in the static page. + * @param event + */ + processLinks(event: Event): void { + const targetElement = event.target as HTMLElement; + + if (targetElement.nodeName !== 'A') { + return; } + + event.preventDefault(); + + const href = targetElement.getAttribute('href'); + const { nameSpace } = this.appConfig.ui; + const namespacePrefix = nameSpace === '/' ? '' : nameSpace; + + const redirectUrl = this.composeRedirectUrl(href, namespacePrefix); + + if (this.isFragmentLink(href)) { + this.redirectToFragment(redirectUrl, href); + } else if (this.isRelativeLink(href)) { + this.redirectToRelativeLink(redirectUrl, href); + } else if (this.isExternalLink(href)) { + this.redirectToExternalLink(href); + } else { + this.redirectToAbsoluteLink(redirectUrl, href, namespacePrefix); + } + } + + private composeRedirectUrl(href: string | null, namespacePrefix: string): string { + const staticPagePath = STATIC_PAGE_PATH; + const baseUrl = new URL(window.location.origin); + baseUrl.pathname = `${namespacePrefix}/${staticPagePath}/`; + return baseUrl.href; + } + + private isFragmentLink(href: string | null): boolean { + return href?.startsWith('#') ?? false; + } + + private redirectToFragment(redirectUrl: string, href: string | null): void { + window.location.href = `${redirectUrl}${this.htmlFileName}${href}`; + } + + private isRelativeLink(href: string | null): boolean { + return href?.startsWith('.') ?? false; + } + + private redirectToRelativeLink(redirectUrl: string, href: string | null): void { + window.location.href = new URL(href, redirectUrl).href; + } + + private isExternalLink(href: string | null): boolean { + return (href?.startsWith('http') || href?.startsWith('www')) ?? false; + } + + private redirectToExternalLink(href: string | null): void { + window.location.replace(href); + } + + private redirectToAbsoluteLink(redirectUrl: string, href: string | null, namespacePrefix: string): void { + const absoluteUrl = new URL(href, redirectUrl.replace(namespacePrefix, '')); + window.location.href = absoluteUrl.href; } /**