2022-11-27 20:25:59 +08:00
|
|
|
import * as React from 'react';
|
2022-11-30 11:05:41 +08:00
|
|
|
import { Tooltip } from 'antd';
|
2022-11-27 20:25:59 +08:00
|
|
|
import { css } from '@emotion/react';
|
2022-11-30 11:05:41 +08:00
|
|
|
import useSiteToken from '../../../hooks/useSiteToken';
|
2022-11-27 20:25:59 +08:00
|
|
|
|
|
|
|
export interface LangBtnProps {
|
|
|
|
label1: React.ReactNode;
|
|
|
|
label2: React.ReactNode;
|
|
|
|
tooltip1?: React.ReactNode;
|
|
|
|
tooltip2?: React.ReactNode;
|
|
|
|
value: 1 | 2;
|
|
|
|
pure?: boolean;
|
|
|
|
onClick?: React.MouseEventHandler;
|
|
|
|
}
|
|
|
|
|
2022-11-29 13:14:06 +08:00
|
|
|
const BASE_SIZE = '1.2em';
|
|
|
|
|
2022-11-27 20:25:59 +08:00
|
|
|
const useStyle = () => {
|
|
|
|
const { token } = useSiteToken();
|
2022-11-29 13:14:06 +08:00
|
|
|
const { controlHeight, motionDurationMid } = token;
|
2022-11-27 20:25:59 +08:00
|
|
|
|
|
|
|
return {
|
|
|
|
btn: css`
|
2022-11-29 13:14:06 +08:00
|
|
|
color: ${token.colorText};
|
|
|
|
border-color: ${token.colorBorder};
|
2022-11-27 20:25:59 +08:00
|
|
|
padding: 0 !important;
|
2022-11-29 13:14:06 +08:00
|
|
|
width: ${controlHeight}px;
|
|
|
|
height: ${controlHeight}px;
|
2022-11-27 20:25:59 +08:00
|
|
|
display: inline-flex;
|
|
|
|
align-items: center;
|
|
|
|
justify-content: center;
|
2022-11-29 13:14:06 +08:00
|
|
|
border: none;
|
|
|
|
background: transparent;
|
|
|
|
border-radius: ${token.borderRadius}px;
|
|
|
|
transition: all ${motionDurationMid};
|
|
|
|
cursor: pointer;
|
|
|
|
|
|
|
|
.btn-inner {
|
|
|
|
transition: all ${motionDurationMid};
|
|
|
|
}
|
|
|
|
|
|
|
|
&:hover {
|
|
|
|
background: ${token.colorBgTextHover};
|
|
|
|
}
|
2022-11-27 20:25:59 +08:00
|
|
|
|
|
|
|
img {
|
2022-11-29 13:14:06 +08:00
|
|
|
width: ${BASE_SIZE};
|
|
|
|
height: ${BASE_SIZE};
|
|
|
|
}
|
|
|
|
|
|
|
|
.anticon {
|
|
|
|
font-size: ${BASE_SIZE};
|
2022-11-27 20:25:59 +08:00
|
|
|
}
|
|
|
|
`,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export default function LangBtn({
|
|
|
|
label1,
|
|
|
|
label2,
|
|
|
|
tooltip1,
|
|
|
|
tooltip2,
|
|
|
|
value,
|
|
|
|
pure,
|
|
|
|
onClick,
|
|
|
|
}: LangBtnProps) {
|
|
|
|
const { token } = useSiteToken();
|
|
|
|
const style = useStyle();
|
|
|
|
|
|
|
|
let label1Style: React.CSSProperties;
|
|
|
|
let label2Style: React.CSSProperties;
|
|
|
|
|
|
|
|
const iconStyle: React.CSSProperties = {
|
|
|
|
position: 'absolute',
|
2022-11-29 13:14:06 +08:00
|
|
|
fontSize: BASE_SIZE,
|
2022-11-27 20:25:59 +08:00
|
|
|
lineHeight: 1,
|
|
|
|
border: `1px solid ${token.colorText}`,
|
|
|
|
color: token.colorText,
|
|
|
|
};
|
|
|
|
|
|
|
|
const fontStyle: React.CSSProperties = {
|
|
|
|
left: '-5%',
|
|
|
|
top: 0,
|
|
|
|
zIndex: 1,
|
|
|
|
background: token.colorText,
|
|
|
|
color: token.colorTextLightSolid,
|
|
|
|
transformOrigin: '0 0',
|
|
|
|
transform: `scale(0.7)`,
|
|
|
|
};
|
|
|
|
const backStyle: React.CSSProperties = {
|
|
|
|
right: '-5%',
|
|
|
|
bottom: 0,
|
|
|
|
zIndex: 0,
|
|
|
|
transformOrigin: '100% 100%',
|
|
|
|
transform: `scale(0.5)`,
|
|
|
|
};
|
|
|
|
|
|
|
|
if (value === 1) {
|
|
|
|
label1Style = fontStyle;
|
|
|
|
label2Style = backStyle;
|
|
|
|
} else {
|
|
|
|
label1Style = backStyle;
|
|
|
|
label2Style = fontStyle;
|
|
|
|
}
|
|
|
|
|
|
|
|
let node = (
|
2022-11-29 13:14:06 +08:00
|
|
|
<button onClick={onClick} css={[style.btn]} key="lang-button">
|
|
|
|
<div className="btn-inner">
|
2022-11-30 11:05:41 +08:00
|
|
|
{pure && (value === 1 ? label1 : label2)}
|
|
|
|
{!pure && (
|
2022-11-29 13:14:06 +08:00
|
|
|
<div style={{ position: 'relative', width: BASE_SIZE, height: BASE_SIZE }}>
|
|
|
|
<span
|
|
|
|
style={{
|
|
|
|
...iconStyle,
|
|
|
|
...label1Style,
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
{label1}
|
|
|
|
</span>
|
|
|
|
<span
|
|
|
|
style={{
|
|
|
|
...iconStyle,
|
|
|
|
...label2Style,
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
{label2}
|
|
|
|
</span>
|
|
|
|
</div>
|
|
|
|
)}
|
|
|
|
</div>
|
|
|
|
</button>
|
2022-11-27 20:25:59 +08:00
|
|
|
);
|
|
|
|
|
|
|
|
if (tooltip1 || tooltip2) {
|
|
|
|
node = <Tooltip title={value === 1 ? tooltip1 : tooltip2}>{node}</Tooltip>;
|
|
|
|
}
|
|
|
|
|
|
|
|
return node;
|
|
|
|
}
|