mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-16 16:30:15 +01:00
* To provide a full translation option for the button in other languages * Add a modification for the old version of the chat
71 lines
1.8 KiB
TypeScript
71 lines
1.8 KiB
TypeScript
import type { TMessageProps } from '~/common';
|
|
|
|
type TSiblingSwitchProps = Pick<TMessageProps, 'siblingIdx' | 'siblingCount' | 'setSiblingIdx'>;
|
|
|
|
export default function SiblingSwitch({
|
|
siblingIdx,
|
|
siblingCount,
|
|
setSiblingIdx,
|
|
}: TSiblingSwitchProps) {
|
|
if (siblingIdx === undefined) {
|
|
return null;
|
|
} else if (siblingCount === undefined) {
|
|
return null;
|
|
}
|
|
|
|
const previous = () => {
|
|
setSiblingIdx && setSiblingIdx(siblingIdx - 1);
|
|
};
|
|
|
|
const next = () => {
|
|
setSiblingIdx && setSiblingIdx(siblingIdx + 1);
|
|
};
|
|
|
|
return siblingCount > 1 ? (
|
|
<>
|
|
<button
|
|
className="disabled:text-gray-300 dark:text-white dark:disabled:text-gray-400"
|
|
onClick={previous}
|
|
disabled={siblingIdx == 0}
|
|
>
|
|
<svg
|
|
stroke="currentColor"
|
|
fill="none"
|
|
strokeWidth="1.5"
|
|
viewBox="0 0 24 24"
|
|
strokeLinecap="round"
|
|
strokeLinejoin="round"
|
|
className="h-3 w-3"
|
|
height="1em"
|
|
width="1em"
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
>
|
|
<polyline points="15 18 9 12 15 6" />
|
|
</svg>
|
|
</button>
|
|
<span className="flex-shrink-0 flex-grow">
|
|
{siblingIdx + 1} / {siblingCount}
|
|
</span>
|
|
<button
|
|
className="disabled:text-gray-300 dark:text-white dark:disabled:text-gray-400"
|
|
onClick={next}
|
|
disabled={siblingIdx == siblingCount - 1}
|
|
>
|
|
<svg
|
|
stroke="currentColor"
|
|
fill="none"
|
|
strokeWidth="1.5"
|
|
viewBox="0 0 24 24"
|
|
strokeLinecap="round"
|
|
strokeLinejoin="round"
|
|
className="h-3 w-3"
|
|
height="1em"
|
|
width="1em"
|
|
xmlns="http://www.w3.org/2000/svg"
|
|
>
|
|
<polyline points="9 18 15 12 9 6" />
|
|
</svg>
|
|
</button>
|
|
</>
|
|
) : null;
|
|
}
|