1
0
Fork 0
mirror of https://github.com/openstf/stf synced 2025-10-03 17:59:28 +02:00

- Add Local settings.

- Add Language settings synced back.
This commit is contained in:
Gunther Brunner 2014-03-13 21:03:41 +09:00
parent 710a5daeab
commit eaaf6a36bd
11 changed files with 137 additions and 50 deletions

View file

@ -12,7 +12,6 @@
"Snap.svg": "~0.2.0",
"angular-localForage": "~0.0.2",
"ng-table": "~0.3.1",
"angular-ui-bootstrap": "~0.10.0",
"jquery.terminal": "~0.8.4",
"stf-site": "git@ghe.amb.ca.local:stf/stf-site.git",
"angular-gettext": "~0.2.5",
@ -20,7 +19,9 @@
"ui-bootstrap-alerts": "~0.1.5",
"angular-sanitize": "~1.2.14",
"requirejs": "~2.1.11",
"stf-graphics": "git@ghe.amb.ca.local:stf/stf-graphics.git"
"stf-graphics": "git@ghe.amb.ca.local:stf/stf-graphics.git",
"angular-bootstrap": "~0.10.0",
"angular-dialog-service": "~3.1.0"
},
"private": true,
"resolutions": {

View file

@ -6,7 +6,8 @@ var webpackOptions = require('../../webpack.config.js')
var overrideOptions = {
debug: true,
devtool: 'eval'
devtool: 'source-map'
//devtool: 'eval'
}
var finalOptions = _.assign(webpackOptions, overrideOptions)

View file

@ -4,4 +4,7 @@ require('angular-localForage')
module.exports = angular.module('stf/settings', [
'LocalForageModule'
])
.config(['$localForageProvider', function ($localForageProvider) {
$localForageProvider.setPrefix('stf.v0');
}])
.factory('SettingsService', require('./settings-service'))

View file

@ -1,4 +1,5 @@
module.exports = angular.module('ui-settings', [
require('./local').name,
require('./language').name
])
.config(['$routeProvider', function ($routeProvider) {

View file

@ -1,23 +1,23 @@
module.exports = function ($scope, LanguageService, SettingsService) { //gettextCatalog,
module.exports = function ($scope, LanguageService, SettingsService) {
// SettingsService.sync($scope, 'Language', {
// language: LanguageService.detectedLanguage
// })
//SettingsService.set('')
SettingsService.set('valueCrazy', 35)
SettingsService.set('valueCrazyNew', {one: 1, two: 35.3, three: '日本語', four: [1, 2, 3, 4]})
//console.log('he')
//console.log(SettingsService.get('valueCrazy'))
// $scope.$watch('language', function (newValue) {
// gettextCatalog.currentLanguage = newValue
// SettingsService.bind($scope, {
// key: 'language',
// defaultValue: LanguageService.selectedLanguage
// })
//
// $scope.supportedLanguages = LanguageService.supportedLanguages
LanguageService.getSelectedLanguage().then(function (data) {
$scope.language = data
console.log('real', data)
})
$scope.$watch('language', function (newValue, oldValue) {
if (newValue !== oldValue) {
LanguageService.setSelectedLanguage(newValue)
}
})
$scope.supportedLanguages = LanguageService.supportedLanguages
}

View file

@ -1,23 +1,56 @@
//var _ = require('lodash')
var _ = require('lodash')
module.exports = function LanguageServiceFactory() {
// var LanguageService = {}
//
// LanguageService.supportedLanguages = [
// {code: 'en', name: 'English'},
// {code: 'ja', name: '日本語'}
// ]
//
// var browserLocale = navigator.language || navigator.userLanguage || 'en-US'
// var browserLanguage = browserLocale.substring(0, 2)
// var detectedLanguage = _.some(LanguageService.supportedLanguages, {code: browserLanguage}) ? browserLanguage : 'en'
// var defaultLanguage = 'ja'
// LanguageService.detectedLanguage = defaultLanguage
// LanguageService.selectedLanguage = defaultLanguage
//
// LanguageService.getSelectedLanguage = function () {
// return LanguageService.selectedLanguage = defaultLanguage //WebStorage.get('Language.language') || defaultLanguage
// }
//
// return LanguageService
module.exports = function LanguageServiceFactory(SettingsService, $q, gettextCatalog) {
var LanguageService = {}
LanguageService.supportedLanguages = [
{code: 'en', name: 'English'},
{code: 'ja', name: '日本語'}
]
var browserLocale = navigator.language || navigator.userLanguage || 'en-US'
var browserLanguage = browserLocale.substring(0, 2)
var detectedLanguage = _.some(LanguageService.supportedLanguages, {code: browserLanguage}) ? browserLanguage : 'en'
var defaultLanguage = 'ja'
LanguageService.detectedLanguage = defaultLanguage
LanguageService.selectedLanguage = null
// TODO: Can't this be refactored to something like this?
// SettingsService.sync(LanguageService.selectedLanguage, 'Language', {
// selected: LanguageService.detectedLanguage
// })
LanguageService.getSelectedLanguage = function () {
var deferred = $q.defer()
if (LanguageService.selectedLanguage) {
deferred.resolve(LanguageService.selectedLanguage)
} else {
SettingsService.get('Language.selected').then(function (data) {
if (data) {
deferred.resolve(data)
} else {
LanguageService.setSelectedLanguage(LanguageService.detectedLanguage).then(function () {
deferred.resolve(LanguageService.detectedLanguage)
})
}
})
}
return deferred.promise
}
// Initialize gettextCatalog
LanguageService.getSelectedLanguage()
LanguageService.setSelectedLanguage = function (lang) {
var deferred = $q.defer()
LanguageService.selectedLanguage = lang
gettextCatalog.currentLanguage = lang
SettingsService.set('Language.selected', lang).then(function () {
deferred.resolve(lang)
})
return deferred.promise
}
return LanguageService
}

View file

@ -0,0 +1,13 @@
require('angular-bootstrap')
require('angular-dialog-service/dialogs')
require('angular-dialog-service/dialogs.css')
module.exports = angular.module('ui-local-settings', [
require('stf/settings').name,
'ui.bootstrap',
//'dialogs'
])
.run(["$templateCache", function ($templateCache) {
$templateCache.put('settings/local/local-settings.jade', require('./local-settings.jade'))
}])
.controller('LocalSettingsCtrl', require('./local-settings-controller'))

View file

@ -0,0 +1,24 @@
module.exports = function ($scope, SettingsService) {
$scope.resetSettings = function () {
SettingsService.clearAll()
}
$scope.savedTo = SettingsService.getDriver()
// $scope.resetSettings = function () {
// var title = 'Reset Settings';
// var msg = 'Are you sure you want to revert all settings to their default values?';
// var btns = [
// {result: 'cancel', label: 'Cancel'},
// {result: 'ok', label: 'OK', cssClass: 'btn-primary'}
// ];
// $dialog.messageBox(title, msg, btns)
// .open()
// .then(function (result) {
// if (result === 'ok') {
// //SettingsService.clearAll();
// }
// });
// };
}

View file

@ -0,0 +1,11 @@
.widget-container.fluid-height(ng-controller='LocalSettingsCtrl')
.heading
i.fa.fa-save
span(translate) Local Settings
.widget-content.padded
button(ng-click='resetSettings()').btn.btn-danger
i.fa.fa-trash-o
span(translate) Reset Settings
p
span.text-muted(translate) Saved to: {{savedTo}}

View file

@ -1,14 +1,7 @@
div(pane='center')
.row
.col-md-4
.widget-container.fluid-height
.heading
i.fa.fa-save
span(translate) Local storage
.widget-content.padded
button(ng-click='resetSettings()').btn.btn-danger
i.fa.fa-trash-o
span(translate) Reset Settings
div(ng-include='"settings/local/local-settings.jade"')
.col-md-4
div(ng-include='"settings/language/language.jade"')
.col-md-4

View file

@ -18,6 +18,7 @@ module.exports = {
'./node_modules'
],
alias: {
'angular-bootstrap': 'angular-bootstrap/ui-bootstrap-tpls',
'localforage': 'localforage/dist/localforage.js',
'socket.io': 'socket.io-client/dist/socket.io',
'oboe': 'oboe/dist/oboe-browser'
@ -39,7 +40,9 @@ module.exports = {
{ test: /angular\.js/, loader: 'exports?angular'},
{ test: /angular-route\.js/, loader: 'imports?angular=angular'},
{ test: /oboe-browser\.js/, loader: 'imports?define=>false!exports?oboe'},
{ test: /localforage\.js/, loader: 'script'}
{ test: /localforage\.js/, loader: 'script'},
{ test: /ui-bootstrap-tpls\.js/, loader: 'script'},
{ test: /dialogs\.js/, loader: 'script'}
],
noParse: [
// pathutil.resource('bower_components')
@ -49,6 +52,10 @@ module.exports = {
new webpack.ResolverPlugin(
new webpack.ResolverPlugin.DirectoryDescriptionFilePlugin('bower.json', ['main'])
),
new webpack.ResolverPlugin(
new webpack.ResolverPlugin.DirectoryDescriptionFilePlugin('.bower.json', ['main'])
)
// new webpack.ResolverPlugin(
// new webpack.ResolverPlugin.DirectoryDescriptionFilePlugin('package.json', ['main'])
// )