wallet code + some finer touches on header + nav
This commit is contained in:
parent
0d2775138a
commit
a36f0f2691
13 changed files with 132 additions and 79 deletions
|
@ -9,7 +9,7 @@ var App = React.createClass({
|
||||||
if (param && ['settings', 'help', 'start', 'watch', 'report', 'files', 'claim', 'show', 'wallet', 'publish'].indexOf(param) != -1) {
|
if (param && ['settings', 'help', 'start', 'watch', 'report', 'files', 'claim', 'show', 'wallet', 'publish'].indexOf(param) != -1) {
|
||||||
viewingPage = param;
|
viewingPage = param;
|
||||||
}
|
}
|
||||||
|
|
||||||
return {
|
return {
|
||||||
viewingPage: viewingPage ? viewingPage : 'home',
|
viewingPage: viewingPage ? viewingPage : 'home',
|
||||||
drawerOpen: drawerOpenRaw !== null ? JSON.parse(drawerOpenRaw) : true,
|
drawerOpen: drawerOpenRaw !== null ? JSON.parse(drawerOpenRaw) : true,
|
||||||
|
|
|
@ -61,6 +61,10 @@ var creditAmountStyle = {
|
||||||
color: '#aaa',
|
color: '#aaa',
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var CurrencySymbol = React.createClass({
|
||||||
|
render: function() { return <span>LBC</span>; }
|
||||||
|
});
|
||||||
|
|
||||||
var CreditAmount = React.createClass({
|
var CreditAmount = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
amount: React.PropTypes.number,
|
amount: React.PropTypes.number,
|
||||||
|
|
|
@ -32,7 +32,7 @@ var Drawer = React.createClass({
|
||||||
<DrawerItem href='/?home' viewingPage={this.props.viewingPage} label="Discover" icon="icon-search" />
|
<DrawerItem href='/?home' viewingPage={this.props.viewingPage} label="Discover" icon="icon-search" />
|
||||||
<DrawerItem href='/?publish' viewingPage={this.props.viewingPage} label="Publish" icon="icon-upload" />
|
<DrawerItem href='/?publish' viewingPage={this.props.viewingPage} label="Publish" icon="icon-upload" />
|
||||||
<DrawerItem href='/?files' viewingPage={this.props.viewingPage} label="My Files" icon='icon-cloud-download' />
|
<DrawerItem href='/?files' viewingPage={this.props.viewingPage} label="My Files" icon='icon-cloud-download' />
|
||||||
<DrawerItem href="/?wallet" viewingPage={this.props.viewingPage} label={ lbry.formatCredits(this.state.balance) } icon="icon-bank" />
|
<DrawerItem href="/?wallet" viewingPage={this.props.viewingPage} label="My Wallet" badge={lbry.formatCredits(this.state.balance) } icon="icon-bank" />
|
||||||
<DrawerItem href='/?settings' viewingPage={this.props.viewingPage} label="Settings" icon='icon-gear' />
|
<DrawerItem href='/?settings' viewingPage={this.props.viewingPage} label="Settings" icon='icon-gear' />
|
||||||
<DrawerItem href='/?help' viewingPage={this.props.viewingPage} label="Help" icon='icon-question-circle' />
|
<DrawerItem href='/?help' viewingPage={this.props.viewingPage} label="Help" icon='icon-question-circle' />
|
||||||
</nav>
|
</nav>
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
var Header = React.createClass({
|
var Header = React.createClass({
|
||||||
getInitialState: function() {
|
getInitialState: function() {
|
||||||
return {
|
return {
|
||||||
title: "LBRY"
|
title: "LBRY",
|
||||||
|
isScrolled: false
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
componentWillMount: function() {
|
componentWillMount: function() {
|
||||||
|
@ -12,10 +13,21 @@ var Header = React.createClass({
|
||||||
{ subtree: true, characterData: true, childList: true }
|
{ subtree: true, characterData: true, childList: true }
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
|
componentDidMount() {
|
||||||
|
document.addEventListener('scroll', this.handleScroll);
|
||||||
|
},
|
||||||
|
componentWillUnmount() {
|
||||||
|
document.removeEventListener('scroll', this.handleScroll);
|
||||||
|
},
|
||||||
|
handleScroll() {
|
||||||
|
this.setState({
|
||||||
|
isScrolled: event.srcElement.body.scrollTop > 0
|
||||||
|
});
|
||||||
|
},
|
||||||
render: function() {
|
render: function() {
|
||||||
var isLinux = /linux/i.test(navigator.userAgent); // @TODO: find a way to use getVersionInfo() here without messy state management
|
var isLinux = /linux/i.test(navigator.userAgent); // @TODO: find a way to use getVersionInfo() here without messy state management
|
||||||
return (
|
return (
|
||||||
<header id="header">
|
<header id="header" className={this.state.isScrolled ? 'header-scrolled' : 'header-unscrolled'}>
|
||||||
<Link onClick={this.props.onOpenDrawer} icon="icon-bars" className="open-drawer-link" />
|
<Link onClick={this.props.onOpenDrawer} icon="icon-bars" className="open-drawer-link" />
|
||||||
{isLinux ? <Link href="/?start" icon="icon-close" className="close-lbry-link" /> : null}
|
{isLinux ? <Link href="/?start" icon="icon-close" className="close-lbry-link" /> : null}
|
||||||
<h1>{ this.state.title }</h1>
|
<h1>{ this.state.title }</h1>
|
||||||
|
|
|
@ -16,7 +16,8 @@ var Link = React.createClass({
|
||||||
<a className={className ? className : 'button-text'} href={href} style={this.props.style ? this.props.style : {}}
|
<a className={className ? className : 'button-text'} href={href} style={this.props.style ? this.props.style : {}}
|
||||||
title={this.props.title} onClick={this.handleClick}>
|
title={this.props.title} onClick={this.handleClick}>
|
||||||
{this.props.icon ? icon : '' }
|
{this.props.icon ? icon : '' }
|
||||||
{this.props.label}
|
<span className="link-label">{this.props.label}</span>
|
||||||
|
{this.props.badge ? <span className="badge">{this.props.badge}</span> : '' }
|
||||||
</a>
|
</a>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -72,17 +73,6 @@ var ToolTipLink = React.createClass({
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
var ReturnLink = React.createClass({
|
|
||||||
render: function() {
|
|
||||||
return <div style={ { padding: '24px 0' } }><Link
|
|
||||||
href={this.props.href ? this.props.href : '/'}
|
|
||||||
icon="icon-chevron-left"
|
|
||||||
label={this.props.label ? this.props.label : 'Return'}
|
|
||||||
/></div>;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
var DownloadLink = React.createClass({
|
var DownloadLink = React.createClass({
|
||||||
propTypes: {
|
propTypes: {
|
||||||
type: React.PropTypes.string,
|
type: React.PropTypes.string,
|
||||||
|
|
|
@ -1,6 +1,4 @@
|
||||||
var claimCodePageStyle = {
|
var claimCodeContentStyle = {
|
||||||
textAlign: 'center',
|
|
||||||
}, claimCodeContentStyle = {
|
|
||||||
display: 'inline-block',
|
display: 'inline-block',
|
||||||
textAlign: 'left',
|
textAlign: 'left',
|
||||||
width: '600px',
|
width: '600px',
|
||||||
|
@ -72,24 +70,26 @@ var ClaimCodePage = React.createClass({
|
||||||
},
|
},
|
||||||
render: function() {
|
render: function() {
|
||||||
return (
|
return (
|
||||||
<main className="page" style={claimCodePageStyle}>
|
<main>
|
||||||
<h1>Claim your beta invitation code</h1>
|
<div className="card">
|
||||||
<section style={claimCodeContentStyle}>
|
<h2>Claim your beta invitation code</h2>
|
||||||
<p>Thanks for beta testing LBRY! Enter your invitation code and email address below to receive your initial
|
<section style={claimCodeContentStyle}>
|
||||||
LBRY credits.</p>
|
<p>Thanks for beta testing LBRY! Enter your invitation code and email address below to receive your initial
|
||||||
<p>You will be added to our mailing list (if you're not already on it) and will be eligible for future rewards for beta testers.</p>
|
LBRY credits.</p>
|
||||||
</section>
|
<p>You will be added to our mailing list (if you're not already on it) and will be eligible for future rewards for beta testers.</p>
|
||||||
<section>
|
</section>
|
||||||
<form onSubmit={this.handleSubmit}>
|
<section>
|
||||||
<section><label style={claimCodeLabelStyle} htmlFor="code">Invitation code</label><input name="code" ref="code" /></section>
|
<form onSubmit={this.handleSubmit}>
|
||||||
<section><label style={claimCodeLabelStyle} htmlFor="email">Email</label><input name="email" ref="email" /></section>
|
<section><label style={claimCodeLabelStyle} htmlFor="code">Invitation code</label><input name="code" ref="code" /></section>
|
||||||
</form>
|
<section><label style={claimCodeLabelStyle} htmlFor="email">Email</label><input name="email" ref="email" /></section>
|
||||||
</section>
|
</form>
|
||||||
<section>
|
</section>
|
||||||
<Link button="primary" label={this.state.submitting ? "Submitting..." : "Submit"}
|
<section>
|
||||||
disabled={this.state.submitting} onClick={this.handleSubmit} />
|
<Link button="primary" label={this.state.submitting ? "Submitting..." : "Submit"}
|
||||||
<Link button="alt" label="Skip" disabled={this.state.submitting} onClick={this.handleSkip} />
|
disabled={this.state.submitting} onClick={this.handleSubmit} />
|
||||||
</section>
|
<Link button="alt" label="Skip" disabled={this.state.submitting} onClick={this.handleSkip} />
|
||||||
|
</section>
|
||||||
|
</div>
|
||||||
</main>
|
</main>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -191,9 +191,6 @@ var MyFilesPage = React.createClass({
|
||||||
<section>
|
<section>
|
||||||
{content}
|
{content}
|
||||||
</section>
|
</section>
|
||||||
<section>
|
|
||||||
<ReturnLink />
|
|
||||||
</section>
|
|
||||||
</main>
|
</main>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
|
@ -78,13 +78,13 @@ var SettingsPage = React.createClass({
|
||||||
return (
|
return (
|
||||||
<main>
|
<main>
|
||||||
<section className="card">
|
<section className="card">
|
||||||
<h3>Run on startup</h3>
|
<h3>Run on Startup</h3>
|
||||||
<label style={settingsCheckBoxOptionStyles}>
|
<label style={settingsCheckBoxOptionStyles}>
|
||||||
<input type="checkbox" onChange={this.onRunOnStartChange} defaultChecked={this.state.settings.run_on_startup} /> Run LBRY automatically when I start my computer
|
<input type="checkbox" onChange={this.onRunOnStartChange} defaultChecked={this.state.settings.run_on_startup} /> Run LBRY automatically when I start my computer
|
||||||
</label>
|
</label>
|
||||||
</section>
|
</section>
|
||||||
<section className="card">
|
<section className="card">
|
||||||
<h3>Download directory</h3>
|
<h3>Download Directory</h3>
|
||||||
<div className="help">Where would you like the files you download from LBRY to be saved?</div>
|
<div className="help">Where would you like the files you download from LBRY to be saved?</div>
|
||||||
<input style={downloadDirectoryFieldStyles} type="text" name="download_directory" defaultValue={this.state.settings.download_directory} onChange={this.onDownloadDirChange}/>
|
<input style={downloadDirectoryFieldStyles} type="text" name="download_directory" defaultValue={this.state.settings.download_directory} onChange={this.onDownloadDirChange}/>
|
||||||
</section>
|
</section>
|
||||||
|
@ -108,7 +108,7 @@ var SettingsPage = React.createClass({
|
||||||
</label>
|
</label>
|
||||||
</section>
|
</section>
|
||||||
<section className="card">
|
<section className="card">
|
||||||
<h3>Share diagnostic data</h3>
|
<h3>Share Diagnostic Data</h3>
|
||||||
<label style={settingsCheckBoxOptionStyles}>
|
<label style={settingsCheckBoxOptionStyles}>
|
||||||
<input type="checkbox" onChange={this.onShareDataChange} defaultChecked={this.state.settings.upload_log} /> Help make LBRY better by contributing diagnostic data about my usage
|
<input type="checkbox" onChange={this.onShareDataChange} defaultChecked={this.state.settings.upload_log} /> Help make LBRY better by contributing diagnostic data about my usage
|
||||||
</label>
|
</label>
|
||||||
|
|
|
@ -142,9 +142,6 @@ var DetailPage = React.createClass({
|
||||||
return (
|
return (
|
||||||
<main className="page">
|
<main className="page">
|
||||||
<FormatsSection name={name} claimInfo={claimInfo} amount={amount} />
|
<FormatsSection name={name} claimInfo={claimInfo} amount={amount} />
|
||||||
<section>
|
|
||||||
<ReturnLink />
|
|
||||||
</section>
|
|
||||||
</main>);
|
</main>);
|
||||||
}
|
}
|
||||||
});
|
});
|
|
@ -13,8 +13,8 @@ var NewAddressSection = React.createClass({
|
||||||
},
|
},
|
||||||
render: function() {
|
render: function() {
|
||||||
return (
|
return (
|
||||||
<section>
|
<section className="card">
|
||||||
<h1>Generate New Address</h1>
|
<h3>Generate New Address</h3>
|
||||||
<section><input type="text" size="60" value={this.state.address}></input></section>
|
<section><input type="text" size="60" value={this.state.address}></input></section>
|
||||||
<Link button="primary" label="Generate" onClick={this.generateAddress} />
|
<Link button="primary" label="Generate" onClick={this.generateAddress} />
|
||||||
</section>
|
</section>
|
||||||
|
@ -80,35 +80,57 @@ var SendToAddressSection = React.createClass({
|
||||||
},
|
},
|
||||||
render: function() {
|
render: function() {
|
||||||
return (
|
return (
|
||||||
<section>
|
<section className="card">
|
||||||
<h1>Send Credits</h1>
|
<h3>Send Credits</h3>
|
||||||
<section>
|
<section>
|
||||||
<section><label for="balance">Balance {this.state.balance}</label></section>
|
<label htmlFor="amount">Amount <input id="amount" type="text" size="10" onChange={this.setAmount}></input></label>
|
||||||
<label for="amount">Amount <input id="amount" type="text" size="10" onChange={this.setAmount}></input></label>
|
<label htmlFor="address">Recipient address <input id="address" type="text" size="60" onChange={this.setAddress}></input></label>
|
||||||
<label for="address">Recipient address <input id="address" type="text" size="60" onChange={this.setAddress}></input></label>
|
|
||||||
<Link button="primary" label="Send" onClick={this.sendToAddress} disabled={!(parseFloat(this.state.amount) > 0.0) || this.state.address == ""} />
|
<Link button="primary" label="Send" onClick={this.sendToAddress} disabled={!(parseFloat(this.state.amount) > 0.0) || this.state.address == ""} />
|
||||||
</section>
|
</section>
|
||||||
<section className={!this.state.results ? 'hidden' : ''}>
|
{
|
||||||
<h4>Results:</h4>
|
this.state.results ?
|
||||||
{this.state.results}
|
<section>
|
||||||
</section>
|
<h4>Results</h4>
|
||||||
</section>
|
{this.state.results}
|
||||||
|
</section>
|
||||||
|
: ''
|
||||||
|
}
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
var WalletPage = React.createClass({
|
var WalletPage = React.createClass({
|
||||||
|
componentDidMount: function() {
|
||||||
|
document.title = "My Wallet";
|
||||||
|
},
|
||||||
|
/*
|
||||||
|
Below should be refactored so that balance is shared all of wallet page. Or even broader?
|
||||||
|
What is the proper React pattern for sharing a global state like balance?
|
||||||
|
*/
|
||||||
|
getInitialState: function() {
|
||||||
|
return {
|
||||||
|
balance: "Checking balance...",
|
||||||
|
}
|
||||||
|
},
|
||||||
|
componentWillMount: function() {
|
||||||
|
lbry.getBalance((results) => {
|
||||||
|
this.setState({
|
||||||
|
balance: results,
|
||||||
|
});
|
||||||
|
});
|
||||||
|
},
|
||||||
render: function() {
|
render: function() {
|
||||||
return (
|
return (
|
||||||
<main className="page">
|
<main className="page">
|
||||||
<NewAddressSection />
|
<section className="card">
|
||||||
<SendToAddressSection />
|
<h3>Balance</h3>
|
||||||
<section>
|
{this.state.balance} <CurrencySymbol />
|
||||||
<h4>Claim invite code</h4>
|
|
||||||
<Link href="?claim" label="Claim a LBRY beta invite code"/>
|
|
||||||
</section>
|
</section>
|
||||||
<section>
|
<SendToAddressSection />
|
||||||
<ReturnLink />
|
<NewAddressSection />
|
||||||
|
<section className="card">
|
||||||
|
<h3>Claim Invite Code</h3>
|
||||||
|
<Link href="?claim" label="Claim a LBRY beta invite code" button="alt" />
|
||||||
</section>
|
</section>
|
||||||
</main>
|
</main>
|
||||||
);
|
);
|
||||||
|
|
|
@ -9,41 +9,54 @@ body
|
||||||
{
|
{
|
||||||
font-family: 'Source Sans Pro', sans-serif;
|
font-family: 'Source Sans Pro', sans-serif;
|
||||||
line-height: 1.3333;
|
line-height: 1.3333;
|
||||||
min-height: 100%;
|
|
||||||
position: relative;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#window
|
$drawer-width: 240px;
|
||||||
{
|
|
||||||
position: relative;
|
|
||||||
}
|
|
||||||
|
|
||||||
#drawer
|
#drawer
|
||||||
{
|
{
|
||||||
width: 240px;
|
width: $drawer-width;
|
||||||
position: absolute;
|
position: absolute;
|
||||||
min-height: 100vh;
|
min-height: 100vh;
|
||||||
left: 0;
|
left: 0;
|
||||||
top: 0;
|
top: 0;
|
||||||
|
background: $color-bg;
|
||||||
|
z-index: 1;
|
||||||
.drawer-item
|
.drawer-item
|
||||||
{
|
{
|
||||||
display: block;
|
display: block;
|
||||||
padding: $spacing-vertical / 2;
|
padding: $spacing-vertical / 2;
|
||||||
font-size: 1.2em;
|
font-size: 1.2em;
|
||||||
|
height: $spacing-vertical * 1.5;
|
||||||
.icon
|
.icon
|
||||||
{
|
{
|
||||||
margin-right: 6px;
|
margin-right: 6px;
|
||||||
}
|
}
|
||||||
|
.link-label
|
||||||
|
{
|
||||||
|
line-height: $spacing-vertical * 1.5;
|
||||||
|
}
|
||||||
|
.badge
|
||||||
|
{
|
||||||
|
float: right;
|
||||||
|
background: $color-money;
|
||||||
|
display: inline-block;
|
||||||
|
padding: 2px;
|
||||||
|
color: white;
|
||||||
|
margin-top: $spacing-vertical * 0.25 - 2;
|
||||||
|
border-radius: 2px;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
.drawer-item-selected
|
.drawer-item-selected
|
||||||
{
|
{
|
||||||
background: $color-canvas;
|
background: $color-canvas;
|
||||||
|
color: $color-primary;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#drawer-handle
|
#drawer-handle
|
||||||
{
|
{
|
||||||
padding: $spacing-vertical / 2;
|
padding: $spacing-vertical / 2;
|
||||||
max-height: $header-height;
|
max-height: $header-height - $spacing-vertical;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,7 +66,7 @@ body
|
||||||
}
|
}
|
||||||
#window.drawer-open
|
#window.drawer-open
|
||||||
{
|
{
|
||||||
#main-content { margin-left: 240px; }
|
#main-content { margin-left: $drawer-width; }
|
||||||
.open-drawer-link { display: none; }
|
.open-drawer-link { display: none; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,16 +75,26 @@ body
|
||||||
background: $color-primary;
|
background: $color-primary;
|
||||||
color: white;
|
color: white;
|
||||||
height: $header-height;
|
height: $header-height;
|
||||||
padding: $spacing-vertical / 2;
|
padding: $spacing-vertical / 2 $spacing-vertical / 2 $spacing-vertical / 2 $drawer-width + $spacing-vertical / 2;
|
||||||
h1 { font-size: 1.8em; line-height: $header-height; }
|
position: fixed;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 100%;
|
||||||
|
box-sizing: border-box;
|
||||||
|
h1 { font-size: 1.8em; line-height: $header-height - $spacing-vertical; }
|
||||||
|
&.header-scrolled
|
||||||
|
{
|
||||||
|
box-shadow: $default-box-shadow;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#main-content
|
#main-content
|
||||||
{
|
{
|
||||||
background: $color-canvas;
|
background: $color-canvas;
|
||||||
min-height: 100vh;
|
min-height: calc(100vh - 60px); //should be -$header-height, but I'm dumb I guess? It wouldn't work
|
||||||
main
|
main
|
||||||
{
|
{
|
||||||
|
margin-top: $header-height;
|
||||||
padding: $spacing-vertical;
|
padding: $spacing-vertical;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -98,6 +121,12 @@ $header-icon-size: 1.5em;
|
||||||
max-width: 800px;
|
max-width: 800px;
|
||||||
padding: $spacing-vertical;
|
padding: $spacing-vertical;
|
||||||
background: $color-bg;
|
background: $color-bg;
|
||||||
|
box-shadow: $default-box-shadow;
|
||||||
|
border-radius: 2px;
|
||||||
|
h2
|
||||||
|
{
|
||||||
|
margin-bottom: $spacing-vertical;
|
||||||
|
}
|
||||||
h3, h4
|
h3, h4
|
||||||
{
|
{
|
||||||
margin-bottom: $spacing-vertical / 2;
|
margin-bottom: $spacing-vertical / 2;
|
||||||
|
|
|
@ -17,7 +17,9 @@ $mobile-width-threshold: 801px;
|
||||||
$max-content-width: 1000px;
|
$max-content-width: 1000px;
|
||||||
$max-text-width: 660px;
|
$max-text-width: 660px;
|
||||||
|
|
||||||
$header-height: $spacing-vertical * 1.5;
|
$header-height: $spacing-vertical * 2.5;
|
||||||
|
|
||||||
|
$default-box-shadow: 0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.2),0 1px 5px 0 rgba(0,0,0,.12);
|
||||||
|
|
||||||
|
|
||||||
@mixin clearfix()
|
@mixin clearfix()
|
||||||
|
|
|
@ -135,7 +135,7 @@ select {
|
||||||
border: 0 none;
|
border: 0 none;
|
||||||
text-align: center;
|
text-align: center;
|
||||||
border-radius: 2px;
|
border-radius: 2px;
|
||||||
box-shadow: 0 2px 2px 0 rgba(0,0,0,.14),0 3px 1px -2px rgba(0,0,0,.2),0 1px 5px 0 rgba(0,0,0,.12);
|
box-shadow: $default-box-shadow;
|
||||||
text-transform: uppercase;
|
text-transform: uppercase;
|
||||||
+ .button-block
|
+ .button-block
|
||||||
{
|
{
|
||||||
|
|
Loading…
Add table
Reference in a new issue