diff --git a/src/main/html/webapp/components/core/job/detail/logs/logs.js b/src/main/html/webapp/components/core/job/detail/logs/logs.js index 02123b3b..1589ac64 100644 --- a/src/main/html/webapp/components/core/job/detail/logs/logs.js +++ b/src/main/html/webapp/components/core/job/detail/logs/logs.js @@ -1,18 +1,59 @@ import $ from 'jquery'; import Control from 'can-control'; - import template from './logs.stache'; - export default Control.extend({ + init: function(element, options) { + this.element = element; + this.options = options; + this.loadLogs(); + + // Start refresh if job is in running state (state 1, 2, or 3) + if ([1, 2, 3].includes(options.job.attr('state'))) { + this.startRefresh(); + } - "init": function(element, options) { + // Listen for state changes + this.options.job.bind('state', (ev, newState) => { + if ([1, 2, 3].includes(newState)) { + this.startRefresh(); + } else { + this.stopRefresh(); + } + }); + }, - $.get('logs/' + options.job.attr('id'),function(data) { - $(element).html(template({ + loadLogs: function() { + $.get('logs/' + this.options.job.attr('id'), (data) => { + $(this.element).html(template({ content: data, - job: options.job + job: this.options.job })); + + // Auto scroll to bottom after content loads + const preElement = $(this.element).find('pre'); + preElement.scrollTop(preElement[0].scrollHeight); }); + }, + + startRefresh: function() { + if (!this.refreshInterval) { + this.refreshInterval = setInterval(() => { + this.loadLogs(); + }, 5000); + } + }, + + stopRefresh: function() { + if (this.refreshInterval) { + clearInterval(this.refreshInterval); + this.refreshInterval = null; + } + }, + + destroy: function() { + this.stopRefresh(); + this.options.job.unbind('state'); + Control.prototype.destroy.call(this); } }); diff --git a/src/main/html/webapp/components/core/job/detail/logs/logs.stache b/src/main/html/webapp/components/core/job/detail/logs/logs.stache index 907ff178..3ae3d687 100644 --- a/src/main/html/webapp/components/core/job/detail/logs/logs.stache +++ b/src/main/html/webapp/components/core/job/detail/logs/logs.stache @@ -8,7 +8,7 @@
{{{ansiToHtml(content)}}}+
{{{ansiToHtml(content)}}}