diff --git a/src/locales/en.json b/src/locales/en.json index 68f6c528e..7a62d3ca4 100644 --- a/src/locales/en.json +++ b/src/locales/en.json @@ -1083,7 +1083,8 @@ "open_time": "First Channel", "update_time": "Last Update", "total_local_balance": "Local Balance", - "rpc_addr": "RPC Address" + "rpc_addr": "RPC Address", + "connect_id": "Connect" }, "channel": { "channel_id": "Channel ID", diff --git a/src/pages/Fiber/Peer/index.module.scss b/src/pages/Fiber/Peer/index.module.scss index 2aae9fdbe..9839c7629 100644 --- a/src/pages/Fiber/Peer/index.module.scss +++ b/src/pages/Fiber/Peer/index.module.scss @@ -70,7 +70,8 @@ } } - .id { + .id, + .connectId { overflow: hidden; & > span:first-child { diff --git a/src/pages/Fiber/Peer/index.tsx b/src/pages/Fiber/Peer/index.tsx index b474c791c..955db08de 100644 --- a/src/pages/Fiber/Peer/index.tsx +++ b/src/pages/Fiber/Peer/index.tsx @@ -1,7 +1,9 @@ +import { useEffect, useRef } from 'react' import { useTranslation } from 'react-i18next' import { Link, useParams } from 'react-router-dom' import { useQuery } from '@tanstack/react-query' import { CopyIcon, OpenInNewWindowIcon } from '@radix-ui/react-icons' +import QRCode from 'qrcode' import { Tooltip } from 'antd' import Content from '../../../components/Content' import { explorerService } from '../../../services/ExplorerService' @@ -12,6 +14,8 @@ import Loading from '../../../components/Loading' const Peer = () => { const [t] = useTranslation() const { id } = useParams<{ id: string }>() + const qrRef = useRef(null) + const setToast = useSetToast() const { data, isLoading } = useQuery({ @@ -21,14 +25,37 @@ const Peer = () => { }, enabled: !!id, }) + + const peer = data?.data + + const connectId = peer ? `${peer.peerId}@${peer.rpcListeningAddr}` : null + + useEffect(() => { + const cvs = qrRef.current + if (!cvs || !connectId) return + QRCode.toCanvas( + cvs, + connectId, + { + margin: 5, + errorCorrectionLevel: 'H', + width: 144, + }, + err => { + if (err) { + console.error(err) + } + }, + ) + }, [qrRef, connectId]) + if (isLoading) { return } - if (!data) { + if (!peer) { return
Fiber Peer Not Found
} - const peer = data.data const channels = peer.fiberChannels const handleCopy = (e: React.SyntheticEvent) => { @@ -68,6 +95,22 @@ const Peer = () => { +
+
{t('fiber.peer.connect_id')}
+
+ + {connectId} + + +
+
+ {connectId ? ( +
+ +
+ ) : null}
{t('fiber.peer.open_time')}