mirror of
https://github.com/gethomepage/homepage.git
synced 2025-12-06 21:57:48 +01:00
51 lines
1.7 KiB
JavaScript
51 lines
1.7 KiB
JavaScript
import classNames from "classnames";
|
|
import { useTranslation } from "next-i18next";
|
|
import { useContext, useMemo } from "react";
|
|
|
|
import { BlockHighlightContext } from "./highlight-context";
|
|
|
|
import { evaluateHighlight, getHighlightClass } from "utils/highlights";
|
|
|
|
export default function Block({ value, label, field }) {
|
|
const { t } = useTranslation();
|
|
const highlightConfig = useContext(BlockHighlightContext);
|
|
|
|
const highlight = useMemo(() => {
|
|
if (!highlightConfig) return null;
|
|
const labels = Array.isArray(label) ? label : [label];
|
|
const candidates = [];
|
|
if (typeof field === "string") candidates.push(field);
|
|
for (const candidateLabel of labels) {
|
|
if (typeof candidateLabel === "string") candidates.push(candidateLabel);
|
|
}
|
|
|
|
for (const candidate of candidates) {
|
|
const result = evaluateHighlight(candidate, value, highlightConfig);
|
|
if (result) return result;
|
|
}
|
|
|
|
return null;
|
|
}, [field, label, value, highlightConfig]);
|
|
|
|
const highlightClass = useMemo(() => {
|
|
if (!highlight?.level) return undefined;
|
|
return getHighlightClass(highlight.level, highlightConfig);
|
|
}, [highlight, highlightConfig]);
|
|
|
|
return (
|
|
<div
|
|
className={classNames(
|
|
"bg-theme-200/50 dark:bg-theme-900/20 rounded-sm m-1 flex-1 flex flex-col items-center justify-center text-center p-1",
|
|
value === undefined ? "animate-pulse" : "",
|
|
highlightClass,
|
|
"service-block",
|
|
)}
|
|
data-highlight-level={highlight?.level}
|
|
data-highlight-source={highlight?.source}
|
|
>
|
|
<div className="font-thin text-sm">{value === undefined || value === null ? "-" : value}</div>
|
|
<div className="font-bold text-xs uppercase">{t(label)}</div>
|
|
</div>
|
|
);
|
|
}
|