mirror of
https://github.com/overte-org/overte.git
synced 2025-04-25 17:55:36 +02:00
486 lines
No EOL
16 KiB
JavaScript
486 lines
No EOL
16 KiB
JavaScript
var Settings = {
|
|
showAdvanced: false
|
|
};
|
|
|
|
var viewHelpers = {
|
|
getFormGroup: function(groupName, setting, values, isAdvanced, isLocked) {
|
|
setting_name = groupName + "." + setting.name
|
|
|
|
form_group = "<div class='form-group" + (isAdvanced ? " advanced-setting" : "") + "'>"
|
|
|
|
if (_.has(values, groupName) && _.has(values[groupName], setting.name)) {
|
|
setting_value = values[groupName][setting.name]
|
|
} else if (_.has(setting, 'default')) {
|
|
setting_value = setting.default
|
|
} else {
|
|
setting_value = ""
|
|
}
|
|
|
|
label_class = 'control-label'
|
|
if (isLocked) {
|
|
label_class += ' locked'
|
|
}
|
|
|
|
if (setting.type === 'checkbox') {
|
|
form_group += "<label class='" + label_class + "'>" + setting.label + "</label>"
|
|
form_group += "<div class='checkbox" + (isLocked ? " disabled" : "") + "'>"
|
|
form_group += "<label for='" + setting_name + "'>"
|
|
form_group += "<input type='checkbox' name='" + setting_name + "' " +
|
|
(setting_value ? "checked" : "") + (isLocked ? " disabled" : "") + "/>"
|
|
form_group += " " + setting.help + "</label>";
|
|
form_group += "</div>"
|
|
} else if (setting.type === 'table') {
|
|
form_group += makeTable(setting, setting_name, setting_value);
|
|
} else {
|
|
input_type = _.has(setting, 'type') ? setting.type : "text"
|
|
|
|
form_group += "<label for='" + setting_name + "' class='" + label_class + "'>" + setting.label + "</label>";
|
|
|
|
if (setting.type === 'select') {
|
|
form_group += "<select class='form-control' data-hidden-input='" + setting_name + "'>'"
|
|
|
|
_.each(setting.options, function(option) {
|
|
form_group += "<option value='" + option.value + "'" +
|
|
(option.value == setting_value ? 'selected' : '') + ">" + option.label + "</option>"
|
|
})
|
|
|
|
form_group += "</select>"
|
|
|
|
form_group += "<input type='hidden' name='" + setting_name + "' value='" + setting_value + "'>"
|
|
} else {
|
|
form_group += "<input type='" + input_type + "' class='form-control' name='" + setting_name +
|
|
"' placeholder='" + (_.has(setting, 'placeholder') ? setting.placeholder : "") +
|
|
"' value='" + setting_value + "'" + (isLocked ? " disabled" : "") + "/>"
|
|
}
|
|
|
|
form_group += "<span class='help-block'>" + setting.help + "</span>"
|
|
}
|
|
|
|
form_group += "</div>"
|
|
return form_group
|
|
}
|
|
}
|
|
|
|
$(document).ready(function(){
|
|
/*
|
|
* Clamped-width.
|
|
* Usage:
|
|
* <div data-clampedwidth=".myParent">This long content will force clamped width</div>
|
|
*
|
|
* Author: LV
|
|
*/
|
|
|
|
$('[data-clampedwidth]').each(function () {
|
|
var elem = $(this);
|
|
var parentPanel = elem.data('clampedwidth');
|
|
var resizeFn = function () {
|
|
var sideBarNavWidth = $(parentPanel).width() - parseInt(elem.css('paddingLeft')) - parseInt(elem.css('paddingRight')) - parseInt(elem.css('marginLeft')) - parseInt(elem.css('marginRight')) - parseInt(elem.css('borderLeftWidth')) - parseInt(elem.css('borderRightWidth'));
|
|
elem.css('width', sideBarNavWidth);
|
|
};
|
|
|
|
resizeFn();
|
|
$(window).resize(resizeFn);
|
|
})
|
|
|
|
$('#settings-form').on('click', '.add-row', function(){
|
|
var row = $(this).parents("tr")
|
|
var row-data = row.parent().children(".row-data")
|
|
|
|
// Check key spaces
|
|
var name = row.children(".key").children("input").val()
|
|
if (name.indexOf(' ') !== -1) {
|
|
showAlertMessage("Key contains spaces", false)
|
|
return
|
|
}
|
|
// Check keys with the same name
|
|
var equals = false;
|
|
_.each(row-data.children(".key"), function(element) {
|
|
if ($(element).text() === name) {
|
|
equals = true
|
|
return
|
|
}
|
|
})
|
|
if (equals) {
|
|
showAlertMessage("Two keys cannot be identical.", false)
|
|
return
|
|
}
|
|
|
|
// Check empty fields
|
|
var empty = false;
|
|
_.each(row.children(".row-data").children("input"), function(element) {
|
|
if ($(element).val().length === 0) {
|
|
empty = true
|
|
return
|
|
}
|
|
})
|
|
if (empty) {
|
|
showAlertMessage("Empty field(s)")
|
|
return
|
|
}
|
|
|
|
var input_clone = row.clone()
|
|
// Change input row to data row
|
|
var full_name = row.parents("table").attr("name") + "." + name
|
|
row.attr("class", "row-data")
|
|
|
|
_.each(row.children(), function(element) {
|
|
if ($(element).hasClass("number")) { // Index row
|
|
var numbers = row-data.children(".number")
|
|
if (numbers.length > 0) {
|
|
$(element).html(parseInt(numbers.last().text()) + 1)
|
|
} else {
|
|
$(element).html(1)
|
|
}
|
|
} else if ($(element).hasClass("buttons")) { // Change buttons
|
|
var prevSpan = $(element).parent().prev().children(".buttons").children("span")
|
|
var span = $(element).children("span")
|
|
console.log(prevSpan.length)
|
|
console.log(span.length)
|
|
if (prevSpan.hasClass("del-row")) {
|
|
console.log("Switching icons")
|
|
span.removeClass("glyphicon-ok add-row")
|
|
span.addClass("glyphicon-remove del-row")
|
|
} else {
|
|
span.remove()
|
|
}
|
|
} else if ($(element).hasClass("key")) {
|
|
var input = $(element).children("input")
|
|
$(element).html(input.val())
|
|
input.remove()
|
|
} else if($(element).hasClass("row-data")) { // Hide inputs
|
|
var input = $(element).children("input")
|
|
input.attr("type", "hidden")
|
|
input.attr("name", full_name + "." + $(element).attr("name"))
|
|
input.attr("value", input.val())
|
|
input.attr("data-changed", "true")
|
|
|
|
$(element).html($(element).html() + input.val())
|
|
} else {
|
|
console.log("Unknown table element")
|
|
}
|
|
})
|
|
row.parent().append(input_clone)
|
|
showAlertMessage("Row added", true)
|
|
})
|
|
|
|
$('#settings-form').on('click', '.del-row', function(){
|
|
var row = $(this).parents("tr")
|
|
row.empty()
|
|
row.html("<input type='hidden' class='form-control' name='" + row.attr("name") + "' data-changed='true' value=''>");
|
|
})
|
|
|
|
$('#settings-form').on('change', 'input', function(){
|
|
// this input was changed, add the changed data attribute to it
|
|
$(this).attr('data-changed', true)
|
|
|
|
badgeSidebarForDifferences($(this))
|
|
})
|
|
|
|
$('#advanced-toggle-button').click(function(){
|
|
Settings.showAdvanced = !Settings.showAdvanced
|
|
var advancedSelector = $('.advanced-setting')
|
|
|
|
if (Settings.showAdvanced) {
|
|
advancedSelector.show()
|
|
$(this).html("Hide advanced")
|
|
} else {
|
|
advancedSelector.hide()
|
|
$(this).html("Show advanced")
|
|
}
|
|
|
|
$(this).blur()
|
|
})
|
|
|
|
$('#settings-form').on('click', '#choose-domain-btn', function(){
|
|
chooseFromHighFidelityDomains($(this))
|
|
})
|
|
|
|
$('#settings-form').on('change', 'select', function(){
|
|
console.log("Changed" + $(this))
|
|
$("input[name='" + $(this).attr('data-hidden-input') + "']").val($(this).val()).change()
|
|
})
|
|
|
|
var panelsSource = $('#panels-template').html()
|
|
Settings.panelsTemplate = _.template(panelsSource)
|
|
|
|
var sidebarTemplate = $('#list-group-template').html()
|
|
Settings.sidebarTemplate = _.template(sidebarTemplate)
|
|
|
|
// $('body').scrollspy({ target: '#setup-sidebar'})
|
|
|
|
reloadSettings()
|
|
})
|
|
|
|
function reloadSettings() {
|
|
$.getJSON('/settings.json', function(data){
|
|
_.extend(data, viewHelpers)
|
|
|
|
$('.nav-stacked').html(Settings.sidebarTemplate(data))
|
|
$('#panels').html(Settings.panelsTemplate(data))
|
|
|
|
Settings.initialValues = form2js('settings-form', ".", false, cleanupFormValues, true);
|
|
|
|
// add tooltip to locked settings
|
|
$('label.locked').tooltip({
|
|
placement: 'right',
|
|
title: 'This setting is in the master config file and cannot be changed'
|
|
})
|
|
|
|
appendDomainSelectionModal()
|
|
});
|
|
}
|
|
|
|
function appendDomainSelectionModal() {
|
|
var metaverseInput = $("[name='metaverse.id']");
|
|
var chooseButton = $("<button type='button' id='choose-domain-btn' class='btn btn-primary' style='margin-top:10px'>Choose ID from my domains</button>");
|
|
metaverseInput.after(chooseButton);
|
|
}
|
|
|
|
var SETTINGS_ERROR_MESSAGE = "There was a problem saving domain settings. Please try again!";
|
|
|
|
$('body').on('click', '.save-button', function(e){
|
|
// disable any inputs not changed
|
|
$("input:not([data-changed])").each(function(){
|
|
$(this).prop('disabled', true);
|
|
});
|
|
|
|
// grab a JSON representation of the form via form2js
|
|
var formJSON = form2js('settings-form', ".", false, cleanupFormValues, true);
|
|
|
|
console.log(formJSON);
|
|
|
|
// re-enable all inputs
|
|
$("input").each(function(){
|
|
$(this).prop('disabled', false);
|
|
});
|
|
|
|
// remove focus from the button
|
|
$(this).blur()
|
|
|
|
// POST the form JSON to the domain-server settings.json endpoint so the settings are saved
|
|
$.ajax('/settings.json', {
|
|
data: JSON.stringify(formJSON),
|
|
contentType: 'application/json',
|
|
type: 'POST'
|
|
}).done(function(data){
|
|
if (data.status == "success") {
|
|
showRestartModal();
|
|
} else {
|
|
showAlertMessage(SETTINGS_ERROR_MESSAGE, false);
|
|
reloadSettings();
|
|
}
|
|
}).fail(function(){
|
|
showAlertMessage(SETTINGS_ERROR_MESSAGE, false);
|
|
reloadSettings();
|
|
});
|
|
|
|
return false;
|
|
});
|
|
|
|
function makeTable(setting, setting_name, setting_value) {
|
|
var html = "<div class='panel panel-default'>"
|
|
html += "<div class='panel-heading'>" + setting.label + "</div>"
|
|
html += "<div class='panel-body'>"
|
|
html += "<p>" + setting.help + "</p>"
|
|
html += "</div>"
|
|
html += "<table class='table' name='" + setting_name + "'>"
|
|
|
|
// Column names
|
|
html += "<tr class='headers'>"
|
|
if (setting.number === true) {
|
|
html += "<td class='number'><strong>#</strong></td>" // Row number
|
|
}
|
|
html += "<td class='key'><strong>" + setting.key.label + "</strong></td>" // Key
|
|
_.each(setting.columns, function(col) {
|
|
html += "<td class='data'><strong>" + col.label + "</strong></td>" // Data
|
|
})
|
|
if (setting.can_delete === true || setting.can_add === true) {
|
|
html += "<td class='buttons'></td>" // Buttons
|
|
}
|
|
html += "</tr>"
|
|
|
|
// Rows
|
|
var row_num = 1
|
|
_.each(setting_value, function(row, name) {
|
|
html += "<tr class='row-data' name='" + setting_name + "." + name + "'>"
|
|
if (setting.number === true) {
|
|
html += "<td class='number'>" + row_num + "</td>"
|
|
}
|
|
html += "<td class='key'>" + name + "</td>"
|
|
_.each(setting.columns, function(col) {
|
|
html += "<td class='data'>"
|
|
if (row.hasOwnProperty(col.name)) {
|
|
html += row[col.name]
|
|
}
|
|
html += "</td>"
|
|
})
|
|
if (setting.can_delete === true) {
|
|
html += "<td class='buttons'><span class='glyphicon glyphicon-remove del-row'></span></td>"
|
|
} else if (setting.can_add === true) {
|
|
html += "<td class='buttons'></td>"
|
|
}
|
|
html += "</tr>"
|
|
row_num++
|
|
})
|
|
|
|
// Inputs
|
|
if (setting.can_add === true) {
|
|
html += makeTableInputs(setting)
|
|
}
|
|
|
|
html += "</table>"
|
|
html += "</div>"
|
|
|
|
return html;
|
|
}
|
|
|
|
function makeTableInputs(setting) {
|
|
var html = "<tr class='inputs'>"
|
|
if (setting.number === true) {
|
|
html += "<td class='number'></td>"
|
|
}
|
|
html += "<td class='key' name='" + setting.key.name + "'>\
|
|
<input type='text' class='form-control' placeholder='" + setting.key.placeholder + "' value=''>\
|
|
</td>"
|
|
_.each(setting.columns, function(col) {
|
|
html += "<td class='data'name='" + col.name + "'>\
|
|
<input type='text' class='form-control' placeholder='" + col.placeholder + "' value=''>\
|
|
</td>"
|
|
})
|
|
html += "<td class='buttons'><span class='glyphicon glyphicon-ok add-row'></span></td>"
|
|
html += "</tr>"
|
|
|
|
return html
|
|
}
|
|
|
|
function badgeSidebarForDifferences(changedInput) {
|
|
// figure out which group this input is in
|
|
var panelParentID = changedInput.closest('.panel').attr('id')
|
|
|
|
// get a JSON representation of that section
|
|
var rootJSON = form2js(panelParentID, ".", false, cleanupFormValues, true);
|
|
var panelJSON = rootJSON[panelParentID]
|
|
|
|
var badgeValue = 0
|
|
|
|
for (var setting in panelJSON) {
|
|
if (panelJSON[setting] != Settings.initialValues[panelParentID][setting]) {
|
|
badgeValue += 1
|
|
}
|
|
}
|
|
|
|
// update the list-group-item badge to have the new value
|
|
if (badgeValue == 0) {
|
|
badgeValue = ""
|
|
}
|
|
|
|
$("a[href='#" + panelParentID + "'] .badge").html(badgeValue);
|
|
}
|
|
|
|
function showRestartModal() {
|
|
$('#restart-modal').modal({
|
|
backdrop: 'static',
|
|
keyboard: false
|
|
});
|
|
|
|
var secondsElapsed = 0;
|
|
var numberOfSecondsToWait = 3;
|
|
|
|
var refreshSpan = $('span#refresh-time')
|
|
refreshSpan.html(numberOfSecondsToWait + " seconds");
|
|
|
|
// call ourselves every 1 second to countdown
|
|
var refreshCountdown = setInterval(function(){
|
|
secondsElapsed++;
|
|
secondsLeft = numberOfSecondsToWait - secondsElapsed
|
|
refreshSpan.html(secondsLeft + (secondsLeft == 1 ? " second" : " seconds"))
|
|
|
|
if (secondsElapsed == numberOfSecondsToWait) {
|
|
location.reload(true);
|
|
clearInterval(refreshCountdown);
|
|
}
|
|
}, 1000);
|
|
}
|
|
|
|
function cleanupFormValues(node) {
|
|
if (node.type && node.type === 'checkbox') {
|
|
return { name: node.name, value: node.checked ? true : false };
|
|
} else {
|
|
return false;
|
|
}
|
|
}
|
|
|
|
function showAlertMessage(message, isSuccess) {
|
|
var alertBox = $('.alert');
|
|
alertBox.attr('class', 'alert');
|
|
alertBox.addClass(isSuccess ? 'alert-success' : 'alert-danger');
|
|
alertBox.html(message);
|
|
alertBox.fadeIn();
|
|
}
|
|
|
|
function chooseFromHighFidelityDomains(clickedButton) {
|
|
// setup the modal to help user pick their domain
|
|
if (Settings.initialValues.metaverse.access_token) {
|
|
|
|
// add a spinner to the choose button
|
|
clickedButton.html("Loading domains...")
|
|
clickedButton.attr('disabled', 'disabled')
|
|
|
|
// get a list of user domains from data-web
|
|
data_web_domains_url = "https://data.highfidelity.io/api/v1/domains?access_token="
|
|
$.getJSON(data_web_domains_url + Settings.initialValues.metaverse.access_token, function(data){
|
|
|
|
modal_buttons = {
|
|
cancel: {
|
|
label: 'Cancel',
|
|
className: 'btn-default'
|
|
}
|
|
}
|
|
|
|
if (data.data.domains.length) {
|
|
// setup a select box for the returned domains
|
|
modal_body = "<p>Choose the High Fidelity domain you want this domain-server to represent.<br/>This will set your domain ID on the settings page.</p>"
|
|
domain_select = $("<select id='domain-name-select' class='form-control'></select>")
|
|
_.each(data.data.domains, function(domain){
|
|
domain_select.append("<option value='" + domain.id + "'>" + domain.name + "</option>")
|
|
})
|
|
modal_body += "<label for='domain-name-select'>Domains</label>" + domain_select[0].outerHTML
|
|
modal_buttons["success"] = {
|
|
label: 'Choose domain',
|
|
callback: function() {
|
|
domainID = $('#domain-name-select').val()
|
|
// set the domain ID on the form
|
|
$("[name='metaverse.id']").val(domainID).change();
|
|
}
|
|
}
|
|
} else {
|
|
modal_buttons["success"] = {
|
|
label: 'Create new domain',
|
|
callback: function() {
|
|
window.open("https://data.highfidelity.io/user/domains", '_blank');
|
|
}
|
|
}
|
|
modal_body = "<p>You do not have any domains in your High Fidelity account." +
|
|
"<br/><br/>Go to your domains page to create a new one. Once your domain is created re-open this dialog to select it.</p>"
|
|
}
|
|
|
|
|
|
bootbox.dialog({
|
|
title: "Choose matching domain",
|
|
message: modal_body,
|
|
buttons: modal_buttons
|
|
})
|
|
|
|
// remove the spinner from the choose button
|
|
clickedButton.html("Choose from my domains")
|
|
clickedButton.removeAttr('disabled')
|
|
})
|
|
|
|
} else {
|
|
bootbox.alert({
|
|
message: "You must have an access token to query your High Fidelity domains.<br><br>" +
|
|
"Please follow the instructions on the settings page to add an access token.",
|
|
title: "Access token required"
|
|
})
|
|
}
|
|
} |