Files
mtdb_movie/resources/client/base-media-link.tsx
maher 703f50a09d
Some checks failed
Build / run (push) Has been cancelled
first commit
2025-10-29 11:42:25 +01:00

45 lines
1.2 KiB
TypeScript
Executable File

import {Link, LinkProps} from 'react-router-dom';
import clsx from 'clsx';
import React, {ReactNode} from 'react';
import {getBootstrapData} from '@common/core/bootstrap-data/use-backend-bootstrap-data';
export interface BaseMediaLinkProps extends Omit<LinkProps, 'to' | 'title'> {
link: string;
className?: string;
children?: ReactNode;
color?: 'primary' | 'inherit';
displayContents?: boolean;
}
export function BaseMediaLink({
link,
className,
children,
color = 'inherit',
displayContents,
...linkProps
}: BaseMediaLinkProps) {
const baseClassName = displayContents
? 'contents'
: clsx(
color === 'primary'
? 'text-primary hover:text-primary-dark'
: 'text-inherit',
'hover:underline outline-none focus-visible:underline overflow-x-hidden overflow-ellipsis transition-colors'
);
return (
<Link {...linkProps} className={clsx(baseClassName, className)} to={link}>
{children}
</Link>
);
}
export function getBaseMediaLink(
link: string,
{absolute}: {absolute?: boolean} = {}
): string {
if (absolute) {
link = `${getBootstrapData().settings.base_url}${link}`;
}
return link;
}