97 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
		
			3.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { getGetServerSideProps } from '@/api/ssrApollo'
 | |
| import { Form, ClientInput, ClientCheckbox, PasswordInput } from '@/components/form'
 | |
| import { CenterLayout } from '@/components/layout'
 | |
| import { WalletButtonBar } from '@/components/wallet-card'
 | |
| import { WalletSecurityBanner } from '@/components/banners'
 | |
| import { WalletLogs } from '@/components/wallet-logger'
 | |
| import { useToast } from '@/components/toast'
 | |
| import { useRouter } from 'next/router'
 | |
| import { useWallet, Status } from '@/components/wallet'
 | |
| 
 | |
| export const getServerSideProps = getGetServerSideProps({ authRequired: true })
 | |
| 
 | |
| export default function WalletSettings () {
 | |
|   const toaster = useToast()
 | |
|   const router = useRouter()
 | |
|   const { wallet: name } = router.query
 | |
|   const wallet = useWallet(name)
 | |
| 
 | |
|   const initial = wallet.fields.reduce((acc, field) => {
 | |
|     return {
 | |
|       ...acc,
 | |
|       [field.name]: wallet.config?.[field.name] || ''
 | |
|     }
 | |
|   }, {})
 | |
| 
 | |
|   return (
 | |
|     <CenterLayout>
 | |
|       <h2 className='pb-2'>{wallet.card.title}</h2>
 | |
|       <h6 className='text-muted text-center pb-3'>{wallet.card.subtitle}</h6>
 | |
|       <WalletSecurityBanner />
 | |
|       <Form
 | |
|         initial={initial}
 | |
|         schema={wallet.schema}
 | |
|         onSubmit={async ({ enabled, ...values }) => {
 | |
|           try {
 | |
|             const newConfig = !wallet.isConfigured
 | |
|             await wallet.validate(values)
 | |
|             wallet.save(values)
 | |
|             // enable wallet if checkbox was set or if wallet was just configured
 | |
|             if (enabled || newConfig) wallet.enable()
 | |
|             else wallet.disable()
 | |
|             toaster.success('saved settings')
 | |
|             router.push('/settings/wallets')
 | |
|           } catch (err) {
 | |
|             console.error(err)
 | |
|             const message = 'failed to attach: ' + err.message || err.toString?.()
 | |
|             toaster.danger(message)
 | |
|           }
 | |
|         }}
 | |
|       >
 | |
|         <WalletFields wallet={wallet} />
 | |
|         <ClientCheckbox
 | |
|           disabled={false}
 | |
|           initialValue={wallet.status === Status.Enabled}
 | |
|           label='enabled'
 | |
|           name='enabled'
 | |
|         />
 | |
|         <WalletButtonBar
 | |
|           wallet={wallet} onDelete={async () => {
 | |
|             try {
 | |
|               wallet.delete()
 | |
|               toaster.success('saved settings')
 | |
|               router.push('/settings/wallets')
 | |
|             } catch (err) {
 | |
|               console.error(err)
 | |
|               const message = 'failed to detach: ' + err.message || err.toString?.()
 | |
|               toaster.danger(message)
 | |
|             }
 | |
|           }}
 | |
|         />
 | |
|       </Form>
 | |
|       <div className='mt-3 w-100'>
 | |
|         <WalletLogs wallet={wallet} embedded />
 | |
|       </div>
 | |
|     </CenterLayout>
 | |
|   )
 | |
| }
 | |
| 
 | |
| function WalletFields ({ wallet: { config, fields } }) {
 | |
|   return fields.map(({ name, label, type }, i) => {
 | |
|     const props = {
 | |
|       initialValue: config?.[name],
 | |
|       label,
 | |
|       name,
 | |
|       required: true,
 | |
|       autoFocus: i === 0
 | |
|     }
 | |
|     if (type === 'text') {
 | |
|       return <ClientInput key={i} {...props} />
 | |
|     }
 | |
|     if (type === 'password') {
 | |
|       return <PasswordInput key={i} {...props} newPass />
 | |
|     }
 | |
|     return null
 | |
|   })
 | |
| }
 |