1
0
mirror of https://github.com/ascribe/onion.git synced 2025-01-03 18:35:09 +01:00

start implementing localization functionality

This commit is contained in:
Tim Daubenschütz 2015-06-01 18:20:15 +02:00
parent 8a18d894cc
commit f2d9f3b115
5 changed files with 51 additions and 38 deletions

View File

@ -12,6 +12,8 @@ import TableItemText from '../ascribe_table/table_item_text';
import TableItemCheckbox from '../ascribe_table/table_item_checkbox'; import TableItemCheckbox from '../ascribe_table/table_item_checkbox';
import TableItemAclFiltered from '../ascribe_table/table_item_acl_filtered'; import TableItemAclFiltered from '../ascribe_table/table_item_acl_filtered';
import getText from '../../utils/lang_utils';
let AccordionListItemTableEditions = React.createClass({ let AccordionListItemTableEditions = React.createClass({
propTypes: { propTypes: {
@ -47,8 +49,8 @@ let AccordionListItemTableEditions = React.createClass({
render() { render() {
let columnList = [ let columnList = [
new TableColumnContentModel((item) => { return { 'editionId': item.id, 'pieceId': this.props.parentId, 'selectItem': this.selectItem, 'selected': item.selected }}, '', '', TableItemCheckbox, 1, false), new TableColumnContentModel((item) => { return { 'editionId': item.id, 'pieceId': this.props.parentId, 'selectItem': this.selectItem, 'selected': item.selected }}, '', '', TableItemCheckbox, 1, false),
new TableColumnContentModel((item) => { return { 'content': item.edition_number }}, 'num_editions', 'Nr', TableItemText, 1, false), new TableColumnContentModel((item) => { return { 'content': item.edition_number }}, 'num_editions', '#', TableItemText, 1, false),
new TableColumnContentModel((item) => { return { 'content': item.bitcoin_id }}, 'bitcoin_id', 'Bitcoin Address', TableItemText, 5, false), new TableColumnContentModel((item) => { return { 'content': item.bitcoin_id }}, 'bitcoin_id', getText('Bitcoin Address'), TableItemText, 5, false),
new TableColumnContentModel((item) => { return { 'content': item.acl }}, 'acl', 'Actions', TableItemAclFiltered, 4, false) new TableColumnContentModel((item) => { return { 'content': item.acl }}, 'acl', 'Actions', TableItemAclFiltered, 4, false)
]; ];

View File

@ -5,6 +5,12 @@ import AltContainer from 'alt/AltContainer';
import UserActions from '../actions/user_actions'; import UserActions from '../actions/user_actions';
import UserStore from '../stores/user_store'; import UserStore from '../stores/user_store';
import Nav from 'react-bootstrap/lib/Nav';
import Navbar from 'react-bootstrap/lib/Navbar';
import NavItem from 'react-bootstrap/lib/NavItem';
import DropdownButton from 'react-bootstrap/lib/DropdownButton';
import MenuItem from 'react-bootstrap/lib/MenuItem';
let Link = Router.Link; let Link = Router.Link;
let Header = React.createClass({ let Header = React.createClass({
@ -24,40 +30,24 @@ let Header = React.createClass({
render() { render() {
return ( return (
<nav className="navbar navbar-default"> <Navbar>
<div className="container"> <Nav>
<div className="navbar-header">
<button type="button" className="navbar-toggle collapsed" data-toggle="collapse" data-target="#navbar" aria-expanded="false" aria-controls="navbar">
<span className="sr-only">Toggle navigation</span>
<span className="icon-bar"></span>
<span className="icon-bar"></span>
<span className="icon-bar"></span>
</button>
<a className="navbar-brand" href="#"> <a className="navbar-brand" href="#">
<span>ascribe </span> <span>ascribe </span>
<span className="glyph-ascribe-spool-chunked ascribe-color"></span> <span className="glyph-ascribe-spool-chunked ascribe-color"></span>
</a> </a>
</div> </Nav>
<Nav right>
<div id="navbar" className="navbar-collapse collapse"> <DropdownButton eventKey={3} title={this.state.currentUser.username}>
<ul className="nav navbar-nav navbar-left"> <MenuItem eventKey="1" href="/art/account_settings/">Account Settings</MenuItem>
</ul>
<ul className="nav navbar-nav navbar-right">
<li className="dropdown">
<a href="#" className="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false">{this.state.currentUser.username} <span className="caret"></span></a>
<ul className="dropdown-menu" role="menu">
<li><a href="/art/faq/">Account Settings</a></li>
<li className="divider"></li> <li className="divider"></li>
<li><a href="/art/faq/">FAQ</a></li> <MenuItem eventKey="2" href="/art/faq/">FAQ</MenuItem>
<li><a href="/art/terms/">Terms of Service</a></li> <MenuItem eventKey="3" href="/art/terms/">Terms of Service</MenuItem>
<li className="divider"></li> <MenuItem divider />
<li><a href="/api/users/logout/">Log out</a></li> <MenuItem eventKey="4" href="/api/users/logout/">Log out</MenuItem>
</ul> </DropdownButton>
</li> </Nav>
</ul> </Navbar>
</div>
</div>
</nav>
); );
} }
}); });

View File

@ -0,0 +1,8 @@
const languages = {
'en-US': {
'Bitcoin Address': 'Bitcoin Address',
'Actions': 'Actions'
}
};
export default languages;

View File

@ -1,11 +1,11 @@
import alt from '../alt'; import alt from '../alt';
import EditionAction from '../actions/edition_actions'; import EditionActions from '../actions/edition_actions';
class EditionStore { class EditionStore {
constructor() { constructor() {
this.edition = {}; this.edition = {};
this.bindActions(EditionAction); this.bindActions(EditionActions);
} }
onUpdateEdition(edition) { onUpdateEdition(edition) {

13
js/utils/lang_utils.js Normal file
View File

@ -0,0 +1,13 @@
import languages from '../constants/languages';
let getText = function(s) {
let lang = navigator.language || navigator.userLanguage;
if(lang in languages && s in languages[lang]) {
return languages[lang][s];
} else {
throw new Error('Your language is not supported.');
// How ironic that this error is thrown in the english language...
}
};
export default getText;