stacker.news/components/item-act.js

65 lines
1.6 KiB
JavaScript
Raw Normal View History

import { Button, InputGroup } from 'react-bootstrap'
import React, { useState, useRef, useEffect } from 'react'
import { Form, Input, SubmitButton } from './form'
2021-09-12 11:55:38 -05:00
import { useMe } from './me'
2022-12-09 14:13:31 -06:00
import UpBolt from '../svgs/bolt.svg'
2023-02-08 13:38:04 -06:00
import { amountSchema } from '../lib/validate'
2021-09-10 13:55:36 -05:00
export default function ItemAct ({ onClose, itemId, act, strike }) {
2021-09-10 13:55:36 -05:00
const inputRef = useRef(null)
2021-09-12 11:55:38 -05:00
const me = useMe()
2022-12-09 14:13:31 -06:00
const [oValue, setOValue] = useState()
2021-09-10 13:55:36 -05:00
useEffect(() => {
inputRef.current?.focus()
}, [onClose, itemId])
2021-09-10 13:55:36 -05:00
return (
<Form
initial={{
amount: me?.tipDefault,
default: false
}}
2023-02-08 13:38:04 -06:00
schema={amountSchema}
onSubmit={async ({ amount }) => {
await act({
variables: {
id: itemId,
sats: Number(amount)
}
})
await strike()
onClose()
2021-09-10 13:55:36 -05:00
}}
>
<Input
label='amount'
name='amount'
innerRef={inputRef}
overrideValue={oValue}
required
autoFocus
append={<InputGroup.Text className='text-monospace'>sats</InputGroup.Text>}
/>
<div>
{[1, 10, 100, 1000, 10000].map(num =>
<Button
size='sm'
className={`${num > 1 ? 'ml-2' : ''} mb-2`}
key={num}
onClick={() => { setOValue(num) }}
>
<UpBolt
className='mr-1'
width={14}
height={14}
/>{num}
</Button>)}
</div>
<div className='d-flex'>
<SubmitButton variant='success' className='ml-auto mt-1 px-4' value='TIP'>tip</SubmitButton>
</div>
</Form>
2021-09-10 13:55:36 -05:00
)
}