mirror of
				https://github.com/hyperion-project/hyperion.ng.git
				synced 2025-03-01 10:33:28 +00:00 
			
		
		
		
	* SPI Fix - Free allocated memory in case of invert * Remove development statement * UI updates * Minor corrections * Tpm2net Fix - Free allocated memory * LGTM Finding * Add config directory and user type to SysInfo * WS281x - Ensure that device runs with root priviliges * WS281x - Update DMA defauls as per rpi_ws281x recommendation * Support Sysinfo for Qt < 5.10 * Address LGTM finding
		
			
				
	
	
		
			186 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			186 lines
		
	
	
		
			6.0 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
var conf_editor = null;
 | 
						|
var createdCont = false;
 | 
						|
var isScroll = true;
 | 
						|
 | 
						|
performTranslation();
 | 
						|
requestLoggingStop();
 | 
						|
 | 
						|
$(document).ready(function () {
 | 
						|
 | 
						|
  requestLoggingStart();
 | 
						|
 | 
						|
  $('#conf_cont').append(createOptPanel('fa-reorder', $.i18n("edt_conf_log_heading_title"), 'editor_container', 'btn_submit'));
 | 
						|
  if (window.showOptHelp) {
 | 
						|
    $('#conf_cont').append(createHelpTable(window.schema.logger.properties, $.i18n("edt_conf_log_heading_title")));
 | 
						|
    createHintH("intro", $.i18n('conf_logging_label_intro'), "log_head");
 | 
						|
  }
 | 
						|
 | 
						|
  conf_editor = createJsonEditor('editor_container', {
 | 
						|
    logger: window.schema.logger
 | 
						|
  }, true, true);
 | 
						|
 | 
						|
  conf_editor.on('change', function () {
 | 
						|
    conf_editor.validate().length || window.readOnlyMode ? $('#btn_submit').attr('disabled', true) : $('#btn_submit').attr('disabled', false);
 | 
						|
  });
 | 
						|
 | 
						|
  $('#btn_submit').off().on('click', function () {
 | 
						|
 | 
						|
    var displayedLogLevel = conf_editor.getEditor("root.logger.level").getValue();
 | 
						|
    var newLogLevel = { logger: {} };
 | 
						|
    newLogLevel.logger.level = displayedLogLevel;
 | 
						|
 | 
						|
    requestWriteConfig(newLogLevel);
 | 
						|
  });
 | 
						|
 | 
						|
  function infoSummary() {
 | 
						|
    var info = "";
 | 
						|
 | 
						|
    info += 'Hyperion System Summary Report (' + window.serverConfig.general.name + '), Reported instance: ' + window.currentHyperionInstanceName + '\n';
 | 
						|
 | 
						|
    info += "\n< ----- System information -------------------- >\n";
 | 
						|
    info += getSystemInfo() + '\n';
 | 
						|
 | 
						|
    info += "\n< ----- Configured Instances ------------------ >\n";
 | 
						|
    var instances = window.serverInfo.instance;
 | 
						|
    for (var i = 0; i < instances.length; i++) {
 | 
						|
      info += instances[i].instance + ': ' + instances[i].friendly_name + ' Running: ' + instances[i].running + '\n';
 | 
						|
    }
 | 
						|
 | 
						|
    info += "\n< ----- This instance's priorities ------------ >\n";
 | 
						|
    var prios = window.serverInfo.priorities;
 | 
						|
    for (var i = 0; i < prios.length; i++) {
 | 
						|
      info += prios[i].priority + ': ';
 | 
						|
      if (prios[i].visible) {
 | 
						|
        info += ' VISIBLE!';
 | 
						|
      }
 | 
						|
      else {
 | 
						|
        info += '         ';
 | 
						|
      }
 | 
						|
      info += ' (' + prios[i].componentId + ') Owner: ' + prios[i].owner + '\n';
 | 
						|
    }
 | 
						|
    info += 'priorities_autoselect: ' + window.serverInfo.priorities_autoselect + '\n';
 | 
						|
 | 
						|
    info += "\n< ----- This instance components' status ------->\n";
 | 
						|
    var comps = window.serverInfo.components;
 | 
						|
    for (var i = 0; i < comps.length; i++) {
 | 
						|
      info += comps[i].name + ' - ' + comps[i].enabled + '\n';
 | 
						|
    }
 | 
						|
 | 
						|
    info += "\n< ----- This instance's configuration --------- >\n";
 | 
						|
    info += JSON.stringify(window.serverConfig) + '\n';
 | 
						|
 | 
						|
    info += "\n< ----- Current Log --------------------------- >\n";
 | 
						|
    var logMsgs = document.getElementById("logmessages").textContent;
 | 
						|
    if (logMsgs.length !== 0) {
 | 
						|
      info += logMsgs;
 | 
						|
    } else {
 | 
						|
      info += "Log is empty!";
 | 
						|
    }
 | 
						|
 | 
						|
    return info;
 | 
						|
  }
 | 
						|
 | 
						|
  function createLogContainer() {
 | 
						|
 | 
						|
    const isScrollEnableStyle = (isScroll ? "checked" : "");
 | 
						|
 | 
						|
    $('#log_content').html('<pre><div id="logmessages" style="overflow:scroll;max-height:400px"></div></pre>');
 | 
						|
    $('#log_footer').append('<label class="checkbox-inline">'
 | 
						|
      + '<input id = "btn_scroll"' + isScrollEnableStyle + ' type = "checkbox"'
 | 
						|
      + 'data-toggle="toggle" data-onstyle="success" data-on="' + $.i18n('general_btn_on') + '" data-off="' + $.i18n('general_btn_off') + '">'
 | 
						|
      + $.i18n('conf_logging_btn_autoscroll') + '</label>'
 | 
						|
    );
 | 
						|
 | 
						|
    $(`#btn_scroll`).bootstrapToggle();
 | 
						|
    $(`#btn_scroll`).change(e => {
 | 
						|
      if (e.currentTarget.checked) {
 | 
						|
        //Scroll to end of log
 | 
						|
        isScroll = true;
 | 
						|
        if ($("#logmessages").length > 0) {
 | 
						|
          $('#logmessages')[0].scrollTop = $('#logmessages')[0].scrollHeight;
 | 
						|
        }
 | 
						|
      } else {
 | 
						|
        isScroll = false;
 | 
						|
      }
 | 
						|
    });
 | 
						|
 | 
						|
    $('#log_footer').append('<button class="btn btn-primary pull-right" id="btn_clipboard"><i class="fa fa-fw fa-clipboard"></i>' + $.i18n("conf_logging_btn_clipboard") + '</button>');
 | 
						|
 | 
						|
    $('#btn_clipboard').off().on('click', function () {
 | 
						|
      const temp = document.createElement('textarea');
 | 
						|
      temp.textContent = infoSummary();
 | 
						|
      document.body.append(temp);
 | 
						|
      temp.select();
 | 
						|
      document.execCommand("copy");
 | 
						|
      temp.remove();
 | 
						|
    });
 | 
						|
  }
 | 
						|
 | 
						|
  function updateLogOutput(messages) {
 | 
						|
 | 
						|
    if (messages.length != 0) {
 | 
						|
 | 
						|
      for (var idx = 0; idx < messages.length; idx++) {
 | 
						|
        var app_name = messages[idx].appName;
 | 
						|
        var logger_name = messages[idx].loggerName;
 | 
						|
        var function_ = messages[idx].function;
 | 
						|
        var line = messages[idx].line;
 | 
						|
        var file_name = messages[idx].fileName;
 | 
						|
        var msg = encodeHTML(messages[idx].message);
 | 
						|
        var level_string = messages[idx].levelString;
 | 
						|
        var utime = messages[idx].utime;
 | 
						|
 | 
						|
        var debug = "";
 | 
						|
        if (level_string == "DEBUG") {
 | 
						|
          debug = "(" + file_name + ":" + line + ":" + function_ + "()) ";
 | 
						|
        }
 | 
						|
 | 
						|
        var date = new Date(parseInt(utime));
 | 
						|
        var newLogLine = date.toISOString() + " [" + app_name + " " + logger_name + "] (" + level_string + ") " + debug + msg;
 | 
						|
 | 
						|
        $("#logmessages").append("<code>" + newLogLine + "</code>\n");
 | 
						|
      }
 | 
						|
 | 
						|
      if (isScroll && $("#logmessages").length > 0) {
 | 
						|
        $('#logmessages').stop().animate({
 | 
						|
          scrollTop: $('#logmessages')[0].scrollHeight
 | 
						|
        }, 800);
 | 
						|
      }
 | 
						|
    }
 | 
						|
  }
 | 
						|
 | 
						|
  if (!window.loggingHandlerInstalled) {
 | 
						|
    window.loggingHandlerInstalled = true;
 | 
						|
 | 
						|
    $(window.hyperion).on("cmd-logging-update", function (event) {
 | 
						|
 | 
						|
      var messages = (event.response.result.messages);
 | 
						|
 | 
						|
      if (messages.length != 0) {
 | 
						|
        if (!createdCont) {
 | 
						|
          createLogContainer();
 | 
						|
          createdCont = true;
 | 
						|
        }
 | 
						|
        updateLogOutput(messages)
 | 
						|
      }
 | 
						|
    });
 | 
						|
  }
 | 
						|
 | 
						|
  $(window.hyperion).on("cmd-settings-update", function (event) {
 | 
						|
 | 
						|
    var obj = event.response.data
 | 
						|
    if (obj.logger) {
 | 
						|
      Object.getOwnPropertyNames(obj).forEach(function (val, idx, array) {
 | 
						|
        window.serverConfig[val] = obj[val];
 | 
						|
      });
 | 
						|
 | 
						|
      var currentlogLevel = window.serverConfig.logger.level;
 | 
						|
      conf_editor.getEditor("root.logger.level").setValue(currentlogLevel);
 | 
						|
      location.reload();
 | 
						|
    }
 | 
						|
 | 
						|
  });
 | 
						|
 | 
						|
  removeOverlay();
 | 
						|
});
 |