forked from lix-project/hydra
Split viewing and editing a jobset
This commit is contained in:
parent
9c7b416f8b
commit
547e41263d
6 changed files with 277 additions and 239 deletions
|
@ -115,7 +115,7 @@ sub edit : Chained('jobset') PathPart Args(0) {
|
||||||
|
|
||||||
requireProjectOwner($c, $c->stash->{project});
|
requireProjectOwner($c, $c->stash->{project});
|
||||||
|
|
||||||
$c->stash->{template} = 'jobset.tt';
|
$c->stash->{template} = 'edit-jobset.tt';
|
||||||
$c->stash->{edit} = 1;
|
$c->stash->{edit} = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -235,8 +235,8 @@ sub updateJobset {
|
||||||
, description => trim($c->request->params->{"description"})
|
, description => trim($c->request->params->{"description"})
|
||||||
, nixexprpath => $nixExprPath
|
, nixexprpath => $nixExprPath
|
||||||
, nixexprinput => $nixExprInput
|
, nixexprinput => $nixExprInput
|
||||||
, enabled => trim($c->request->params->{enabled}) eq "1" ? 1 : 0
|
, enabled => defined $c->request->params->{enabled} ? 1 : 0
|
||||||
, enableemail => trim($c->request->params->{enableemail}) eq "1" ? 1 : 0
|
, enableemail => defined $c->request->params->{enableemail} ? 1 : 0
|
||||||
, emailoverride => trim($c->request->params->{emailoverride}) || ""
|
, emailoverride => trim($c->request->params->{emailoverride}) || ""
|
||||||
, keepnr => trim($c->request->params->{keepnr}) || 3
|
, keepnr => trim($c->request->params->{keepnr}) || 3
|
||||||
});
|
});
|
||||||
|
|
|
@ -110,7 +110,7 @@ sub create_jobset : Chained('project') PathPart('create-jobset') Args(0) {
|
||||||
|
|
||||||
requireProjectOwner($c, $c->stash->{project});
|
requireProjectOwner($c, $c->stash->{project});
|
||||||
|
|
||||||
$c->stash->{template} = 'jobset.tt';
|
$c->stash->{template} = 'edit-jobset.tt';
|
||||||
$c->stash->{create} = 1;
|
$c->stash->{create} = 1;
|
||||||
$c->stash->{edit} = 1;
|
$c->stash->{edit} = 1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -196,11 +196,6 @@ BLOCK maybeLink;
|
||||||
END;
|
END;
|
||||||
|
|
||||||
|
|
||||||
BLOCK maybeButton;
|
|
||||||
IF uri %]<a class="btn btn-mini" [% HTML.attributes(href => uri); IF confirmmsg %]onclick="javascript:return confirm('[% confirmmsg %]')"[% END; content %]</a>[% ELSE; content; END;
|
|
||||||
END;
|
|
||||||
|
|
||||||
|
|
||||||
BLOCK renderSelection;
|
BLOCK renderSelection;
|
||||||
IF edit;
|
IF edit;
|
||||||
IF radiobuttons; %]
|
IF radiobuttons; %]
|
||||||
|
@ -227,21 +222,8 @@ BLOCK renderSelection;
|
||||||
END;
|
END;
|
||||||
|
|
||||||
|
|
||||||
BLOCK maybeEditString;
|
BLOCK editString; %]
|
||||||
IF edit %]
|
<input type="text" class="string" [% HTML.attributes(id => param, name => param, value => value) %] />
|
||||||
<input type="text" class="string [% extraClass %]" [% HTML.attributes(id => param, name => param, value => value) %] />
|
|
||||||
[% ELSE;
|
|
||||||
HTML.escape(value);
|
|
||||||
END;
|
|
||||||
END;
|
|
||||||
|
|
||||||
|
|
||||||
BLOCK editString;
|
|
||||||
IF edit %]
|
|
||||||
<input type="text" class="string" [% HTML.attributes(id => param, name => param, value => value) %] />
|
|
||||||
[% ELSE;
|
|
||||||
HTML.escape(value);
|
|
||||||
END;
|
|
||||||
END;
|
END;
|
||||||
|
|
||||||
|
|
||||||
|
|
143
src/root/edit-jobset.tt
Normal file
143
src/root/edit-jobset.tt
Normal file
|
@ -0,0 +1,143 @@
|
||||||
|
[% WRAPPER layout.tt title=(create ? "Create jobset in project $project.name" : "Editing jobset $project.name:$jobset.name") %]
|
||||||
|
[% PROCESS common.tt %]
|
||||||
|
|
||||||
|
[% BLOCK renderInputAlt %]
|
||||||
|
<button type="button" class="btn btn-warning" onclick='$(this).parents(".inputalt").remove()'><i class="icon-trash icon-white"></i></button>
|
||||||
|
<input type="text" [% HTML.attributes(value => alt.value, name => name) %]></input>
|
||||||
|
<br />
|
||||||
|
[% END %]
|
||||||
|
|
||||||
|
[% BLOCK renderInput %]
|
||||||
|
<tr class="input [% extraClass %]" [% IF id %]id="[% id %]"[% END %]>
|
||||||
|
<td>
|
||||||
|
<button type="button" class="btn btn-warning" onclick='$(this).parents(".input").remove()'><i class="icon-trash icon-white"></i></button>
|
||||||
|
<tt><input type="text" name="[% baseName %]-name" [% HTML.attributes(value => input.name) %]></input>
|
||||||
|
</td>
|
||||||
|
<td>
|
||||||
|
[% INCLUDE renderSelection curValue=input.type param="$baseName-type" options=inputTypes %]
|
||||||
|
</td>
|
||||||
|
<td class="inputalts" id="[% baseName %]">
|
||||||
|
[% FOREACH alt IN input.jobsetinputalts %]
|
||||||
|
<span class="inputalt">
|
||||||
|
[% INCLUDE renderInputAlt alt=alt name="$baseName-values" %]
|
||||||
|
</span>
|
||||||
|
[% END %]
|
||||||
|
[% IF edit %]<button type="button" class="add-inputalt btn btn-success" onclick='return false'><i class="icon-plus icon-white"></i></button>[% END %]
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
[% END %]
|
||||||
|
|
||||||
|
[% BLOCK renderInputs %]
|
||||||
|
<table class="table table-striped table-condensed">
|
||||||
|
<thead>
|
||||||
|
<tr><th>Input name</th><th>Type</th><th>Values</th></tr>
|
||||||
|
</thead>
|
||||||
|
<tbody class="inputs">
|
||||||
|
[% FOREACH input IN jobset.jobsetinputs %]
|
||||||
|
[% INCLUDE renderInput input=input baseName="input-$input.name" %]
|
||||||
|
[% END %]
|
||||||
|
<tr>
|
||||||
|
<td colspan="3" style="text-align: center;"><button type="button" class="add-input btn btn-success"><i class="icon-plus icon-white"></i> Add a new input</button></td
|
||||||
|
</tr>
|
||||||
|
</tbody>
|
||||||
|
</table>
|
||||||
|
[% END %]
|
||||||
|
|
||||||
|
<form class="form-horizontal" action="[% IF create %][% c.uri_for('/project' project.name 'create-jobset/submit') %][% ELSE %][% c.uri_for('/jobset' project.name jobset.name 'submit') %][% END %]" method="post">
|
||||||
|
|
||||||
|
<fieldset>
|
||||||
|
|
||||||
|
<div class="control-group">
|
||||||
|
<div class="controls">
|
||||||
|
<label class="checkbox">
|
||||||
|
<input type="checkbox" name="enabled" [% IF jobset.enabled; 'checked="checked"'; END %]></input>Enabled
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label">Identifier</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input type="text" class="span3" name="name" [% HTML.attributes(value => jobset.name) %]></input>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label">Description</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input type="text" class="span3" name="description" [% HTML.attributes(value => jobset.description) %]></input>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label">Nix expression</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input type="text" class="span3" name="nixexprpath" [% HTML.attributes(value => jobset.nixexprpath) %]></input>
|
||||||
|
in
|
||||||
|
<input type="text" class="span3" name="nixexprinput" [% HTML.attributes(value => jobset.nixexprinput) %]></input>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="control-group">
|
||||||
|
<div class="controls">
|
||||||
|
<label class="checkbox">
|
||||||
|
<input type="checkbox" name="enableemail" [% IF jobset.enableemail; 'checked="checked"'; END %]></input>Email notification
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label">Email override</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input type="text" class="span3" name="emailoverride" [% HTML.attributes(value => jobset.emailoverride) %]></input>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div class="control-group">
|
||||||
|
<label class="control-label">Number of builds to keep</label>
|
||||||
|
<div class="controls">
|
||||||
|
<input type="number" class="span3" name="keepnr" [% HTML.attributes(value => jobset.keepnr) %]></input>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
[% INCLUDE renderInputs %]
|
||||||
|
|
||||||
|
<div class="form-actions">
|
||||||
|
<button type="submit" class="btn btn-primary"><i class="icon-ok icon-white"></i> [%IF create %]Create[% ELSE %]Apply changes[% END %]</button>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</fieldset>
|
||||||
|
|
||||||
|
<table class="hidden">
|
||||||
|
[% INCLUDE renderInput input="" extraClass="template" id="input-template" baseName="input-template" %]
|
||||||
|
</table>
|
||||||
|
|
||||||
|
<tt class="inputalt hidden" id="inputalt-template">
|
||||||
|
[% INCLUDE renderInputAlt alt=alt %]
|
||||||
|
</tt>
|
||||||
|
|
||||||
|
<script type="text/javascript">
|
||||||
|
$(document).ready(function() {
|
||||||
|
var id = 0;
|
||||||
|
|
||||||
|
$(".add-input").click(function() {
|
||||||
|
var newid = "input-" + id++;
|
||||||
|
var x = $("#input-template").clone(true).attr("id", "").insertBefore($(this).parents("tr")).show();
|
||||||
|
$("#input-template-name", x).attr("name", newid + "-name");
|
||||||
|
$("#input-template-type", x).attr("name", newid + "-type");
|
||||||
|
$("#input-template", x).attr("id", newid);
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
|
||||||
|
$(".add-inputalt").click(function() {
|
||||||
|
var x = $("#inputalt-template").clone(true).insertBefore($(this)).attr("id", "").show();
|
||||||
|
$("input", x).attr("name", x.parents(".inputalts").attr("id") + "-values");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
</form>
|
||||||
|
|
||||||
|
[% END %]
|
||||||
|
|
||||||
|
|
|
@ -8,12 +8,12 @@
|
||||||
<div class="control-group">
|
<div class="control-group">
|
||||||
<div class="controls">
|
<div class="controls">
|
||||||
<label class="checkbox">
|
<label class="checkbox">
|
||||||
<input type="checkbox" name="enabled" value="enabled" [% IF project.enabled; 'checked="checked"'; END %]></input>Enabled
|
<input type="checkbox" name="enabled" [% IF project.enabled; 'checked="checked"'; END %]></input>Enabled
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
<div class="controls">
|
<div class="controls">
|
||||||
<label class="checkbox">
|
<label class="checkbox">
|
||||||
<input type="checkbox" name="visible" value="visible" [% IF !project.hidden; 'checked="checked"'; END %]></input>Visible in the list of projects
|
<input type="checkbox" name="visible" [% IF !project.hidden; 'checked="checked"'; END %]></input>Visible in the list of projects
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -1,28 +1,11 @@
|
||||||
[% WRAPPER layout.tt title=(edit ? (create ? "Create jobset in project $project.name" : "Editing jobset $project.name:$jobset.name") : "Jobset $project.name:$jobset.name") %]
|
[% WRAPPER layout.tt title="Jobset $project.name:$jobset.name" %]
|
||||||
[% PROCESS common.tt %]
|
[% PROCESS common.tt %]
|
||||||
|
|
||||||
[% IF edit %]
|
|
||||||
<form class="form-horizontal" action="[% IF create %][% c.uri_for('/project' project.name 'create-jobset/submit') %][% ELSE %][% c.uri_for('/jobset' project.name jobset.name 'submit') %][% END %]" method="post">
|
|
||||||
[% END %]
|
|
||||||
|
|
||||||
|
|
||||||
[% BLOCK renderInputAlt %]
|
|
||||||
[% IF edit %]
|
|
||||||
<button type="button" class="btn btn-warning" onclick='$(this).parents(".inputalt").remove()'><i class="icon-trash icon-white"></i></button>
|
|
||||||
[% INCLUDE maybeEditString param=param value=alt.value %]
|
|
||||||
<br />
|
|
||||||
[% ELSE %]
|
|
||||||
[% INCLUDE maybeEditString param=param value=alt.value %]
|
|
||||||
[% END %]
|
|
||||||
[% END %]
|
|
||||||
|
|
||||||
|
|
||||||
[% BLOCK renderInput %]
|
[% BLOCK renderInput %]
|
||||||
|
|
||||||
<tr class="input [% extraClass %]" [% IF id %]id="[% id %]"[% END %]>
|
<tr class="input [% extraClass %]" [% IF id %]id="[% id %]"[% END %]>
|
||||||
<td>
|
<td>
|
||||||
[% IF edit %]<button type="button" class="btn btn-warning" onclick='$(this).parents(".input").remove()'><i class="icon-trash icon-white"></i></button>[% END %]
|
<tt>[% HTML.escape(input.name) %]</tt>
|
||||||
<tt>[% INCLUDE maybeEditString param="$baseName-name" value=input.name %]</tt>
|
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
[% INCLUDE renderSelection curValue=input.type param="$baseName-type" options=inputTypes %]
|
[% INCLUDE renderSelection curValue=input.type param="$baseName-type" options=inputTypes %]
|
||||||
|
@ -30,230 +13,160 @@
|
||||||
<td class="inputalts" id="[% baseName %]">
|
<td class="inputalts" id="[% baseName %]">
|
||||||
[% FOREACH alt IN input.jobsetinputalts %]
|
[% FOREACH alt IN input.jobsetinputalts %]
|
||||||
<tt class="inputalt">
|
<tt class="inputalt">
|
||||||
[% IF input.type == "string" && !edit %]
|
[% IF input.type == "string" %]
|
||||||
"[% HTML.escape(alt.value) %]"
|
"[% HTML.escape(alt.value) %]"
|
||||||
[% ELSE %]
|
[% ELSE %]
|
||||||
[% INCLUDE renderInputAlt alt=alt param="$baseName-values" %]
|
[% HTML.escape(alt.value) %]
|
||||||
[% END %]
|
[% END %]
|
||||||
</tt>
|
</tt>
|
||||||
[% END %]
|
[% END %]
|
||||||
[% IF edit %]<button type="button" class="add-inputalt btn btn-success" onclick='return false'><i class="icon-plus icon-white"></i></button>[% END %]
|
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
[% END %]
|
[% END %]
|
||||||
|
|
||||||
|
|
||||||
[% BLOCK renderInputs %]
|
[% BLOCK renderInputs %]
|
||||||
<h3>Inputs</h3>
|
<h3>Inputs</h3>
|
||||||
|
<table class="tablesorter table table-striped table-condensed">
|
||||||
<table class="tablesorter table table-striped table-condensed">
|
<thead>
|
||||||
<thead>
|
<tr><th>Input name</th><th>Type</th><th>Values</th></tr>
|
||||||
<tr><th>Input name</th><th>Type</th><th>Values</th></tr>
|
</thead>
|
||||||
</thead>
|
<tbody class="inputs">
|
||||||
<tbody class="inputs">
|
[% FOREACH input IN jobset.jobsetinputs %]
|
||||||
[% FOREACH input IN jobset.jobsetinputs %]
|
[% INCLUDE renderInput input=input baseName="input-$input.name" %]
|
||||||
[% INCLUDE renderInput input=input baseName="input-$input.name" %]
|
[% END %]
|
||||||
[% END %]
|
</tbody>
|
||||||
[% IF edit %]
|
</table>
|
||||||
<tr>
|
|
||||||
<td colspan="3" style="text-align: center;"><button type="button" class="add-input btn btn-success"><i class="icon-plus icon-white"></i> Add a new input</button></td>
|
|
||||||
</tr>
|
|
||||||
[% END %]
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
[% END %]
|
[% END %]
|
||||||
|
|
||||||
|
|
||||||
<ul class="nav nav-tabs">
|
<ul class="nav nav-tabs">
|
||||||
[% IF !edit %]
|
<li class="active"><a href="#tabs-information" data-toggle="tab">Jobset</a></li>
|
||||||
<li class="active"><a href="#tabs-information" data-toggle="tab">Jobset</a></li>
|
[% IF jobset.errormsg %]
|
||||||
[% IF jobset.errormsg %]<li><a href="#tabs-errors" data-toggle="tab"><img src="/static/images/error_16.png" /> Evaluation errors</a></li>[% END %]
|
<li><a href="#tabs-errors" data-toggle="tab"><img src="/static/images/error_16.png" /> Evaluation errors</a></li>
|
||||||
<li><a href="#tabs-jobs" data-toggle="tab">Jobs ([% activeJobs.size %])</a></li>
|
[% END %]
|
||||||
[% END %]
|
<li><a href="#tabs-jobs" data-toggle="tab">Jobs ([% activeJobs.size %])</a></li>
|
||||||
<li><a href="#tabs-setup" data-toggle="tab">Setup</a></li>
|
<li><a href="#tabs-setup" data-toggle="tab">Configuration</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
||||||
<div id="generic-tabs" class="tab-content">
|
<div id="generic-tabs" class="tab-content">
|
||||||
<div id="tabs-information" class="tab-pane active">
|
|
||||||
[% IF !edit && evals.size() > 0 %]
|
|
||||||
<h2>Most recent evaluations</h2>
|
|
||||||
[% INCLUDE renderEvals linkToAll=c.uri_for(c.controller('Jobset').action_for('evals'), [project.name, jobset.name]) %]
|
|
||||||
[% END %]
|
|
||||||
[% IF !edit && activeJobsStatus %]
|
|
||||||
<h2>Status</h2>
|
|
||||||
<table class="table table-striped table-condensed">
|
|
||||||
<thead><tr><th>Job</th>[% FOREACH s IN systems %]<th>[% s.system %]</th>[% END %]</tr></thead>
|
|
||||||
<tbody>
|
|
||||||
[% odd = 0 %]
|
|
||||||
[% FOREACH j IN activeJobsStatus %]
|
|
||||||
<tr class="[% IF odd %] odd [% END; odd = !odd %]">
|
|
||||||
<td>[% INCLUDE renderJobName project=project.name jobset = jobset.name job = j.get_column('job') %]</td>
|
|
||||||
[% FOREACH s IN systems %]
|
|
||||||
[% system = s.system %]
|
|
||||||
[% systemStatus = j.get_column(system) %]
|
|
||||||
<td class="centered">
|
|
||||||
[% IF systemStatus != undef %]
|
|
||||||
<a href="[% c.uri_for('/build' j.get_column(system _ '-build') ) %]">
|
|
||||||
[% INCLUDE renderBuildStatusIcon buildstatus=systemStatus size=16 %]
|
|
||||||
</a>
|
|
||||||
[% END %]
|
|
||||||
</td>
|
|
||||||
[% END %]
|
|
||||||
</tr>
|
|
||||||
[% END %]
|
|
||||||
</tbody>
|
|
||||||
</table>
|
|
||||||
[% END %]
|
|
||||||
[% IF !edit && !activeJobsStatus %]
|
|
||||||
<h2>Status</h2>
|
|
||||||
<p>
|
|
||||||
[ <a href="[% c.uri_for('/jobset' project.name jobset.name 'with-status' ) %]">Show status overview</a> ]
|
|
||||||
</p>
|
|
||||||
[% END %]
|
|
||||||
|
|
||||||
</div>
|
<div id="tabs-information" class="tab-pane active">
|
||||||
[% IF !edit %]
|
|
||||||
|
|
||||||
[% IF jobset.errormsg %]
|
[% IF evals.size() > 0 %]
|
||||||
<div id="tabs-errors" class="tab-pane">
|
<h2>Most recent evaluations</h2>
|
||||||
<h2>Evaluation errors</h2>
|
[% INCLUDE renderEvals linkToAll=c.uri_for(c.controller('Jobset').action_for('evals'), [project.name, jobset.name]) %]
|
||||||
<p>
|
[% END %]
|
||||||
Errors occurred at <tt>[% INCLUDE renderDateTime timestamp=jobset.errortime %]</tt>.
|
|
||||||
</p>
|
|
||||||
<pre class="multiLineMsg error">[% HTML.escape(jobset.errormsg) %]</pre>
|
|
||||||
</div>
|
|
||||||
[% END %]
|
|
||||||
[% END %]
|
|
||||||
<div id="tabs-setup" class="tab-pane [% IF edit %]active[% END %]">
|
|
||||||
<h2>Information</h2>
|
|
||||||
|
|
||||||
<table class="layoutTable">
|
[% IF activeJobsStatus %]
|
||||||
[% IF edit %]
|
<h2>Status</h2>
|
||||||
<tr>
|
<table class="table table-striped table-condensed">
|
||||||
<th>Identifier:</th>
|
<thead><tr><th>Job</th>[% FOREACH s IN systems %]<th>[% s.system %]</th>[% END %]</tr></thead>
|
||||||
<td>[% INCLUDE maybeEditString param="name" value=jobset.name %]</td>
|
<tbody>
|
||||||
</tr>
|
[% odd = 0 %]
|
||||||
[% END %]
|
[% FOREACH j IN activeJobsStatus %]
|
||||||
<tr>
|
<tr class="[% IF odd %] odd [% END; odd = !odd %]">
|
||||||
<th>Description:</th>
|
<td>[% INCLUDE renderJobName project=project.name jobset = jobset.name job = j.get_column('job') %]</td>
|
||||||
<td>[% INCLUDE maybeEditString param="description" value=jobset.description %]</td>
|
[% FOREACH s IN systems %]
|
||||||
</tr>
|
[% system = s.system %]
|
||||||
<tr>
|
[% systemStatus = j.get_column(system) %]
|
||||||
<th>Nix expression:</th>
|
<td class="centered">
|
||||||
<td>
|
[% IF systemStatus != undef %]
|
||||||
<tt>[% INCLUDE maybeEditString param="nixexprpath" value=jobset.nixexprpath %]</tt> in input
|
<a href="[% c.uri_for('/build' j.get_column(system _ '-build') ) %]">
|
||||||
<tt>[% INCLUDE maybeEditString param="nixexprinput" value=jobset.nixexprinput %]</tt>
|
[% INCLUDE renderBuildStatusIcon buildstatus=systemStatus size=16 %]
|
||||||
</td>
|
</a>
|
||||||
</tr>
|
[% END %]
|
||||||
<tr>
|
|
||||||
<th>Enabled:</th>
|
|
||||||
<td>
|
|
||||||
[% INCLUDE renderSelection param="enabled" curValue=jobset.enabled radiobuttons=1 options={"1" = "Yes", "0" = "No"} %]
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<th>Enable email notification:</th>
|
|
||||||
<td>
|
|
||||||
[% INCLUDE renderSelection param="enableemail" curValue=jobset.enableemail radiobuttons=1 options={"1" = "Yes", "0" = "No"} %]
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<th>Email override:</th>
|
|
||||||
<td>
|
|
||||||
[% INCLUDE maybeEditString param="emailoverride" value=jobset.emailoverride %]
|
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
[% END %]
|
||||||
<tr>
|
</tr>
|
||||||
<th>Number of builds to keep:</th>
|
[% END %]
|
||||||
<td>
|
</tbody>
|
||||||
[% INCLUDE maybeEditString param="keepnr" value=jobset.keepnr %]
|
</table>
|
||||||
</td>
|
[% ELSE %]
|
||||||
</tr>
|
<h2>Status</h2>
|
||||||
[% IF !edit %]
|
<p>
|
||||||
<tr>
|
[ <a href="[% c.uri_for('/jobset' project.name jobset.name 'with-status' ) %]">Show status overview</a> ]
|
||||||
<th>Last checked:</th>
|
</p>
|
||||||
<td>
|
[% END %]
|
||||||
[% IF jobset.lastcheckedtime %]
|
|
||||||
[% INCLUDE renderDateTime timestamp = jobset.lastcheckedtime %][% IF jobset.errormsg %]<em>, with errors!</em>
|
|
||||||
[% ELSE %], <em>no errors</em>
|
|
||||||
[% END %]
|
|
||||||
[% ELSE %]
|
|
||||||
<em>never</em>
|
|
||||||
[% END %]
|
|
||||||
</td>
|
|
||||||
</tr>
|
|
||||||
[% END %]
|
|
||||||
</table>
|
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
[% INCLUDE renderInputs %]
|
[% IF jobset.errormsg %]
|
||||||
</div>
|
<div id="tabs-errors" class="tab-pane">
|
||||||
[% IF !edit %]
|
<h2>Evaluation errors</h2>
|
||||||
<div id="tabs-jobs" class="tab-pane">
|
<p>
|
||||||
|
Errors occurred at <tt>[% INCLUDE renderDateTime timestamp=jobset.errortime %]</tt>.
|
||||||
|
</p>
|
||||||
|
<pre class="multiLineMsg error">[% HTML.escape(jobset.errormsg) %]</pre>
|
||||||
|
</div>
|
||||||
|
[% END %]
|
||||||
|
|
||||||
<h2>Jobs</h2>
|
<div id="tabs-setup" class="tab-pane">
|
||||||
|
<h2>Information</h2>
|
||||||
|
|
||||||
<p>This jobset currently contains the following [% activeJobs.size %] jobs:
|
<table class="layoutTable">
|
||||||
|
<tr>
|
||||||
|
<th>Description:</th>
|
||||||
|
<td>[% HTML.escape(jobset.description) %]</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Nix expression:</th>
|
||||||
|
<td>
|
||||||
|
<tt>[% HTML.escape(jobset.nixexprpath) %]</tt> in input
|
||||||
|
<tt>[% HTML.escape(jobset.nixexprinput) %]</tt>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Enabled:</th>
|
||||||
|
<td>[% jobset.enabled ? "Yes" : "No" %]</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Enable email notification:</th>
|
||||||
|
<td>[% jobset.enableemail ? "Yes" : "No" %]</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Email override:</th>
|
||||||
|
<td>[% HTML.escape(jobset.emailoverride) %]</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Number of builds to keep:</th>
|
||||||
|
<td>[% jobset.keepnr %]</td>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<th>Last checked:</th>
|
||||||
|
<td>
|
||||||
|
[% IF jobset.lastcheckedtime %]
|
||||||
|
[% INCLUDE renderDateTime timestamp = jobset.lastcheckedtime %][% IF jobset.errormsg %]<em>, with errors!</em>[% ELSE %], <em>no errors</em>[% END %]
|
||||||
|
[% ELSE %]
|
||||||
|
<em>never</em>
|
||||||
|
[% END %]
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
</table>
|
||||||
|
|
||||||
<blockquote>
|
[% INCLUDE renderInputs %]
|
||||||
[% IF activeJobs.size == 0 %]<em>(none)</em>[% END %]
|
</div>
|
||||||
[% FOREACH j IN activeJobs %][% INCLUDE renderJobName project=project.name jobset=jobset.name job=j %]<br/>[% END %]
|
|
||||||
</blockquote>
|
|
||||||
</p>
|
|
||||||
|
|
||||||
<p>This jobset used to contain the following [% inactiveJobs.size %] jobs:
|
<div id="tabs-jobs" class="tab-pane">
|
||||||
|
|
||||||
<blockquote>
|
<p>This jobset currently contains the following [% activeJobs.size %] jobs:
|
||||||
[% IF inactiveJobs.size == 0 %]<em>(none)</em>[% END %]
|
|
||||||
[% FOREACH j IN inactiveJobs %][% INCLUDE renderJobName project=project.name jobset=jobset.name job=j %]<br/>[% END %]
|
|
||||||
</blockquote>
|
|
||||||
|
|
||||||
</p>
|
<blockquote>
|
||||||
|
[% IF activeJobs.size == 0 %]<em>(none)</em>[% END %]
|
||||||
|
[% FOREACH j IN activeJobs %][% INCLUDE renderJobName project=project.name jobset=jobset.name job=j %]<br/>[% END %]
|
||||||
|
</blockquote>
|
||||||
|
</p>
|
||||||
|
|
||||||
</div>
|
<p>This jobset used to contain the following [% inactiveJobs.size %] jobs:
|
||||||
[% END %]
|
|
||||||
|
<blockquote>
|
||||||
|
[% IF inactiveJobs.size == 0 %]<em>(none)</em>[% END %]
|
||||||
|
[% FOREACH j IN inactiveJobs %][% INCLUDE renderJobName project=project.name jobset=jobset.name job=j %]<br/>[% END %]
|
||||||
|
</blockquote>
|
||||||
|
</p>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
[% IF edit %]
|
|
||||||
|
|
||||||
<table class="template"> <!-- dummy wrapper needed because “hidden” trs are visible anyway -->
|
|
||||||
[% INCLUDE renderInput input="" extraClass="template" id="input-template" baseName="input-template" %]
|
|
||||||
</table>
|
|
||||||
|
|
||||||
<tt class="inputalt template" id="inputalt-template">
|
|
||||||
[% INCLUDE renderInputAlt alt=alt %]
|
|
||||||
</tt>
|
|
||||||
|
|
||||||
<script type="text/javascript">
|
|
||||||
$(document).ready(function() {
|
|
||||||
var id = 0;
|
|
||||||
|
|
||||||
$(".add-input").click(function() {
|
|
||||||
var newid = "input-" + id++;
|
|
||||||
var x = $("#input-template").clone(true).attr("id", "").insertBefore($(this).parents("tr")).show();
|
|
||||||
$("#input-template-name", x).attr("name", newid + "-name");
|
|
||||||
$("#input-template-type", x).attr("name", newid + "-type");
|
|
||||||
$("#input-template", x).attr("id", newid);
|
|
||||||
return false;
|
|
||||||
});
|
|
||||||
|
|
||||||
$(".add-inputalt").click(function() {
|
|
||||||
var x = $("#inputalt-template").clone(true).insertBefore($(this)).attr("id", "").show();
|
|
||||||
$("input", x).attr("name", x.parents(".inputalts").attr("id") + "-values");
|
|
||||||
});
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<div class="form-actions">
|
|
||||||
<button type="submit" class="btn btn-primary"><i class="icon-ok icon-white"></i> [%IF create %]Create[% ELSE %]Apply changes[% END %]</button>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
</form>
|
|
||||||
|
|
||||||
[% END %]
|
|
||||||
|
|
||||||
|
|
||||||
[% END %]
|
[% END %]
|
||||||
|
|
Loading…
Reference in a new issue