1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-14 18:27:44 +02:00
joplin/packages/pdf-viewer/ui/IconButtons.tsx

69 lines
2.0 KiB
TypeScript

import React from 'react';
import styled from 'styled-components';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { faPrint, faDownload, faSquareArrowUpRight, faXmark, IconDefinition } from '@fortawesome/free-solid-svg-icons';
import { IconButtonProps } from '../types';
const ButtonElement = styled.button<{ hoverColor?: string; size?: number; color?: string }>`
padding: 0.2rem 0.7rem;
cursor: pointer;
border: solid thin transparent;
border-radius: 5px;
user-select: none;
display: flex;
justify-content: center;
align-items: center;
font-size: ${props=> props.size || 1}rem;
background: transparent;
color: var(--${props=>props.color || 'grey'});
&:hover {
background: #7676764d;
${props=>props.hoverColor && `color: var(--${props.hoverColor})`}
}
`;
interface BaseButtonProps {
icon: IconDefinition;
onClick: ()=> void;
name: string;
size: number;
color: string;
hoverColor?: string;
}
function BaseButton({ onClick, icon, name, size, color, hoverColor }: BaseButtonProps) {
return (
<ButtonElement onClick={onClick} title={name}
color={color}
size={size}
hoverColor={hoverColor || 'secondary'}>
<FontAwesomeIcon icon={icon} />
</ButtonElement>
);
}
export function OpenLinkButton({ onClick, size, color }: IconButtonProps) {
return (
<BaseButton onClick={onClick} icon={faSquareArrowUpRight} name='Open in another app' size={size} color={color} />
);
}
export function CloseButton({ onClick, size, color }: IconButtonProps) {
return (
<BaseButton onClick={onClick} icon={faXmark} name='Close' size={size} color={color} hoverColor={'red'} />
);
}
export function DownloadButton({ onClick, size, color }: IconButtonProps) {
return (
<BaseButton onClick={onClick} icon={faDownload} name='Download' size={size} color={color} />
);
}
export function PrintButton({ onClick, size, color }: IconButtonProps) {
return (
<BaseButton onClick={onClick} icon={faPrint} name='Print' size={size} color={color} />
);
}