You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

90 lines
2.5 KiB

5 years ago
import React, {useState} from 'react';
import ContactForm from './ContactForm.jsx'
import styles from './styles'
import * as api from '../../api'
export default function ({contact,onSave,chats}){
const [edit, setEdit] = useState(false)
const [pay, setPay] = useState(false)
const [amount, setAmount] = useState(0)
const [paying, setPaying] = useState(false)
if (edit) {
return (
<li style={{background:'#eee',padding:10}}>
<ContactForm contact={contact} onSave={(id, values) => {
onSave(id, values)
setEdit(false)
}} onCancel={()=>setEdit(false)} />
</li>
)
}
function payButton() {
if(pay){
confirmPay()
} else {
setPay(true)
setAmount(0)
}
}
async function confirmPay() {
const amt = parseInt(amount)
console.log(chats)
console.log(contact)
const chatz = chats && chats.filter(c=> c.contact_ids.includes(parseInt(contact.id)))
console.log(chatz)
let chat
let n = 9999999
chatz && chatz.forEach(c=>{
if(c.contact_ids.length<n) {
n = c.contact_ids.length
chat = c // smallest for this user
}
})
console.log(chat)
if(!chat) return
setPaying(true)
if(window.testPurchaseMUID) {
await api.relay.POST('purchase',{
chat_id: chat.id,
contact_id: contact.id,
amount: amt,
muid: window.testPurchaseMUID
})
} else {
await api.relay.POST('payment',{
chat_id: chat.id,
contact_id: contact.id,
amount: amt,
})
}
setPay(false)
setPaying(false)
}
return <div style={styles.contact}>
<div>
<b>{contact.alias}</b> local_id: {contact.id}; remote_id: {contact.remote_id} <br />
<a style={{color:'blue'}}>{contact.public_key}</a><br/>
{contact.is_owner && <span className="ui label green">Is Node Owner</span>}
{contact.photo_url &&
<div>
<a href={contact.photo_url} target="_blank">{contact.photo_url}</a>
</div>
}
<a onClick={() => setEdit(true)}>Edit</a>
</div>
{!contact.is_owner && <div style={styles.payer}>
{pay && <div style={styles.x} onClick={()=>setPay(false)}>x</div>}
{pay && <input type="number" style={styles.input}
value={amount} onChange={e=> setAmount(e.target.value)}
/>}
<button style={styles.pay}
disabled={(pay && !amount) || paying}
onClick={payButton}>
{pay ? 'Confirm' : `Pay ${contact.alias}`}
</button>
</div>}
</div>
}