import React, { useState, useCallback } from 'react'; import { Title, Wrapper, Container, InputText, Preview } from '../js/SharedStyles'; import styled from 'styled-components'; import { useTranslation } from '../js/i18n'; import SEO from './SEO'; const EncoderContainer = styled(Container)` flex-direction: column; `; const StyledInputText = styled(InputText)` height: 100px; margin-bottom: 20px; @media (min-width: 768px) { height: 100px; width: 100%; } `; const PreviewWrapper = styled.div` width: 100%; `; const Label = styled.label` font-weight: 500; font-size: 14px; color: #5f6368; margin-bottom: 8px; display: block; letter-spacing: 0.1px; `; const StyledPreview = styled(Preview)` background-color: #f8f9fa; padding: 12px 40px 12px 12px; // 增加右侧 padding 为按钮留出空间 border-radius: 8px; border: 1px solid #dadce0; font-size: 14px; color: #202124; min-height: 24px; // 确保即使内容为空,也有足够的高度容纳按钮 `; const ResultContainer = styled.div` position: relative; width: 100%; `; const CopyButton = styled.button` position: absolute; top: 8px; right: 8px; background-color: transparent; border: none; cursor: pointer; padding: 4px; display: flex; align-items: center; justify-content: center; opacity: 0.6; transition: opacity 0.3s, color 0.3s; &:hover { opacity: 1; } svg { width: 16px; height: 16px; } &.copied { color: #34a853; // 成功复制后的绿色反馈 } `; function UrlEncoder() { const { t } = useTranslation(); const [input, setInput] = useState(''); const [encodedText, setEncodedText] = useState(''); const [isCopied, setIsCopied] = useState(false); const handleInputChange = (e) => { const inputValue = e.target.value; setInput(inputValue); try { const encoded = encodeURIComponent(inputValue); setEncodedText(encoded); } catch (error) { setEncodedText('编码出错'); } }; const handleCopy = useCallback(() => { navigator.clipboard.writeText(encodedText).then(() => { setIsCopied(true); setTimeout(() => setIsCopied(false), 2000); }); }, [encodedText]); return ( <> {t('tools.urlEncode.title')} {encodedText} {isCopied ? ( ) : ( )} ); } export default UrlEncoder;