moved the import of y18n component before some other imports; translations for auth developer

This commit is contained in:
Intnick 2017-05-26 02:16:25 +02:00
parent df2192116c
commit 8917d9e7e7
19 changed files with 200 additions and 127 deletions

View file

@ -75,5 +75,73 @@
"Discover": "Discover", "Discover": "Discover",
"Fetching content": "Fetching content", "Fetching content": "Fetching content",
"What's this?": "What's this?", "What's this?": "What's this?",
"Community Content is a public space where anyone can share content with the rest of the LBRY community. Bid on the names \"one,\" \"two,\" \"three,\" \"four\" and \"five\" to put your content here!": "Community Content is a public space where anyone can share content with the rest of the LBRY community. Bid on the names \"one,\" \"two,\" \"three,\" \"four\" and \"five\" to put your content here!" "Community Content is a public space where anyone can share content with the rest of the LBRY community. Bid on the names \"one,\" \"two,\" \"three,\" \"four\" and \"five\" to put your content here!": "Community Content is a public space where anyone can share content with the rest of the LBRY community. Bid on the names \"one,\" \"two,\" \"three,\" \"four\" and \"five\" to put your content here!",
"LBRY is Closed": "LBRY is Closed",
"Click here to start LBRY": "Click here to start LBRY",
"Failed to load landing content.": "Failed to load landing content.",
"Settings": "Settings",
"Welcome to LBRY": "Welcome to LBRY",
"Downloads & Purchases": "Downloads & Purchases",
"Downloaded": "Downloaded",
"Published": "Published",
"Publishes": "Publishes",
"Overview": "Overview",
"Send": "Send",
"Receive": "Receive",
"Rewards": "Rewards",
"Search results for %s": "Search results for %s",
"Search": "Search",
"Your email is still not verified.": "Your email is still not verified.",
"Next": "Next",
"Email": "Email",
"Verification Code": "Verification Code",
"A verification code is required to access this version.": "A verification code is required to access this version.",
"Verify": "Verify",
"No code?": "No code?",
"Click here": "Click here",
"Authentication": "Authentication",
"LBRY Early Access": "LBRY Early Access",
"Preparing for first access": "Preparing for first access",
"Welcome to LBRY.": "Welcome to LBRY.",
"Using LBRY is like dating a centaur. Totally normal up top, and <em>way different</em> underneath.": "Using LBRY is like dating a centaur. Totally normal up top, and <em>way different</em> underneath.",
"Up top, LBRY is similar to popular media sites.": "Up top, LBRY is similar to popular media sites.",
"Below, LBRY is controlled by users -- you -- via blockchain and decentralization.": "Below, LBRY is controlled by users -- you -- via blockchain and decentralization.",
"Thank you for making content freedom possible! Here's a nickel, kid.": "Thank you for making content freedom possible! Here's a nickel, kid.",
"Developer Settings": "Developer Settings",
"Show developer menu": "Show developer menu",
"Use custom search servers": "Use custom search servers",
"Custom search servers (one per line)": "Custom search servers (one per line)",
"Force Upgrade": "Force Upgrade",
"OK": "OK",
"Show More...": "Show More...",
"Show Less": "Show Less",
"Starting daemon": "Starting daemon",
"Waiting for name resolution": "Waiting for name resolution",
"Using LBRY is like dating a centaur. Totally normal up top, and way different underneath.": "Using LBRY is like dating a centaur. Totally normal up top, and way different underneath.",
"Claim Reward": "Claim Reward",
"Claiming...": "Claiming...",
"This is an estimate and does not include data fees": "This is an estimate and does not include data fees",
"free": "free",
"Reward Claim Error": "Reward Claim Error",
"This field is required": "This field is required",
"Choose File": "Choose File",
"No File Chosen": "No File Chosen",
"Choose Directory": "Choose Directory",
"Downloading Update": "Downloading Update",
"Click \"Begin Upgrade\" to start the upgrade process.": "Click \"Begin Upgrade\" to start the upgrade process.",
"The app will close, and you will be prompted to install the latest version of LBRY.": "The app will close, and you will be prompted to install the latest version of LBRY.",
"After the install is complete, please reopen the app.": "After the install is complete, please reopen the app.",
"Begin Upgrade": "Begin Upgrade",
"API connection string": "API connection string",
"We're sorry that LBRY has encountered an error. This has been reported and we will investigate the problem.": "We're sorry that LBRY has encountered an error. This has been reported and we will investigate the problem.",
"You haven't downloaded anything from LBRY yet. Go": "You haven't downloaded anything from LBRY yet. Go",
"search for your first download": "search for your first download",
"Loading": "Loading",
" credits": " credits",
"It looks like you haven't published anything to LBRY yet. Go": "It looks like you haven't published anything to LBRY yet. Go",
"share your beautiful cats with the world": "share your beautiful cats with the world",
"report": "report",
"Content-Type": "Content-Type",
"Author": "Author",
"License": "License"
} }

View file

@ -55,11 +55,11 @@ class SubmitEmailStage extends React.Component {
return ( return (
<section> <section>
<form onSubmit={(event) => { this.handleSubmit(event) }}> <form onSubmit={(event) => { this.handleSubmit(event) }}>
<FormRow ref={(ref) => { this._emailRow = ref }} type="text" label="Email" placeholder="scrwvwls@lbry.io" <FormRow ref={(ref) => { this._emailRow = ref }} type="text" label={__("Email")} placeholder="scrwvwls@lbry.io"
name="email" value={this.state.email} name="email" value={this.state.email}
onChange={(event) => { this.handleEmailChanged(event) }} /> onChange={(event) => { this.handleEmailChanged(event) }} />
<div className="form-row-submit"> <div className="form-row-submit">
<Link button="primary" label="Next" disabled={this.state.submitting} onClick={(event) => { this.handleSubmit(event) }} /> <Link button="primary" label={__("Next")} disabled={this.state.submitting} onClick={(event) => { this.handleSubmit(event) }} />
</div> </div>
</form> </form>
</section> </section>
@ -102,7 +102,7 @@ class ConfirmEmailStage extends React.Component {
if (userEmail.is_verified) { if (userEmail.is_verified) {
this.props.setStage("welcome") this.props.setStage("welcome")
} else { } else {
onSubmitError(new Error("Your email is still not verified.")) //shouldn't happen? onSubmitError(new Error(__("Your email is still not verified."))) //shouldn't happen?
} }
}, onSubmitError); }, onSubmitError);
} }
@ -111,14 +111,14 @@ class ConfirmEmailStage extends React.Component {
return ( return (
<section> <section>
<form onSubmit={(event) => { this.handleSubmit(event) }}> <form onSubmit={(event) => { this.handleSubmit(event) }}>
<FormRow label="Verification Code" ref={(ref) => { this._codeRow = ref }} type="text" <FormRow label={__("Verification Code")} ref={(ref) => { this._codeRow = ref }} type="text"
name="code" placeholder="a94bXXXXXXXXXXXXXX" value={this.state.code} onChange={(event) => { this.handleCodeChanged(event) }} name="code" placeholder="a94bXXXXXXXXXXXXXX" value={this.state.code} onChange={(event) => { this.handleCodeChanged(event) }}
helper="A verification code is required to access this version."/> helper={__("A verification code is required to access this version.")}/>
<div className="form-row-submit form-row-submit--with-footer"> <div className="form-row-submit form-row-submit--with-footer">
<Link button="primary" label="Verify" disabled={this.state.submitting} onClick={(event) => { this.handleSubmit(event)}} /> <Link button="primary" label={__("Verify")} disabled={this.state.submitting} onClick={(event) => { this.handleSubmit(event)}} />
</div> </div>
<div className="form-field__helper"> <div className="form-field__helper">
No code? <Link onClick={() => { this.props.setStage("nocode")}} label="Click here" />. {__("No code?")} <Link onClick={() => { this.props.setStage("nocode")}} label={__("Click here")} />.
</div> </div>
</form> </form>
</section> </section>
@ -150,26 +150,26 @@ class WelcomeStage extends React.Component {
render() { render() {
return ( return (
!this.state.hasReward ? !this.state.hasReward ?
<Modal type="custom" isOpen={true} contentLabel="Welcome to LBRY" {...this.props}> <Modal type="custom" isOpen={true} contentLabel={__("Welcome to LBRY")} {...this.props}>
<section> <section>
<h3 className="modal__header">Welcome to LBRY.</h3> <h3 className="modal__header">{__("Welcome to LBRY.")}</h3>
<p>Using LBRY is like dating a centaur. Totally normal up top, and <em>way different</em> underneath.</p> <p>{__("Using LBRY is like dating a centaur. Totally normal up top, and way different underneath.")}</p>
<p>Up top, LBRY is similar to popular media sites.</p> <p>{__("Up top, LBRY is similar to popular media sites.")}</p>
<p>Below, LBRY is controlled by users -- you -- via blockchain and decentralization.</p> <p>{__("Below, LBRY is controlled by users -- you -- via blockchain and decentralization.")}</p>
<p>Thank you for making content freedom possible! Here's a nickel, kid.</p> <p>{__("Thank you for making content freedom possible! Here's a nickel, kid.")}</p>
<div style={{textAlign: "center", marginBottom: "12px"}}> <div style={{textAlign: "center", marginBottom: "12px"}}>
<RewardLink type="new_user" button="primary" onRewardClaim={(event) => { this.onRewardClaim(event) }} onRewardFailure={() => this.props.setStage(null)} onConfirmed={() => { this.props.setStage(null) }} /> <RewardLink type="new_user" button="primary" onRewardClaim={(event) => { this.onRewardClaim(event) }} onRewardFailure={() => this.props.setStage(null)} onConfirmed={() => { this.props.setStage(null) }} />
</div> </div>
</section> </section>
</Modal> : </Modal> :
<Modal type="alert" overlayClassName="modal-overlay modal-overlay--clear" isOpen={true} contentLabel="Welcome to LBRY" {...this.props} onConfirmed={() => { this.props.setStage(null) }}> <Modal type="alert" overlayClassName="modal-overlay modal-overlay--clear" isOpen={true} contentLabel={__("Welcome to LBRY")} {...this.props} onConfirmed={() => { this.props.setStage(null) }}>
<section> <section>
<h3 className="modal__header">About Your Reward</h3> <h3 className="modal__header">{__("About Your Reward")}</h3>
<p>You earned a reward of <CreditAmount amount={this.state.rewardAmount} label={false} /> LBRY credits, or <em>LBC</em>.</p> <p>{__("You earned a reward of ")} <CreditAmount amount={this.state.rewardAmount} label={false} /> {__("LBRY credits, or \"LBC\".")}</p>
<p>This reward will show in your Wallet momentarily, probably while you are reading this message.</p> <p>{__("This reward will show in your Wallet momentarily, probably while you are reading this message.")}</p>
<p>LBC is used to compensate creators, to publish, and to have say in how the network works.</p> <p>{__("LBC is used to compensate creators, to publish, and to have say in how the network works.")}</p>
<p>No need to understand it all just yet! Try watching or downloading something next.</p> <p>{__("No need to understand it all just yet! Try watching or downloading something next.")}</p>
<p>Finally, know that LBRY is an early beta and that it earns the name.</p> <p>{__("Finally, know that LBRY is an early beta and that it earns the name.")}</p>
</section> </section>
</Modal> </Modal>
); );
@ -178,16 +178,16 @@ class WelcomeStage extends React.Component {
const ErrorStage = (props) => { const ErrorStage = (props) => {
return <section> return <section>
<p>An error was encountered that we cannot continue from.</p> <p>{__("An error was encountered that we cannot continue from.")}</p>
<p>At least we're earning the name beta.</p> <p>{__("At least we're earning the name beta.")}</p>
{ props.errorText ? <p>Message: {props.errorText}</p> : '' } { props.errorText ? <p>{__("Message:")} {props.errorText}</p> : '' }
<Link button="alt" label="Try Reload" onClick={() => { window.location.reload() } } /> <Link button="alt" label={__("Try Reload")} onClick={() => { window.location.reload() } } />
</section> </section>
} }
const PendingStage = (props) => { const PendingStage = (props) => {
return <section> return <section>
<p>Preparing for first access <span className="busy-indicator"></span></p> <p>{__("Preparing for first access")} <span className="busy-indicator"></span></p>
</section> </section>
} }
@ -230,20 +230,20 @@ class CodeRequiredStage extends React.Component {
return ( return (
<div> <div>
<section className="section-spaced"> <section className="section-spaced">
<p>Access to LBRY is restricted as we build and scale the network.</p> <p>{__("Access to LBRY is restricted as we build and scale the network.")}</p>
<p>There are two ways in:</p> <p>{__("There are two ways in:")}</p>
<h3>Own LBRY Credits</h3> <h3>{__("Own LBRY Credits")}</h3>
<p>If you own at least 1 LBC, you can get in right now.</p> <p>{__("If you own at least 1 LBC, you can get in right now.")}</p>
<p style={{ textAlign: "center"}}><Link onClick={() => { setLocal('auth_bypassed', true); this.props.setStage(null); }} <p style={{ textAlign: "center"}}><Link onClick={() => { setLocal('auth_bypassed', true); this.props.setStage(null); }}
disabled={disabled} label="Let Me In" button={ disabled ? "alt" : "primary" } /></p> disabled={disabled} label={__("Let Me In")} button={ disabled ? "alt" : "primary" } /></p>
<p>Your balance is <CreditAmount amount={this.state.balance} />. To increase your balance, send credits to this address:</p> <p>{__("Your balance is ")}<CreditAmount amount={this.state.balance} />. {__("To increase your balance, send credits to this address:")}</p>
<p><Address address={ this.state.address ? this.state.address : "Generating Address..." } /></p> <p><Address address={ this.state.address ? this.state.address : __("Generating Address...") } /></p>
<p>If you don't understand how to send credits, then...</p> <p>{__("If you don't understand how to send credits, then...")}</p>
</section> </section>
<section> <section>
<h3>Wait For A Code</h3> <h3>{__("Wait For A Code")}</h3>
<p>If you provide your email, you'll automatically receive a notification when the system is open.</p> <p>{__("If you provide your email, you'll automatically receive a notification when the system is open.")}</p>
<p><Link onClick={() => { this.props.setStage("email"); }} label="Return" /></p> <p><Link onClick={() => { this.props.setStage("email"); }} label={__("Return")} /></p>
</section> </section>
</div> </div>
); );
@ -312,13 +312,13 @@ export class AuthOverlay extends React.Component {
const StageContent = this._stages[this.state.stage]; const StageContent = this._stages[this.state.stage];
if (!StageContent) { if (!StageContent) {
return <span className="empty">Unknown authentication step.</span> return <span className="empty">{__("Unknown authentication step.")}</span>
} }
return ( return (
this.state.stage != "welcome" ? this.state.stage != "welcome" ?
<ModalPage className="modal-page--full" isOpen={true} contentLabel="Authentication"> <ModalPage className="modal-page--full" isOpen={true} contentLabel={__("Authentication")}>
<h1>LBRY Early Access</h1> <h1>{__("LBRY Early Access")}</h1>
<StageContent {...this.state.stageProps} setStage={(stage, stageProps) => { this.setStage(stage, stageProps) }} /> <StageContent {...this.state.stageProps} setStage={(stage, stageProps) => { this.setStage(stage, stageProps) }} />
</ModalPage> : </ModalPage> :
<StageContent setStage={(stage, stageProps) => { this.setStage(stage, stageProps) }} {...this.state.stageProps} /> <StageContent setStage={(stage, stageProps) => { this.setStage(stage, stageProps) }} {...this.state.stageProps} />

View file

@ -68,9 +68,9 @@ export class CreditAmount extends React.Component {
const formattedAmount = lbry.formatCredits(this.props.amount, this.props.precision); const formattedAmount = lbry.formatCredits(this.props.amount, this.props.precision);
let amountText; let amountText;
if (this.props.showFree && parseFloat(formattedAmount) == 0) { if (this.props.showFree && parseFloat(formattedAmount) == 0) {
amountText = 'free'; amountText = __('free');
} else if (this.props.label) { } else if (this.props.label) {
amountText = formattedAmount + (parseFloat(formattedAmount) == 1 ? ' credit' : ' credits'); amountText = formattedAmount + (parseFloat(formattedAmount) == 1 ? __(' credit') : __(' credits'));
} else { } else {
amountText = formattedAmount; amountText = formattedAmount;
} }
@ -80,7 +80,7 @@ export class CreditAmount extends React.Component {
<span> <span>
{amountText} {amountText}
</span> </span>
{ this.props.isEstimate ? <span className="credit-amount__estimate" title="This is an estimate and does not include data fees">*</span> : null } { this.props.isEstimate ? <span className="credit-amount__estimate" title={__("This is an estimate and does not include data fees")}>*</span> : null }
</span> </span>
); );
} }

View file

@ -15,22 +15,22 @@ class DownloadingModal extends React.Component {
} = this.props } = this.props
return ( return (
<Modal isOpen={true} contentLabel="Downloading Update" type="custom"> <Modal isOpen={true} contentLabel={__("Downloading Update")} type="custom">
Downloading Update{downloadProgress ? `: ${downloadProgress}%` : null} {__("Downloading Update")}{downloadProgress ? `: ${downloadProgress}%` : null}
<Line percent={downloadProgress} strokeWidth="4"/> <Line percent={downloadProgress} strokeWidth="4"/>
{downloadComplete ? ( {downloadComplete ? (
<div> <div>
<br /> <br />
<p>Click "Begin Upgrade" to start the upgrade process.</p> <p>{__("Click \"Begin Upgrade\" to start the upgrade process.")}</p>
<p>The app will close, and you will be prompted to install the latest version of LBRY.</p> <p>{__("The app will close, and you will be prompted to install the latest version of LBRY.")}</p>
<p>After the install is complete, please reopen the app.</p> <p>{__("After the install is complete, please reopen the app.")}</p>
</div> </div>
) : null } ) : null }
<div className="modal__buttons"> <div className="modal__buttons">
{downloadComplete {downloadComplete
? <Link button="primary" label="Begin Upgrade" className="modal__button" onClick={startUpgrade} /> ? <Link button="primary" label={__("Begin Upgrade")} className="modal__button" onClick={startUpgrade} />
: null} : null}
<Link button="alt" label="Cancel" className="modal__button" onClick={cancelUpgrade} /> <Link button="alt" label={__("Cancel")} className="modal__button" onClick={cancelUpgrade} />
</div> </div>
</Modal> </Modal>
) )

View file

@ -15,12 +15,12 @@ class ErrorModal extends React.Component {
const errorObj = typeof error === "string" ? { error: error } : error const errorObj = typeof error === "string" ? { error: error } : error
const error_key_labels = { const error_key_labels = {
connectionString: 'API connection string', connectionString: __('API connection string'),
method: 'Method', method: __('Method'),
params: 'Parameters', params: __('Parameters'),
code: 'Error code', code: __('Error code'),
message: 'Error message', message: __('Error message'),
data: 'Error data', data: __('Error data'),
} }
@ -35,16 +35,16 @@ class ErrorModal extends React.Component {
return( return(
<ExpandableModal <ExpandableModal
isOpen={modal == 'error'} isOpen={modal == 'error'}
contentLabel="Error" className="error-modal" contentLabel={__("Error")} className="error-modal"
overlayClassName="error-modal-overlay" overlayClassName="error-modal-overlay"
onConfirmed={closeModal} onConfirmed={closeModal}
extraContent={errorInfo} extraContent={errorInfo}
> >
<h3 className="modal__header">Error</h3> <h3 className="modal__header">{__("Error")}</h3>
<div className="error-modal__content"> <div className="error-modal__content">
<div><img className="error-modal__warning-symbol" src={lbry.imagePath('warning.png')} /></div> <div><img className="error-modal__warning-symbol" src={lbry.imagePath('warning.png')} /></div>
<p>We're sorry that LBRY has encountered an error. This has been reported and we will investigate the problem.</p> <p>{__("We're sorry that LBRY has encountered an error. This has been reported and we will investigate the problem.")}</p>
</div> </div>
</ExpandableModal> </ExpandableModal>
) )

View file

@ -41,14 +41,14 @@ class FileSelector extends React.Component {
<div className="file-selector"> <div className="file-selector">
<button type="button" className="file-selector__choose-button" onClick={() => this.handleButtonClick()}> <button type="button" className="file-selector__choose-button" onClick={() => this.handleButtonClick()}>
{this.props.type == 'file' ? {this.props.type == 'file' ?
'Choose File' : __('Choose File') :
'Choose Directory'} __('Choose Directory')}
</button> </button>
{' '} {' '}
<span className="file-selector__path"> <span className="file-selector__path">
{this.state.path ? {this.state.path ?
this.state.path : this.state.path :
'No File Chosen'} __('No File Chosen')}
</span> </span>
</div> </div>
); );

View file

@ -21,7 +21,7 @@ export class FormField extends React.Component {
constructor(props) { constructor(props) {
super(props); super(props);
this._fieldRequiredText = 'This field is required'; this._fieldRequiredText = __('This field is required');
this._type = null; this._type = null;
this._element = null; this._element = null;
@ -136,7 +136,7 @@ export class FormRow extends React.Component {
constructor(props) { constructor(props) {
super(props); super(props);
this._fieldRequiredText = 'This field is required'; this._fieldRequiredText = __('This field is required');
this.state = { this.state = {
isError: false, isError: false,

View file

@ -2,6 +2,9 @@ import React from 'react';
import ReactModal from 'react-modal'; import ReactModal from 'react-modal';
import Link from 'component/link'; import Link from 'component/link';
const i18n = require('y18n')({directory: 'app/locales'});
export class Modal extends React.Component { export class Modal extends React.Component {
static propTypes = { static propTypes = {
@ -18,8 +21,8 @@ export class Modal extends React.Component {
static defaultProps = { static defaultProps = {
type: 'alert', type: 'alert',
overlay: true, overlay: true,
confirmButtonLabel: 'OK', confirmButtonLabel: i18n.__('OK'),
abortButtonLabel: 'Cancel', abortButtonLabel: i18n.__('Cancel'),
confirmButtonDisabled: false, confirmButtonDisabled: false,
abortButtonDisabled: false, abortButtonDisabled: false,
} }
@ -52,9 +55,9 @@ export class ExpandableModal extends React.Component {
} }
static defaultProps = { static defaultProps = {
confirmButtonLabel: 'OK', confirmButtonLabel: i18n.__('OK'),
expandButtonLabel: 'Show More...', expandButtonLabel: i18n.__('Show More...'),
hideButtonLabel: 'Show Less', hideButtonLabel: i18n.__('Show Less'),
} }
constructor(props) { constructor(props) {

View file

@ -77,11 +77,11 @@ export class RewardLink extends React.Component {
return ( return (
<div className="reward-link"> <div className="reward-link">
{this.props.claimed {this.props.claimed
? <span><Icon icon="icon-check" /> Reward claimed.</span> ? <span><Icon icon="icon-check" /> {__("Reward claimed.")}</span>
: <Link button={this.props.button ? this.props.button : 'alt'} disabled={this.state.pending || !this.state.claimable } : <Link button={this.props.button ? this.props.button : 'alt'} disabled={this.state.pending || !this.state.claimable }
label={ this.state.pending ? "Claiming..." : "Claim Reward"} onClick={() => { this.claimReward() }} />} label={ this.state.pending ? __("Claiming...") : __("Claim Reward")} onClick={() => { this.claimReward() }} />}
{this.state.errorMessage ? {this.state.errorMessage ?
<Modal isOpen={true} contentLabel="Reward Claim Error" className="error-modal" onConfirmed={() => { this.clearError() }}> <Modal isOpen={true} contentLabel={__("Reward Claim Error")} className="error-modal" onConfirmed={() => { this.clearError() }}>
{this.state.errorMessage} {this.state.errorMessage}
</Modal> </Modal>
: ''} : ''}

View file

@ -12,7 +12,7 @@ export class SplashScreen extends React.Component {
super(props); super(props);
this.state = { this.state = {
details: 'Starting daemon', details: __('Starting daemon'),
isLagging: false, isLagging: false,
}; };
} }
@ -29,7 +29,7 @@ export class SplashScreen extends React.Component {
// TODO: This is a hack, and the logic should live in the daemon // TODO: This is a hack, and the logic should live in the daemon
// to give us a better sense of when we are actually started // to give us a better sense of when we are actually started
this.setState({ this.setState({
details: 'Waiting for name resolution', details: __('Waiting for name resolution'),
isLagging: false isLagging: false
}); });
@ -54,8 +54,8 @@ export class SplashScreen extends React.Component {
} else { } else {
this.setState({ this.setState({
isLagging: true, isLagging: true,
message: "Failed to connect to LBRY", message: __("Failed to connect to LBRY"),
details: "LBRY was unable to start and connect properly." details: __("LBRY was unable to start and connect properly.")
}) })
} }
}) })

View file

@ -2,14 +2,19 @@ import React from 'react';
import ReactDOM from 'react-dom'; import ReactDOM from 'react-dom';
import lbry from './lbry.js'; import lbry from './lbry.js';
import lbryio from './lbryio.js'; import lbryio from './lbryio.js';
const i18n = require('y18n')({directory: 'app/locales'});
window.__ = i18n.__;
window.__n = i18n.__n;
import lighthouse from './lighthouse.js'; import lighthouse from './lighthouse.js';
import App from 'component/app/index.js'; import App from 'component/app/index.js';
import SplashScreen from 'component/splash.js';
import SnackBar from 'component/snackBar'; import SnackBar from 'component/snackBar';
import {AuthOverlay} from 'component/auth.js';
import { Provider } from 'react-redux'; import { Provider } from 'react-redux';
import batchActions from 'util/batchActions' import batchActions from 'util/batchActions'
import store from 'store.js'; import store from 'store.js';
import SplashScreen from 'component/splash.js';
import {AuthOverlay} from 'component/auth.js';
import { import {
doChangePath, doChangePath,
doNavigate, doNavigate,
@ -30,9 +35,6 @@ const {remote, ipcRenderer, shell} = require('electron');
const contextMenu = remote.require('./menu/context-menu'); const contextMenu = remote.require('./menu/context-menu');
const app = require('./app') const app = require('./app')
const i18n = require('y18n')({directory: 'app/locales'});
window.__ = i18n.__;
window.__n = i18n.__n;
lbry.showMenuIfNeeded(); lbry.showMenuIfNeeded();

View file

@ -27,11 +27,11 @@ class ChannelPage extends React.Component{
let contentList let contentList
if (claimsInChannel === undefined) { if (claimsInChannel === undefined) {
contentList = <BusyMessage message="Fetching content" /> contentList = <BusyMessage message={__("Fetching content")} />
} else if (claimsInChannel) { } else if (claimsInChannel) {
contentList = claimsInChannel.length ? contentList = claimsInChannel.length ?
claimsInChannel.map((claim) => <FileTile key={claim.claim_id} uri={lbryuri.build({name: claim.name, claimId: claim.claim_id})} />) : claimsInChannel.map((claim) => <FileTile key={claim.claim_id} uri={lbryuri.build({name: claim.name, claimId: claim.claim_id})} />) :
<span className="empty">No content found.</span> <span className="empty">{__("No content found.")}</span>
} }
return <main className="main--single-column"> return <main className="main--single-column">
@ -41,11 +41,11 @@ class ChannelPage extends React.Component{
</div> </div>
<div className="card__content"> <div className="card__content">
<p> <p>
This channel page is a stub. {__("This channel page is a stub.")}
</p> </p>
</div> </div>
</section> </section>
<h3 className="card-row__header">Published Content</h3> <h3 className="card-row__header">{__("Published Content")}</h3>
{contentList} {contentList}
</main> </main>
} }

View file

@ -63,17 +63,17 @@ class DeveloperPage extends React.Component {
return ( return (
<main> <main>
<section className="card"> <section className="card">
<h3>Developer Settings</h3> <h3>{__("Developer Settings")}</h3>
<div className="form-row"> <div className="form-row">
<label><FormField type="checkbox" onChange={(event) => { this.handleShowDeveloperMenuChange() }} checked={this.state.showDeveloperMenu} /> Show developer menu</label> <label><FormField type="checkbox" onChange={(event) => { this.handleShowDeveloperMenuChange() }} checked={this.state.showDeveloperMenu} /> {__("Show developer menu")}</label>
</div> </div>
<div className="form-row"> <div className="form-row">
<label><FormField type="checkbox" onChange={(event) => { this.handleUseCustomLighthouseServersChange() }} checked={this.state.useCustomLighthouseServers} /> Use custom search servers</label> <label><FormField type="checkbox" onChange={(event) => { this.handleUseCustomLighthouseServersChange() }} checked={this.state.useCustomLighthouseServers} /> {__("Use custom search servers")}</label>
</div> </div>
{this.state.useCustomLighthouseServers {this.state.useCustomLighthouseServers
? <div className="form-row"> ? <div className="form-row">
<label> <label>
Custom search servers (one per line) {__("Custom search servers (one per line)")}
<div><FormField type="textarea" className="developer-page__custom-lighthouse-servers" value={this.state.customLighthouseServers} onChange={(event) => { this.handleCustomLighthouseServersChange() }} checked={this.state.debugMode} /></div> <div><FormField type="textarea" className="developer-page__custom-lighthouse-servers" value={this.state.customLighthouseServers} onChange={(event) => { this.handleCustomLighthouseServersChange() }} checked={this.state.debugMode} /></div>
</label> </label>
</div> </div>
@ -83,7 +83,7 @@ class DeveloperPage extends React.Component {
<div className="form-row"> <div className="form-row">
<FormField name="file" ref="file" type="file" onChange={(event) => { this.handleUpgradeFileChange() }}/> <FormField name="file" ref="file" type="file" onChange={(event) => { this.handleUpgradeFileChange() }}/>
&nbsp; &nbsp;
<Link label="Force Upgrade" button="alt" onClick={(event) => { this.handleForceUpgradeClick() }} /> <Link label={__("Force Upgrade")} button="alt" onClick={(event) => { this.handleForceUpgradeClick() }} />
</div> </div>
</section> </section>
</main> </main>

View file

@ -38,7 +38,7 @@ class DiscoverPage extends React.Component{
<main> <main>
{ {
fetchingFeaturedUris && fetchingFeaturedUris &&
<BusyMessage message="Fetching content" /> <BusyMessage message={__("Fetching content")} />
} }
{ {
typeof featuredUris === "object" && typeof featuredUris === "object" &&
@ -48,7 +48,7 @@ class DiscoverPage extends React.Component{
} }
{ {
typeof featuredUris !== undefined && typeof featuredUris !== undefined &&
<div className="empty">Failed to load landing content.</div> <div className="empty">{__("Failed to load landing content.")}</div>
} }
</main> </main>
) )

View file

@ -27,9 +27,9 @@ class FileListDownloaded extends React.Component {
content = <FileList fileInfos={fileInfos} fetching={isPending} /> content = <FileList fileInfos={fileInfos} fetching={isPending} />
} else { } else {
if (isPending) { if (isPending) {
content = <BusyMessage message="Loading" /> content = <BusyMessage message={__("Loading")} />
} else { } else {
content = <span>You haven't downloaded anything from LBRY yet. Go <Link onClick={() => navigate('/discover')} label="search for your first download" />!</span> content = <span>{__("You haven't downloaded anything from LBRY yet. Go")} <Link onClick={() => navigate('/discover')} label={__("search for your first download")} />!</span>
} }
} }

View file

@ -49,9 +49,9 @@ class FileListPublished extends React.Component {
content = <FileList fileInfos={fileInfos} fetching={isPending} fileTileShowEmpty={FileTile.SHOW_EMPTY_PENDING} /> content = <FileList fileInfos={fileInfos} fetching={isPending} fileTileShowEmpty={FileTile.SHOW_EMPTY_PENDING} />
} else { } else {
if (isPending) { if (isPending) {
content = <BusyMessage message="Loading" /> content = <BusyMessage message={__("Loading")} />
} else { } else {
content = <span>It looks like you haven't published anything to LBRY yet. Go <Link onClick={() => navigate('/publish')} label="share your beautiful cats with the world" />!</span> content = <span>{__("It looks like you haven't published anything to LBRY yet. Go")} <Link onClick={() => navigate('/publish')} label={__("share your beautiful cats with the world")} />!</span>
} }
} }

View file

@ -26,16 +26,16 @@ const FormatItem = (props) => {
<table className="table-standard"> <table className="table-standard">
<tbody> <tbody>
<tr> <tr>
<td>Content-Type</td><td>{mediaType}</td> <td>{__("Content-Type")}</td><td>{mediaType}</td>
</tr> </tr>
<tr> <tr>
<td>Author</td><td>{author}</td> <td>{__("Author")}</td><td>{author}</td>
</tr> </tr>
<tr> <tr>
<td>Language</td><td>{language}</td> <td>{__("Language")}</td><td>{language}</td>
</tr> </tr>
<tr> <tr>
<td>License</td><td>{license}</td> <td>{__("License")}</td><td>{license}</td>
</tr> </tr>
</tbody> </tbody>
</table> </table>
@ -68,7 +68,7 @@ class FilePage extends React.Component{
} = this.props } = this.props
if (!claim || !metadata) { if (!claim || !metadata) {
return <span className="empty">Empty claim or metadata info.</span> return <span className="empty">{__("Empty claim or metadata info.")}</span>
} }
const { const {
@ -117,7 +117,7 @@ class FilePage extends React.Component{
<FormatItem metadata={metadata} contentType={contentType} /> <FormatItem metadata={metadata} contentType={contentType} />
</div> : '' } </div> : '' }
<div className="card__content"> <div className="card__content">
<Link href="https://lbry.io/dmca" label="report" className="button-text-help" /> <Link href="https://lbry.io/dmca" label={__("report")} className="button-text-help" />
</div> </div>
</section> </section>
</main> </main>

View file

@ -9,8 +9,8 @@ class StartPage extends React.Component {
render() { render() {
return ( return (
<main className="main--single-column"> <main className="main--single-column">
<h3>__("LBRY is Closed")</h3> <h3>{__("LBRY is Closed")}</h3>
<Link href="lbry://lbry" label="Click here to start LBRY" /> <Link href="lbry://lbry" label={__("Click here to start LBRY")} />
</main> </main>
); );
} }

View file

@ -39,13 +39,13 @@ export const selectPageTitle = createSelector(
(page, params) => { (page, params) => {
switch (page) { switch (page) {
case 'search': case 'search':
return params.query ? `Search results for ${params.query}` : 'Search' return params.query ? __("Search results for %s", params.query) : __('Search')
case 'settings': case 'settings':
return 'Settings' return __('Settings')
case 'help': case 'help':
return 'Help' return __('Help')
case 'report': case 'report':
return 'Report' return __('Report')
case 'wallet': case 'wallet':
case 'send': case 'send':
case 'receive': case 'receive':
@ -54,19 +54,19 @@ export const selectPageTitle = createSelector(
case 'show': case 'show':
return lbryuri.normalize(params.uri) return lbryuri.normalize(params.uri)
case 'downloaded': case 'downloaded':
return 'Downloads & Purchases' return __('Downloads & Purchases')
case 'published': case 'published':
return 'Publishes' return __('Publishes')
case 'start': case 'start':
return 'Start' return __('Start')
case 'publish': case 'publish':
return 'Publish' return __('Publish')
case 'help': case 'help':
return 'Help' return __('Help')
case 'developer': case 'developer':
return 'Developer' return __('Developer')
case 'discover': case 'discover':
return 'Home' return __('Home')
default: default:
return ''; return '';
} }
@ -142,22 +142,22 @@ export const selectHeaderLinks = createSelector(
case 'receive': case 'receive':
case 'rewards': case 'rewards':
return { return {
'wallet': 'Overview', 'wallet': __('Overview'),
'send': 'Send', 'send': __('Send'),
'receive': 'Receive', 'receive': __('Receive'),
'rewards': 'Rewards', 'rewards': __('Rewards'),
}; };
case 'downloaded': case 'downloaded':
case 'published': case 'published':
return { return {
'downloaded': 'Downloaded', 'downloaded': __('Downloaded'),
'published': 'Published', 'published': __('Published'),
}; };
case 'settings': case 'settings':
case 'help': case 'help':
return { return {
'settings': 'Settings', 'settings': __('Settings'),
'help': 'Help', 'help': __('Help'),
} }
default: default:
return null; return null;