feat: 💨

This commit is contained in:
codytseng 2025-06-19 22:24:34 +08:00
parent f25b742877
commit a41ff092cd
13 changed files with 36 additions and 43 deletions

View file

@ -1,19 +1,18 @@
import { formatAmount, getAmountFromInvoice } from '@/lib/lightning' import { Button } from '@/components/ui/button'
import { cn } from '@/lib/utils'
import { useNostr } from '@/providers/NostrProvider'
import { useToast } from '@/hooks' import { useToast } from '@/hooks'
import { Loader, Zap } from 'lucide-react' import { formatAmount, getAmountFromInvoice } from '@/lib/lightning'
import { useNostr } from '@/providers/NostrProvider'
import lightning from '@/services/lightning.service' import lightning from '@/services/lightning.service'
import { Loader, Zap } from 'lucide-react'
import { useMemo, useState } from 'react' import { useMemo, useState } from 'react'
import { useTranslation } from 'react-i18next' import { useTranslation } from 'react-i18next'
import { Button } from '@/components/ui/button'
export function EmbeddedLNInvoice({ invoice }: { invoice: string }) { export function EmbeddedLNInvoice({ invoice }: { invoice: string }) {
const { t } = useTranslation() const { t } = useTranslation()
const { toast } = useToast() const { toast } = useToast()
const { checkLogin, pubkey } = useNostr() const { checkLogin, pubkey } = useNostr()
const [paying, setPaying] = useState(false) const [paying, setPaying] = useState(false)
const amount = useMemo(() => { const amount = useMemo(() => {
return getAmountFromInvoice(invoice) return getAmountFromInvoice(invoice)
}, [invoice]) }, [invoice])
@ -47,37 +46,19 @@ export function EmbeddedLNInvoice({ invoice }: { invoice: string }) {
return ( return (
<div <div
className={cn( className="p-2 sm:p-3 border rounded-lg cursor-default flex flex-col gap-3 max-w-sm"
'border rounded-lg p-4 bg-card text-card-foreground shadow-sm',
'flex flex-col gap-3 my-2 max-w-sm'
)}
onClick={(e) => e.stopPropagation()} onClick={(e) => e.stopPropagation()}
> >
<div className="flex items-center gap-2"> <div className="flex items-center gap-2">
<Zap className="w-5 h-5 text-yellow-500" /> <Zap className="w-5 h-5 text-yellow-400" />
<h3 className="font-semibold text-sm">Lightning Invoice</h3> <div className="font-semibold text-sm">{t('Lightning Invoice')}</div>
</div> </div>
<div className="text-lg font-bold"> <div className="text-lg font-bold">
{formatAmount(amount)} {formatAmount(amount)} {t('sats')}
</div> </div>
<Button <Button onClick={handlePayClick}>
className={cn( {paying && <Loader className="w-4 h-4 animate-spin" />}
'w-full px-4 py-2 rounded-md font-medium text-sm', {t('Pay')}
'bg-purple-600 hover:bg-purple-700 text-white',
'disabled:opacity-50 disabled:cursor-not-allowed',
'transition-colors duration-200',
'flex items-center justify-center gap-2'
)}
onClick={handlePayClick}
>
{paying ? (
<>
<Loader className="w-4 h-4 animate-spin" />
Paying...
</>
) : (
'Pay'
)}
</Button> </Button>
</div> </div>
) )

View file

@ -239,6 +239,7 @@ export default {
'Followed by': 'متابع من قبل', 'Followed by': 'متابع من قبل',
'Mute user privately': 'كتم المستخدم بشكل خاص', 'Mute user privately': 'كتم المستخدم بشكل خاص',
'Mute user publicly': 'كتم المستخدم علنياً', 'Mute user publicly': 'كتم المستخدم علنياً',
Quotes: 'الاقتباسات' Quotes: 'الاقتباسات',
'Lightning Invoice': 'فاتورة Lightning'
} }
} }

View file

@ -246,6 +246,7 @@ export default {
'Followed by': 'Gefolgt von', 'Followed by': 'Gefolgt von',
'Mute user privately': 'Benutzer privat stummschalten', 'Mute user privately': 'Benutzer privat stummschalten',
'Mute user publicly': 'Benutzer öffentlich stummschalten', 'Mute user publicly': 'Benutzer öffentlich stummschalten',
Quotes: 'Zitate' Quotes: 'Zitate',
'Lightning Invoice': 'Lightning-Rechnung'
} }
} }

View file

@ -239,6 +239,7 @@ export default {
'Followed by': 'Followed by', 'Followed by': 'Followed by',
'Mute user privately': 'Mute user privately', 'Mute user privately': 'Mute user privately',
'Mute user publicly': 'Mute user publicly', 'Mute user publicly': 'Mute user publicly',
Quotes: 'Quotes' Quotes: 'Quotes',
'Lightning Invoice': 'Lightning Invoice'
} }
} }

View file

@ -244,6 +244,7 @@ export default {
'Followed by': 'Seguidos por', 'Followed by': 'Seguidos por',
'Mute user privately': 'Silenciar usuario en privado', 'Mute user privately': 'Silenciar usuario en privado',
'Mute user publicly': 'Silenciar usuario públicamente', 'Mute user publicly': 'Silenciar usuario públicamente',
Quotes: 'Citas' Quotes: 'Citas',
'Lightning Invoice': 'Factura Lightning'
} }
} }

View file

@ -244,6 +244,7 @@ export default {
'Followed by': 'Suivi par', 'Followed by': 'Suivi par',
'Mute user privately': 'Mettre lutilisateur en sourdine en privé', 'Mute user privately': 'Mettre lutilisateur en sourdine en privé',
'Mute user publicly': 'Mettre lutilisateur en sourdine publiquement', 'Mute user publicly': 'Mettre lutilisateur en sourdine publiquement',
Quotes: 'Citations' Quotes: 'Citations',
'Lightning Invoice': 'Facture Lightning'
} }
} }

View file

@ -243,6 +243,7 @@ export default {
'Followed by': 'Seguito da', 'Followed by': 'Seguito da',
'Mute user privately': 'Zittisci utente privatamente', 'Mute user privately': 'Zittisci utente privatamente',
'Mute user publicly': 'Zittisci utente pubblicamente', 'Mute user publicly': 'Zittisci utente pubblicamente',
Quotes: 'Citazioni' Quotes: 'Citazioni',
'Lightning Invoice': 'Fattura Lightning'
} }
} }

View file

@ -240,6 +240,7 @@ export default {
'Followed by': 'フォロワー', 'Followed by': 'フォロワー',
'Mute user privately': 'ユーザーを非公開でミュート', 'Mute user privately': 'ユーザーを非公開でミュート',
'Mute user publicly': 'ユーザーを公開でミュート', 'Mute user publicly': 'ユーザーを公開でミュート',
Quotes: '引用' Quotes: '引用',
'Lightning Invoice': 'ライトニングインボイス'
} }
} }

View file

@ -242,6 +242,7 @@ export default {
'Followed by': 'Obserwowany przez', 'Followed by': 'Obserwowany przez',
'Mute user privately': 'Zablokuj użytkownika prywatnie', 'Mute user privately': 'Zablokuj użytkownika prywatnie',
'Mute user publicly': 'Zablokuj użytkownika publicznie', 'Mute user publicly': 'Zablokuj użytkownika publicznie',
Quotes: 'Cytaty' Quotes: 'Cytaty',
'Lightning Invoice': 'Faktura Lightning'
} }
} }

View file

@ -242,6 +242,7 @@ export default {
'Followed by': 'Seguido por', 'Followed by': 'Seguido por',
'Mute user privately': 'Silenciar usuário privadamente', 'Mute user privately': 'Silenciar usuário privadamente',
'Mute user publicly': 'Silenciar usuário publicamente', 'Mute user publicly': 'Silenciar usuário publicamente',
Quotes: 'Citações' Quotes: 'Citações',
'Lightning Invoice': 'Fatura Lightning'
} }
} }

View file

@ -243,6 +243,7 @@ export default {
'Followed by': 'Seguido por', 'Followed by': 'Seguido por',
'Mute user privately': 'Silenciar usuário privadamente', 'Mute user privately': 'Silenciar usuário privadamente',
'Mute user publicly': 'Silenciar usuário publicamente', 'Mute user publicly': 'Silenciar usuário publicamente',
Quotes: 'Citações' Quotes: 'Citações',
'Lightning Invoice': 'Fatura Lightning'
} }
} }

View file

@ -244,6 +244,7 @@ export default {
'Followed by': 'Подписан на', 'Followed by': 'Подписан на',
'Mute user privately': 'Заглушить пользователя приватно', 'Mute user privately': 'Заглушить пользователя приватно',
'Mute user publicly': 'Заглушить пользователя публично', 'Mute user publicly': 'Заглушить пользователя публично',
Quotes: 'Цитаты' Quotes: 'Цитаты',
'Lightning Invoice': 'Lightning-счет'
} }
} }

View file

@ -240,6 +240,7 @@ export default {
'Followed by': '关注者', 'Followed by': '关注者',
'Mute user privately': '悄悄屏蔽', 'Mute user privately': '悄悄屏蔽',
'Mute user publicly': '公开屏蔽', 'Mute user publicly': '公开屏蔽',
Quotes: '引用' Quotes: '引用',
'Lightning Invoice': '闪电发票'
} }
} }