mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-26 18:58:21 +02:00
69 lines
2.0 KiB
TypeScript
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} />
|
|
);
|
|
}
|