Spaces:
Running
Running
File size: 2,592 Bytes
599f646 e23b66d 599f646 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 |
/**
*
* Copyright 2023-2025 InspectorRAGet Team
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
**/
'use client';
import cx from 'classnames';
import { Link as CarbonLink, Tag } from '@carbon/react';
import { ArrowRight, Launch } from '@carbon/icons-react';
import { ComponentType, memo, ReactNode, useId } from 'react';
import Link from 'next/link';
import classes from './Card.module.scss';
type HeadingLevel = 1 | 2 | 3 | 4 | 5 | 6;
const getHeading = (level: HeadingLevel) => `h${level}` as const;
export interface CardProps {
icon: ComponentType<{ size?: number; className?: string }>;
title: string;
href?: string | null;
actionText?: ReactNode;
text?: ReactNode;
content?: ReactNode;
headingLevel?: HeadingLevel;
tag?: string | null;
openInNewTab: boolean;
disabled?: boolean;
}
function Card({
icon: Icon,
title,
text,
href,
actionText,
content,
headingLevel = 2,
tag,
openInNewTab,
disabled,
}: CardProps) {
const id = useId();
const Heading = getHeading(headingLevel);
return (
<section className={cx(classes.root, disabled && classes.disabled)}>
{href && actionText && (
<Link
href={disabled ? 'javascript:void(0)' : href}
legacyBehavior
passHref
>
<CarbonLink
className={classes.link}
renderIcon={openInNewTab ? Launch : ArrowRight}
target={openInNewTab ? '_blank' : undefined}
disabled={disabled}
>
{actionText}
</CarbonLink>
</Link>
)}
<div className={classes.body}>
<Icon className={classes.icon} size={24} />
<Heading className={classes.heading}>
{title}
{tag && (
<Tag as="span" size="sm" id={`${id}-tag`} type="high-contrast">
{tag}
</Tag>
)}
</Heading>
{!!text && <p className={classes.text}>{text}</p>}
{!!content && <div className={classes.content}>{content}</div>}
</div>
</section>
);
}
export default memo(Card);
|