forked from mirrors/easyappointments
78 lines
2.5 KiB
JavaScript
78 lines
2.5 KiB
JavaScript
/* ----------------------------------------------------------------------------
|
|
* Easy!Appointments - Online Appointment Scheduler
|
|
*
|
|
* @package EasyAppointments
|
|
* @author A.Tselegidis <alextselegidis@gmail.com>
|
|
* @copyright Copyright (c) Alex Tselegidis
|
|
* @license https://opensource.org/licenses/GPL-3.0 - GPLv3
|
|
* @link https://easyappointments.org
|
|
* @since v1.5.0
|
|
* ---------------------------------------------------------------------------- */
|
|
|
|
/**
|
|
* Lang utility.
|
|
*
|
|
* This module implements the functionality of translations.
|
|
*/
|
|
window.App.Utils.Lang = (function () {
|
|
/**
|
|
* Enable Language Selection
|
|
*
|
|
* Enables the language selection functionality. Must be called on every page has a language selection button.
|
|
* This method requires the global variable "vars('available_variables')" to be initialized before the execution.
|
|
*
|
|
* @param {Object} $target Selected element button for the language selection.
|
|
*/
|
|
function enableLanguageSelection($target) {
|
|
// Select Language
|
|
const $languageList = $('<ul/>', {
|
|
'id': 'language-list',
|
|
'html': vars('available_languages').map((availableLanguage) =>
|
|
$('<li/>', {
|
|
'class': 'language',
|
|
'data-language': availableLanguage,
|
|
'text': App.Utils.String.upperCaseFirstLetter(availableLanguage),
|
|
}),
|
|
),
|
|
});
|
|
|
|
$target.popover({
|
|
placement: 'top',
|
|
title: 'Select Language',
|
|
content: $languageList[0],
|
|
html: true,
|
|
container: 'body',
|
|
trigger: 'manual',
|
|
});
|
|
|
|
$target.on('click', function (event) {
|
|
event.stopPropagation();
|
|
|
|
const $target = $(event.target);
|
|
|
|
if ($('#language-list').length === 0) {
|
|
$target.popover('show');
|
|
} else {
|
|
$target.popover('hide');
|
|
}
|
|
|
|
$target.toggleClass('active');
|
|
});
|
|
|
|
$(document).on('click', 'li.language', (event) => {
|
|
// Change language with HTTP request and refresh page.
|
|
|
|
const language = $(event.target).data('language');
|
|
|
|
App.Http.Localization.changeLanguage(language).done(() => document.location.reload());
|
|
});
|
|
|
|
$(document).on('click', () => {
|
|
$target.popover('hide');
|
|
});
|
|
}
|
|
|
|
return {
|
|
enableLanguageSelection,
|
|
};
|
|
})();
|