Browse Source

fix(channel): display open channels and tweak channel design

renovate/lint-staged-8.x
Jack Mallers 7 years ago
parent
commit
8eb2cb2ed3
  1. 21
      app/components/Channels/Channel.js
  2. 36
      app/components/Channels/Channel.scss
  3. 29
      app/routes/channels/components/Channels.js
  4. 4
      app/routes/channels/components/Channels.scss
  5. 10
      app/routes/channels/containers/ChannelsContainer.js

21
app/components/Channels/Channel.js

@ -1,11 +1,26 @@
import React from 'react' import React from 'react'
import PropTypes from 'prop-types' import PropTypes from 'prop-types'
import { FaCircle } from 'react-icons/lib/fa'
import { btc } from 'utils' import { btc } from 'utils'
import styles from './Channel.scss' import styles from './Channel.scss'
const Channel = ({ ticker, channel, setChannel, currentTicker }) => ( const Channel = ({ ticker, channel, setChannel, currentTicker }) => (
<li className={styles.channel} onClick={() => setChannel(channel)}> <li className={styles.channel} onClick={() => setChannel(channel)}>
<h1 className={styles.status}>Status: Open</h1> <header>
<span className={styles.status}>Open</span>
{
channel.active ?
<span className={styles.active}>
<FaCircle />
<i>Active</i>
</span>
:
<span className={styles.notactive}>
<FaCircle />
<i>Not Active</i>
</span>
}
</header>
<div className={styles.left}> <div className={styles.left}>
<section className={styles.remotePubkey}> <section className={styles.remotePubkey}>
<span>Remote Pubkey</span> <span>Remote Pubkey</span>
@ -30,6 +45,7 @@ const Channel = ({ ticker, channel, setChannel, currentTicker }) => (
</section> </section>
<div className={styles.balances}> <div className={styles.balances}>
<section> <section>
<span>Local</span>
<h4> <h4>
{ {
ticker.currency === 'btc' ? ticker.currency === 'btc' ?
@ -38,9 +54,9 @@ const Channel = ({ ticker, channel, setChannel, currentTicker }) => (
btc.satoshisToUsd(channel.local_balance, currentTicker.price_usd) btc.satoshisToUsd(channel.local_balance, currentTicker.price_usd)
} }
</h4> </h4>
<span>Local</span>
</section> </section>
<section> <section>
<span>Remote</span>
<h4> <h4>
{ {
ticker.currency === 'btc' ? ticker.currency === 'btc' ?
@ -49,7 +65,6 @@ const Channel = ({ ticker, channel, setChannel, currentTicker }) => (
btc.satoshisToUsd(channel.remote_balance, currentTicker.price_usd) btc.satoshisToUsd(channel.remote_balance, currentTicker.price_usd)
} }
</h4> </h4>
<span>Remote</span>
</section> </section>
</div> </div>
</div> </div>

36
app/components/Channels/Channel.scss

@ -2,12 +2,13 @@
.channel { .channel {
position: relative; position: relative;
background: $white; background: $lightgrey;
margin: 5px 0;
padding: 10px; padding: 10px;
display: flex; display: flex;
flex-direction: row; flex-direction: row;
justify-content: space-between; justify-content: space-between;
border-top: 1px solid $grey; border-top: 1px solid $white;
cursor: pointer; cursor: pointer;
transition: all 0.25s; transition: all 0.25s;
@ -19,17 +20,36 @@
border: none; border: none;
} }
.status { header {
color: $main;
position: absolute; position: absolute;
top: 0; top: 10px;
left: 10px; left: 10px;
.status, .active, .notactive {
padding: 10px; padding: 10px;
text-transform: uppercase; text-transform: uppercase;
font-weight: bold; font-weight: bold;
font-size: 10px; font-size: 10px;
} }
.status {
color: $main;
}
.active i, .notactive i {
margin-left: 5px;
}
.active {
color: $green;
}
.notactive {
color: $red;
}
}
.left, .right { .left, .right {
padding: 0 10px; padding: 0 10px;
margin-bottom: 5; margin-bottom: 5;
@ -60,7 +80,6 @@
.left { .left {
flex: 7; flex: 7;
border-right: 1px solid $grey;
} }
.right { .right {
@ -68,7 +87,6 @@
.capacity { .capacity {
text-align: center; text-align: center;
border-bottom: 1px solid $grey;
margin-bottom: 10px; margin-bottom: 10px;
} }
@ -84,10 +102,6 @@
color: $main; color: $main;
font-size: 16px; font-size: 16px;
} }
&:first-child {
border-right: 1px solid $grey;
}
} }
} }
} }

29
app/routes/channels/components/Channels.js

@ -1,7 +1,11 @@
import React, { Component } from 'react' import React, { Component } from 'react'
import PropTypes from 'prop-types' import PropTypes from 'prop-types'
import { FaAlignJustify, FaThLarge } from 'react-icons/lib/fa' import { FaAlignJustify, FaThLarge } from 'react-icons/lib/fa'
import { MdSearch } from 'react-icons/lib/md' import { MdSearch } from 'react-icons/lib/md'
import Channel from 'components/Channels/Channel'
import styles from './Channels.scss' import styles from './Channels.scss'
class Channels extends Component { class Channels extends Component {
@ -11,8 +15,13 @@ class Channels extends Component {
render() { render() {
const { const {
channels channels: { channels },
allChannels,
ticker,
currentTicker
} = this.props } = this.props
console.log('channels: ', channels)
return ( return (
<div className={styles.container}> <div className={styles.container}>
@ -46,7 +55,23 @@ class Channels extends Component {
</header> </header>
<div className={styles.channels}> <div className={styles.channels}>
channels <ul>
{
allChannels.map((channel, index) => {
console.log('channel: ', channel)
return (
<Channel
key={index}
ticker={ticker}
channel={channel}
setChannel={() => console.log('hi')}
currentTicker={currentTicker}
/>
)
})
}
</ul>
</div> </div>
</div> </div>
) )

4
app/routes/channels/components/Channels.scss

@ -66,3 +66,7 @@
.createChannelContainer { .createChannelContainer {
padding: 40px; padding: 40px;
} }
.channels {
padding: 10px 40px 40px 40px;
}

10
app/routes/channels/containers/ChannelsContainer.js

@ -3,8 +3,12 @@ import { connect } from 'react-redux'
import { import {
fetchChannels, fetchChannels,
channelsSelectors
} from 'reducers/channels' } from 'reducers/channels'
import { tickerSelectors } from 'reducers/ticker'
import Channels from '../components/Channels' import Channels from '../components/Channels'
const mapDispatchToProps = { const mapDispatchToProps = {
@ -12,7 +16,11 @@ const mapDispatchToProps = {
} }
const mapStateToProps = state => ({ const mapStateToProps = state => ({
channels: state.channels channels: state.channels,
ticker: state.ticker,
allChannels: channelsSelectors.allChannels(state),
currentTicker: tickerSelectors.currentTicker(state)
}) })
export default withRouter(connect(mapStateToProps, mapDispatchToProps)(Channels)) export default withRouter(connect(mapStateToProps, mapDispatchToProps)(Channels))

Loading…
Cancel
Save