Jack Mallers
7 years ago
5 changed files with 136 additions and 5 deletions
@ -0,0 +1,44 @@ |
|||||
|
import { shell } from 'electron' |
||||
|
import React from 'react' |
||||
|
import PropTypes from 'prop-types' |
||||
|
import { btc } from 'utils' |
||||
|
import styles from './ChannelsList.scss' |
||||
|
|
||||
|
const ChannelsList = ({ channels }) => ( |
||||
|
<ul className={styles.channels}> |
||||
|
{ |
||||
|
channels.map((channel, index) => |
||||
|
<li key={index} className={styles.channel} onClick={() => console.log('channel clicked')}> |
||||
|
<span className={`${styles.dot}`} /> |
||||
|
|
||||
|
<header> |
||||
|
<h1>Capacity: {btc.satoshisToBtc(channel.capacity)}</h1> |
||||
|
<span onClick={() => shell.openExternal(`https://testnet.smartbit.com.au/tx/${channel.channel_point.split(':')[0]}`)}>Channel Point</span> |
||||
|
</header> |
||||
|
|
||||
|
<section> |
||||
|
<h4>Remote Pubkey:</h4> |
||||
|
<p>{channel.remote_pubkey.substring(0, Math.min(30, channel.remote_pubkey.length))}...</p> |
||||
|
</section> |
||||
|
|
||||
|
<section className={styles.funds}> |
||||
|
<div> |
||||
|
<h4>Sent:</h4> |
||||
|
<p>{btc.satoshisToBtc(channel.total_satoshis_sent)} BTC</p> |
||||
|
</div> |
||||
|
<div> |
||||
|
<h4>Received:</h4> |
||||
|
<p>{btc.satoshisToBtc(channel.total_satoshis_received)} BTC</p> |
||||
|
</div> |
||||
|
</section> |
||||
|
</li> |
||||
|
) |
||||
|
} |
||||
|
</ul> |
||||
|
) |
||||
|
|
||||
|
ChannelsList.propTypes = { |
||||
|
channels: PropTypes.array.isRequired |
||||
|
} |
||||
|
|
||||
|
export default ChannelsList |
@ -0,0 +1,78 @@ |
|||||
|
@import '../../variables.scss'; |
||||
|
|
||||
|
.channels { |
||||
|
color: $white; |
||||
|
margin-top: 50px; |
||||
|
} |
||||
|
|
||||
|
.channel { |
||||
|
position: relative; |
||||
|
margin: 20px 0; |
||||
|
padding: 10px 40px; |
||||
|
cursor: pointer; |
||||
|
transition: all 0.25s; |
||||
|
|
||||
|
&:hover { |
||||
|
background: darken(#353535, 10%); |
||||
|
|
||||
|
.dot { |
||||
|
background: #88D4A2; |
||||
|
opacity: 0.5; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
.dot { |
||||
|
position: absolute; |
||||
|
top: calc(15% - 10px); |
||||
|
left: 5%; |
||||
|
width: 10px; |
||||
|
height: 10px; |
||||
|
border: 1px solid #979797; |
||||
|
border-radius: 50%; |
||||
|
|
||||
|
&.active { |
||||
|
background: #88D4A2; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
header { |
||||
|
margin-bottom: 10px; |
||||
|
display: flex; |
||||
|
flex-direction: row; |
||||
|
justify-content: space-between; |
||||
|
|
||||
|
h1 { |
||||
|
margin-bottom: 10px; |
||||
|
} |
||||
|
|
||||
|
span { |
||||
|
font-size: 10px; |
||||
|
text-decoration: underline; |
||||
|
transition: all 0.25s; |
||||
|
|
||||
|
&:hover { |
||||
|
color: #88D4A2; |
||||
|
} |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
|
||||
|
section { |
||||
|
margin: 10px 0; |
||||
|
|
||||
|
h4 { |
||||
|
font-weight: bold; |
||||
|
text-transform: uppercase; |
||||
|
font-size: 10px; |
||||
|
margin-bottom: 5px; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
.funds { |
||||
|
display: flex; |
||||
|
flex-direction: row; |
||||
|
justify-content: space-between; |
||||
|
align-items: center; |
||||
|
margin-top: 20px; |
||||
|
} |
||||
|
} |
Loading…
Reference in new issue