thingsboard-aplcache
Changes
ui/package.json 12(+6 -6)
ui/src/app/app.config.js 60(+21 -39)
ui/src/app/app.js 4(+2 -2)
ui/src/app/locale/locale.constant-en.json 2928(+1453 -1475)
ui/src/app/locale/locale.constant-es.json 2630(+1306 -1324)
ui/src/app/locale/locale.constant-it.json 2898(+1439 -1459)
ui/src/app/locale/locale.constant-ko.json 2671(+1327 -1344)
ui/src/app/locale/locale.constant-ru.json 2726(+1354 -1372)
ui/src/app/locale/locale.constant-zh.json 2905(+1443 -1462)
ui/webpack.config.dev.js 12(+10 -2)
ui/webpack.config.prod.js 12(+10 -2)
Details
ui/package.json 12(+6 -6)
diff --git a/ui/package.json b/ui/package.json
index 892664f..5fb997b 100644
--- a/ui/package.json
+++ b/ui/package.json
@@ -37,12 +37,12 @@
"angular-socialshare": "^2.3.8",
"angular-storage": "0.0.15",
"angular-touch": "1.5.8",
- "angular-translate": "2.13.1",
- "angular-translate-handler-log": "2.13.1",
- "angular-translate-interpolation-messageformat": "2.13.1",
- "angular-translate-loader-static-files": "2.13.1",
- "angular-translate-storage-cookie": "2.13.1",
- "angular-translate-storage-local": "2.13.1",
+ "angular-translate": "2.18.1",
+ "angular-translate-handler-log": "2.18.1",
+ "angular-translate-interpolation-messageformat": "2.18.1",
+ "angular-translate-loader-static-files": "2.18.1",
+ "angular-translate-storage-cookie": "2.18.1",
+ "angular-translate-storage-local": "2.18.1",
"angular-ui-ace": "^0.2.3",
"angular-ui-router": "^0.3.1",
"angular-websocket": "^2.0.1",
ui/src/app/app.config.js 60(+21 -39)
diff --git a/ui/src/app/app.config.js b/ui/src/app/app.config.js
index a84bdde..982e9a9 100644
--- a/ui/src/app/app.config.js
+++ b/ui/src/app/app.config.js
@@ -15,10 +15,6 @@
*/
import injectTapEventPlugin from 'react-tap-event-plugin';
import UrlHandler from './url.handler';
-import addLocaleKorean from './locale/locale.constant-ko';
-import addLocaleChinese from './locale/locale.constant-zh';
-import addLocaleRussian from './locale/locale.constant-ru';
-import addLocaleSpanish from './locale/locale.constant-es';
/* eslint-disable import/no-unresolved, import/default */
@@ -38,46 +34,32 @@ export default function AppConfig($provide,
$mdThemingProvider,
$httpProvider,
$translateProvider,
- storeProvider,
- locales) {
+ storeProvider) {
injectTapEventPlugin();
$locationProvider.html5Mode(true);
$urlRouterProvider.otherwise(UrlHandler);
storeProvider.setCaching(false);
-
- $translateProvider.useSanitizeValueStrategy(null);
- $translateProvider.useMissingTranslationHandler('tbMissingTranslationHandler');
- $translateProvider.addInterpolation('$translateMessageFormatInterpolation');
- $translateProvider.fallbackLanguage('en_US');
-
- addLocaleKorean(locales);
- addLocaleChinese(locales);
- addLocaleRussian(locales);
- addLocaleSpanish(locales);
-
- for (var langKey in locales) {
- var translationTable = locales[langKey];
- $translateProvider.translations(langKey, translationTable);
- }
-
- var lang = $translateProvider.resolveClientLocale();
- if (lang) {
- lang = lang.toLowerCase();
- if (lang.startsWith('ko')) {
- $translateProvider.preferredLanguage('ko_KR');
- } else if (lang.startsWith('zh')) {
- $translateProvider.preferredLanguage('zh_CN');
- } else if (lang.startsWith('es')) {
- $translateProvider.preferredLanguage('es_ES');
- } else if (lang.startsWith('ru')) {
- $translateProvider.preferredLanguage('ru_RU');
- } else {
- $translateProvider.preferredLanguage('en_US');
- }
- } else {
- $translateProvider.preferredLanguage('en_US');
- }
+
+ $translateProvider.useSanitizeValueStrategy(null)
+ .useMissingTranslationHandler('tbMissingTranslationHandler')
+ /* .useMissingTranslationHandlerLog() */
+ .addInterpolation('$translateMessageFormatInterpolation')
+ .useStaticFilesLoader({
+ prefix: PUBLIC_PATH + 'locale/locale.constant-', //eslint-disable-line
+ suffix: '.json'
+ })
+ .registerAvailableLanguageKeys(['en', 'es', 'it', 'ko', 'ru', 'zh'], {
+ 'en_*': 'en',
+ 'es_*': 'es',
+ 'it_*': 'it',
+ 'ko_*': 'ko',
+ 'ru_*': 'ru',
+ 'zh_*': 'zh'
+ })
+ .fallbackLanguage('en') // must be before determinePreferredLanguage
+ .uniformLanguageTag('java') // must be before determinePreferredLanguage
+ .determinePreferredLanguage();
$httpProvider.interceptors.push('globalInterceptor');
ui/src/app/app.js 4(+2 -2)
diff --git a/ui/src/app/app.js b/ui/src/app/app.js
index f021efb..c8cdeb0 100644
--- a/ui/src/app/app.js
+++ b/ui/src/app/app.js
@@ -51,7 +51,7 @@ import react from 'ngreact';
import '@flowjs/ng-flow/dist/ng-flow-standalone.min';
import 'ngFlowchart/dist/ngFlowchart';
-import thingsboardLocales from './locale/locale.constant';
+import thingsboardTranslateHandler from './locale/translate-handler';
import thingsboardLogin from './login';
import thingsboardDialogs from './components/datakey-config-dialog.controller';
import thingsboardMenu from './services/menu.service';
@@ -117,7 +117,7 @@ angular.module('thingsboard', [
react.name,
'flow',
'flowchart',
- thingsboardLocales,
+ thingsboardTranslateHandler,
thingsboardLogin,
thingsboardDialogs,
thingsboardMenu,
diff --git a/ui/src/app/locale/translate-handler.js b/ui/src/app/locale/translate-handler.js
index 11feb00..9fb28f5 100644
--- a/ui/src/app/locale/translate-handler.js
+++ b/ui/src/app/locale/translate-handler.js
@@ -13,8 +13,12 @@
* See the License for the specific language governing permissions and
* limitations under the License.
*/
+ export default angular.module('thingsboard.locale', [])
+ .factory('tbMissingTranslationHandler', ThingsboardMissingTranslateHandler)
+ .name;
+
/*@ngInject*/
-export default function ThingsboardMissingTranslateHandler($log, types) {
+function ThingsboardMissingTranslateHandler($log, types) {
return function (translationId) {
if (translationId && !translationId.startsWith(types.translate.customTranslationsPrefix)) {
ui/webpack.config.dev.js 12(+10 -2)
diff --git a/ui/webpack.config.dev.js b/ui/webpack.config.dev.js
index b1a1911..e0cc91e 100644
--- a/ui/webpack.config.dev.js
+++ b/ui/webpack.config.dev.js
@@ -21,6 +21,8 @@ const CopyWebpackPlugin = require('copy-webpack-plugin');
const webpack = require('webpack');
const path = require('path');
+const PUBLIC_RESOURCE_PATH = '/';
+
/* devtool: 'cheap-module-eval-source-map', */
module.exports = {
@@ -32,7 +34,7 @@ module.exports = {
],
output: {
path: path.resolve(__dirname, 'target/generated-resources/public/static'),
- publicPath: '/',
+ publicPath: PUBLIC_RESOURCE_PATH,
filename: 'bundle.js',
},
plugins: [
@@ -45,7 +47,8 @@ module.exports = {
moment: "moment"
}),
new CopyWebpackPlugin([
- { from: './src/thingsboard.ico', to: 'thingsboard.ico' }
+ { from: './src/thingsboard.ico', to: 'thingsboard.ico' },
+ { from: './src/app/locale', to: 'locale' }
]),
new webpack.HotModuleReplacementPlugin(),
new HtmlWebpackPlugin({
@@ -65,6 +68,7 @@ module.exports = {
'process.env': {
NODE_ENV: JSON.stringify('development'),
},
+ PUBLIC_PATH: PUBLIC_RESOURCE_PATH
}),
],
node: {
@@ -118,6 +122,10 @@ module.exports = {
'img?minimize'
]
},
+ {
+ test: /\.json$/,
+ loader: 'json-loader'
+ }
],
},
'html-minifier-loader': {
ui/webpack.config.prod.js 12(+10 -2)
diff --git a/ui/webpack.config.prod.js b/ui/webpack.config.prod.js
index 150638d..c7bafb0 100644
--- a/ui/webpack.config.prod.js
+++ b/ui/webpack.config.prod.js
@@ -21,6 +21,8 @@ const CopyWebpackPlugin = require('copy-webpack-plugin');
const webpack = require('webpack');
const path = require('path');
+const PUBLIC_RESOURCE_PATH = '/static/';
+
module.exports = {
devtool: 'source-map',
entry: [
@@ -29,7 +31,7 @@ module.exports = {
],
output: {
path: path.resolve(__dirname, 'target/generated-resources/public/static'),
- publicPath: '/static/',
+ publicPath: PUBLIC_RESOURCE_PATH,
filename: 'bundle.[hash].js',
},
plugins: [
@@ -42,7 +44,8 @@ module.exports = {
moment: "moment"
}),
new CopyWebpackPlugin([
- {from: './src/thingsboard.ico', to: 'thingsboard.ico'}
+ { from: './src/thingsboard.ico', to: 'thingsboard.ico'},
+ { from: './src/app/locale', to: 'locale' }
]),
new HtmlWebpackPlugin({
template: './src/index.html',
@@ -63,6 +66,7 @@ module.exports = {
'process.env': {
NODE_ENV: JSON.stringify('production'),
},
+ PUBLIC_PATH: PUBLIC_RESOURCE_PATH
}),
],
node: {
@@ -116,6 +120,10 @@ module.exports = {
'img?minimize'
]
},
+ {
+ test: /\.json$/,
+ loader: 'json-loader'
+ }
],
},
'html-minifier-loader': {