Added language support
This commit is contained in:
11
public/actions/language.js
Normal file
11
public/actions/language.js
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
import Language from './../language/Language';
|
||||||
|
|
||||||
|
export const SET_LANGUAGE = "SET_LANGUAGE";
|
||||||
|
export const LANGUAGES = Language.getLanguages();
|
||||||
|
|
||||||
|
export function setLanguage(language) {
|
||||||
|
return {
|
||||||
|
type: SET_LANGUAGE,
|
||||||
|
code: language
|
||||||
|
}
|
||||||
|
};
|
@ -10,6 +10,8 @@ import React from 'react';
|
|||||||
|
|
||||||
import { Form, InputGroup, TextInput } from './Form';
|
import { Form, InputGroup, TextInput } from './Form';
|
||||||
import Button from './../components/Button';
|
import Button from './../components/Button';
|
||||||
|
import { connect } from 'react-redux';
|
||||||
|
import Language from './../../language/Language';
|
||||||
|
|
||||||
class ContactForm extends React.Component {
|
class ContactForm extends React.Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
@ -19,23 +21,28 @@ class ContactForm extends React.Component {
|
|||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<Form className={this.props.className}>
|
<Form className={this.props.className}>
|
||||||
<InputGroup title="Name">
|
<InputGroup title={Language.get("contact.form.name.label")} >
|
||||||
<TextInput placeholder="Enter your name." />
|
<TextInput placeholder={Language.get("contact.form.name.placeholder")} />
|
||||||
</InputGroup>
|
</InputGroup>
|
||||||
|
|
||||||
<InputGroup title="Email">
|
<InputGroup title={Language.get("contact.form.email.label")}>
|
||||||
<TextInput type="email" placeholder="Enter your email address." />
|
<TextInput type="email" placeholder={Language.get("contact.form.email.placeholder")} />
|
||||||
</InputGroup>
|
</InputGroup>
|
||||||
|
|
||||||
<InputGroup title="Message">
|
<InputGroup title={Language.get("contact.form.message.label")}>
|
||||||
<TextInput multiline placeholder="Enter your message here." />
|
<TextInput multiline placeholder={Language.get("contact.form.message.placeholder")} />
|
||||||
</InputGroup>
|
</InputGroup>
|
||||||
|
|
||||||
<Button to="/">Home</Button>
|
<Button submit>{Language.get("contact.form.submit")}</Button>
|
||||||
<Button submit>Contact</Button>
|
|
||||||
</Form>
|
</Form>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export default ContactForm;
|
const mapStateToProps = function(state) {
|
||||||
|
return {
|
||||||
|
code: state.language.code
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default connect(mapStateToProps)(ContactForm);
|
||||||
|
@ -17,6 +17,9 @@ import BodySection from './../sections/BodySection';
|
|||||||
|
|
||||||
import ContactForm from './../forms/ContactForm';
|
import ContactForm from './../forms/ContactForm';
|
||||||
|
|
||||||
|
import { connect } from 'react-redux';
|
||||||
|
import Language from './../../language/Language';
|
||||||
|
|
||||||
class ContactPage extends React.Component {
|
class ContactPage extends React.Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props);
|
super(props);
|
||||||
@ -27,10 +30,10 @@ class ContactPage extends React.Component {
|
|||||||
<Page>
|
<Page>
|
||||||
<PhoneSection />
|
<PhoneSection />
|
||||||
<BodySection>
|
<BodySection>
|
||||||
<h1>Contact</h1>
|
<h1>{Language.get("contact.form.title")}</h1>
|
||||||
<div className="c-page--style-container__split">
|
<div className="c-page--style-container__split">
|
||||||
<p className="c-page--style-container__split-part">
|
<p className="c-page--style-container__split-part">
|
||||||
Want to get ahold of me and other lorem ipsum dolor?
|
{Language.get("contact.form.info")}
|
||||||
</p>
|
</p>
|
||||||
<ContactForm className="c-page--style-container__split-part" />
|
<ContactForm className="c-page--style-container__split-part" />
|
||||||
</div>
|
</div>
|
||||||
@ -40,4 +43,10 @@ class ContactPage extends React.Component {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export default ContactPage;
|
const mapStateToProps = function(state) {
|
||||||
|
return {
|
||||||
|
code: state.language.code
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default connect(mapStateToProps)(ContactPage);
|
||||||
|
@ -10,11 +10,37 @@ class Language {
|
|||||||
}
|
}
|
||||||
|
|
||||||
setLanguage(lang) {
|
setLanguage(lang) {
|
||||||
|
this.langName = lang;
|
||||||
this.data = LANGUAGES[lang];
|
this.data = LANGUAGES[lang];
|
||||||
}
|
}
|
||||||
|
|
||||||
get(key) {
|
getLanguage() {
|
||||||
|
return this.langName;
|
||||||
|
}
|
||||||
|
|
||||||
|
get(key) {
|
||||||
|
return this.getRecursive(key.split(".")) || "Missing \"" + key + "\"";
|
||||||
|
}
|
||||||
|
|
||||||
|
getRecursive(key_array, data_obj) {
|
||||||
|
if(typeof data_obj === typeof undefined) data_obj = this.data;
|
||||||
|
if(typeof data_obj === typeof undefined) return null;
|
||||||
|
|
||||||
|
let k = key_array[0];
|
||||||
|
let o = data_obj[k];
|
||||||
|
if(typeof o === typeof undefined) return null;
|
||||||
|
|
||||||
|
//Awesome
|
||||||
|
if(key_array.length > 1) {
|
||||||
|
if(typeof o !== typeof {}) return null;
|
||||||
|
key_array.shift();
|
||||||
|
return this.getRecursive(key_array, o);
|
||||||
|
}
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
getLanguages() {
|
||||||
|
return Object.keys(LANGUAGES);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,3 +1,21 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
""
|
"contact": {
|
||||||
|
"form": {
|
||||||
|
"title": "Contact",
|
||||||
|
"info": "Want to contact me and other lorem ipsum dolor sit amet.",
|
||||||
|
"name": {
|
||||||
|
"label": "Name",
|
||||||
|
"placeholder": "Enter your name."
|
||||||
|
},
|
||||||
|
"email": {
|
||||||
|
"label": "Email",
|
||||||
|
"placeholder": "Enter your email address.",
|
||||||
|
},
|
||||||
|
"message": {
|
||||||
|
"label": "Message",
|
||||||
|
"placeholder": "Enter your message here."
|
||||||
|
},
|
||||||
|
"submit": "Send"
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
26
public/reducers/language.js
Normal file
26
public/reducers/language.js
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
import Language from './../language/Language';
|
||||||
|
import { SET_LANGUAGE, LANGUAGES } from './../actions/language';
|
||||||
|
|
||||||
|
const initialState = {
|
||||||
|
code: Language.getLanguage()
|
||||||
|
};
|
||||||
|
|
||||||
|
function language(state, action) {
|
||||||
|
if(typeof state === typeof undefined) {
|
||||||
|
state = initialState;
|
||||||
|
}
|
||||||
|
|
||||||
|
switch(action.type) {
|
||||||
|
case SET_LANGUAGE:
|
||||||
|
if(!(action.theme)) return state;
|
||||||
|
return {
|
||||||
|
code: action.code
|
||||||
|
};
|
||||||
|
default:
|
||||||
|
return state;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default language;
|
@ -2,10 +2,11 @@
|
|||||||
import {combineReducers} from 'redux';
|
import {combineReducers} from 'redux';
|
||||||
|
|
||||||
//Import Reducers
|
//Import Reducers
|
||||||
|
import language from './language';
|
||||||
|
|
||||||
//Create our Reducer
|
//Create our Reducer
|
||||||
const rootReducer = combineReducers({
|
const rootReducer = combineReducers({
|
||||||
|
language
|
||||||
});
|
});
|
||||||
|
|
||||||
//Export the root reducer
|
//Export the root reducer
|
||||||
|
Reference in New Issue
Block a user