// Copyright (c) 2018 Dominic Masters // // MIT License // // Permission is hereby granted, free of charge, to any person obtaining // a copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to // permit persons to whom the Software is furnished to do so, subject to // the following conditions: // // The above copyright notice and this permission notice shall be // included in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. import React from 'react'; import { connect } from 'react-redux'; import LanguageActions from './../actions/LanguageActions'; import enAU from './en-AU.jsx'; export const LANGUAGES = { 'en-AU': enAU } class Language { constructor() { this.setLanguage("en-AU"); } setLanguage(lang) { this.langName = lang; this.data = LANGUAGES[lang]; } getLanguage() { return this.langName; } get(key) { if(typeof key === typeof undefined) return "Key \"undefined\"."; let j = this.getRecursive(key.split(".")); if(typeof j === typeof undefined || j == null) return "Missing \"" + key + "\""; return j; } 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; if(typeof o === 'function') o = o(); //Awesome if(key_array.length > 1) { if(typeof o !== "object") return null; key_array.shift(); return this.getRecursive(key_array, o); } return o; } getLanguages() { return Object.keys(LANGUAGES); } } const lang = new Language(); export default lang; export const LanguageTools = { random: function(someArray) { return someArray[Math.floor(Math.random() * someArray.length)]; } } export const withLanguage = Wrapped => { let LanguageWrapper = props => { return ; }; return connect(state => { return { language: state.language.code, lang: lang.data } }, dispatch => { return { setLanguage: language => { dispatch(LanguageActions.setLanguage(language)); } }; })(LanguageWrapper); };