Skip to content

Commit

Permalink
🐞 default translation appears when switching language for the first t…
Browse files Browse the repository at this point in the history
…ime (#221)

Parent issue: sequentech/meta#315
  • Loading branch information
edulix authored Feb 8, 2024
1 parent 486a16f commit 79904ea
Show file tree
Hide file tree
Showing 3 changed files with 151 additions and 50 deletions.
1 change: 0 additions & 1 deletion Gruntfile.js
Original file line number Diff line number Diff line change
Expand Up @@ -404,7 +404,6 @@ module.exports = function (grunt) {
main: {
files: {
'temp/app.js':['temp/app.js'],
'temp/lib.js': ['temp/lib.js'],
'temp/libnocompat.js': ['temp/libnocompat.js'],
'temp/libcompat.js': ['temp/libcompat.js']
}
Expand Down
123 changes: 101 additions & 22 deletions app.js
Original file line number Diff line number Diff line change
Expand Up @@ -45,30 +45,109 @@ angular.module(
'common-ui'
]);

angular.module('jm.i18next').config(function ($i18nextProvider, ConfigServiceProvider) {
// note that we do not send the language: by default, it will try the language
// supported by the web browser
$("#no-js").hide();

$i18nextProvider.options = _.extend(
angular
.module('jm.i18next')
.config(function ($i18nextProvider, ConfigServiceProvider)
{
function expandObject(obj)
{
useCookie: true,
useLocalStorage: false,
fallbackLng: 'en',
cookieName: 'lang',
detectLngQS: 'lang',
lngWhitelist: ['en', 'es', 'gl', 'ca', 'nb'],
resGetPath: '/election/locales/__lng__.json',
defaultLoadingValue: '' // ng-i18next option, *NOT* directly supported by i18next
},
ConfigServiceProvider.i18nextInitOptions
);
var result = {};
// Helper function to handle the recursion
function assignValue(ref, keys, value) {
var key = keys.shift(); // Get the current key part
if (keys.length === 0) {
// If no more keys, assign the value directly
ref[key] = value;
} else {
// Prepare the next level sub-object if necessary
if (!ref[key]) {
ref[key] = {};
}
// Recurse with the next level of the key and the corresponding sub-object
assignValue(ref[key], keys, value);
}
}
// Iterate over each property in the input object
for (var prop in obj) {
if (obj.hasOwnProperty(prop)) {
var keys = prop.split('.'); // Split the property by dots into parts
assignValue(result, keys, obj[prop]); // Use the helper to assign the value in the result object
}
}
return result;
}

// Prevent site translation if configured
if (ConfigServiceProvider.preventSiteTranslation) {
$('html').attr('translate', 'no');
}
});
// note that we do not send the language: by default, it will try the language
// supported by the web browser
$("#no-js").hide();
window.i18next
.use(window.i18nextChainedBackend)
.init(_.extend(
{
debug: true,
load: 'languageOnly',
useCookie: true,
// Preload is needed because the language selector shows an item for
// each element in lngWhitelist, and the translation for each language
// is contained at each language i18n file, so we either preload it
// or it wouldn't work.
preload: ConfigServiceProvider.i18nextInitOptions.lngWhitelist || [],
useLocalStorage: false,
fallbackLng: 'en',
cookieName: 'lang',
detectLngQS: 'lang',
lngWhitelist: ['en', 'es'],
interpolation: {
prefix: '__',
suffix: '__',
},
// Define the backends to use in the chain
backend: {
backends: [
{
type: 'backend',
/* use services and options */
init: function(services, backendOptions, i18nextOptions) {},
/* return resources */
read: function(language, namespace, callback)
{
if (
window.i18nOverride &&
typeof window.i18nOverride === 'object' &&
window.i18nOverride[language] &&
typeof window.i18nOverride[language] === 'object'
) {
var override = expandObject(window.i18nOverride[language]);
callback(null, override);
} else {
// not found
callback(true, null);
}
},
/* save the missing translation */
create: function(languages, namespace, key, fallbackValue) {}
},
window.i18nextHttpBackend, // Primary backend
],
backendOptions: [
// Configuration for custom backend
{},
// Configuration for http backend
{
loadPath: '/election/locales/__lng__.json',
},
]
},
defaultLoadingValue: '' // ng-i18next option, *NOT* directly supported by i18next
},
ConfigServiceProvider.i18nextInitOptions
));

// Prevent site translation if configured
if (ConfigServiceProvider.preventSiteTranslation) {
$('html').attr('translate', 'no');
}
});

angular.module('election-portal').config(function($sceDelegateProvider, ConfigServiceProvider) {
$sceDelegateProvider.resourceUrlWhitelist(ConfigServiceProvider.resourceUrlWhitelist);
Expand Down
77 changes: 50 additions & 27 deletions avElection/public-controller/public-controller.js
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,6 @@ angular
$scope,
$rootScope,
$window,
$i18next,
ConfigService,
InsideIframeService,
Authmethod,
Expand All @@ -54,34 +53,58 @@ angular
* @param {number} electionId election whose results should be shown.
*/
$scope.autoreloadResultsTimer = null;
$scope.alreadyReloaded = null;

function reloadTranslations(force) {
function reloadInner() {
var election = $scope.election;

function reloadTranslations(force, ms) {
setTimeout(
function () {
var election = $scope.election;

// reset $window.i18nOverride
var overrides = (
election &&
election.presentation &&
election.presentation.i18n_override
) ? election.presentation.i18n_override : null;

var languagesConf = (
election &&
election.presentation &&
election.presentation.i18n_languages_conf
) ? election.presentation.i18n_languages_conf : null;

I18nOverride(
/* overrides = */ overrides,
/* force = */ force,
/* languagesConf = */ languagesConf
);
},
ms || 1000
);
if ($scope.alreadyReloaded === election.id) {
console.log("booth-directive: broadcast i18nextLanguageChange");
$rootScope.$broadcast('i18nextLanguageChange', $window.i18next.resolvedLanguage);
return;
} else {
$scope.alreadyReloaded = election.id;
}

// should we reset $window.i18nOverride?
var overrides = (
election &&
election.presentation &&
election.presentation.i18n_override
) ? election.presentation.i18n_override : null;

var languagesConf = (
election &&
election.presentation &&
election.presentation.i18n_languages_conf
) ? election.presentation.i18n_languages_conf : null;

I18nOverride(
/* overrides = */ overrides,
/* force = */ force,
/* languagesConf = */ languagesConf
);
}
function timeoutWrap() {
console.log("timeoutWrap");
var election = $scope.election;
if (election && $scope.alreadyReloaded === election.id) {
return;
}
if (!election) {
console.log("timeoutWrap: delaying for election..");
setTimeout(timeoutWrap, 200);
return;
}
// call reloadInner only after i18next initialization
if ($window.i18next.isInitialized) {
reloadInner();
} else {
$window.i18next.on('initialized', reloadInner);
}
}
timeoutWrap();
}

$scope.autoReloadReceive = function (value)
Expand Down

0 comments on commit 79904ea

Please sign in to comment.