123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { useEventListener } from '@vueuse/core'
- import { useRouter } from 'vue-router'
- import { isStandalone } from '#shared/utils/pwa.ts'
- import { useBaseUrl } from './useBaseUrl.ts'
- const useHtmlLinks = (urlPrefix: '/desktop' | '/mobile') => {
- const { baseUrl } = useBaseUrl()
- const router = useRouter()
- const getRedirectRoute = (url: URL): string | undefined => {
- if (url.pathname.startsWith(urlPrefix)) {
- return url.href.slice(`${url.origin}${urlPrefix}`.length)
- }
- const route = router.resolve(`/${url.hash.slice(1)}${url.search}`)
- if (route.name !== 'Error') {
- return route.fullPath
- }
- }
- const openLink = (target: string, path: string) => {
- // keep links inside PWA inside the app
- if (!isStandalone() && target && target !== '_self') {
- window.open(`${urlPrefix}${path}`, target)
- } else {
- router.push(path)
- }
- }
- const handleLinkClick = (link: HTMLAnchorElement, event: Event) => {
- try {
- const url = new URL(link.href)
- if (
- url.origin === window.location.origin ||
- url.origin === baseUrl.value
- ) {
- const redirectRoute = getRedirectRoute(url)
- if (redirectRoute) {
- event.preventDefault()
- return openLink(link.target, redirectRoute)
- }
- }
- if (link.hasAttribute('external')) return
- if (!link.target) {
- event.preventDefault()
- window.open(link.href)
- }
- } catch {
- // skip
- }
- }
- // user links has fqdn in its href, but if it changes the link becomes invalid
- // to bypass that we replace the href with the correct one
- const patchUserMentionLinks = (link: HTMLAnchorElement) => {
- const userId = link.dataset.mentionUserId
- if (!userId) return
- link.href = `${baseUrl.value}${urlPrefix}/users/${userId}`
- }
- const setupLinksHandlers = (element: HTMLDivElement) => {
- element.querySelectorAll('a').forEach((link) => {
- if ('__handled' in link) return
- Object.defineProperty(link, '__handled', { value: true })
- patchUserMentionLinks(link)
- useEventListener(link, 'click', (event) => handleLinkClick(link, event))
- })
- }
- return {
- setupLinksHandlers,
- }
- }
- export { useHtmlLinks }
|