2022-01-22 11:18:42 +01:00
|
|
|
{% extends "base.html.twig" %}
|
|
|
|
|
|
|
|
{% block localstyle %}
|
2022-01-28 16:54:46 +01:00
|
|
|
#main {
|
|
|
|
padding-left:0px;
|
|
|
|
margin-bottom:0px;
|
|
|
|
}
|
|
|
|
#mycontent { display:none }
|
|
|
|
|
2022-01-22 11:18:42 +01:00
|
|
|
.tag {
|
|
|
|
border-radius: 5px;
|
|
|
|
padding: 8px 8px;
|
|
|
|
margin-bottom: 5px;
|
|
|
|
display: inline-block;
|
|
|
|
min-width: 35px;
|
|
|
|
text-align: center;
|
|
|
|
color: #ffffff !important;
|
|
|
|
zoom: 80%;
|
|
|
|
}
|
|
|
|
|
|
|
|
.tag i {
|
|
|
|
margin-right:5px;
|
|
|
|
}
|
|
|
|
|
|
|
|
.assignee {
|
|
|
|
width:30px;
|
|
|
|
margin: 5px 5px 0px 0px;
|
|
|
|
}
|
|
|
|
|
|
|
|
{% endblock %}
|
|
|
|
|
|
|
|
{% block body %}
|
2022-01-28 16:54:46 +01:00
|
|
|
<div class="d-flex">
|
|
|
|
<div id="filters" class="d-flex flex-column pl-2 pr-2 " style="width:350px; background-color:var(--colorbgbodydark);min-height:1000px;">
|
|
|
|
<div style="width:100%" class="mt-3">
|
|
|
|
<label class="control-label" style="color:var(--colorftbodydark)">Filtre TICKET</label>
|
|
|
|
<input type="number" id="filterticket" class=" form-control">
|
|
|
|
</div>
|
2022-01-22 11:18:42 +01:00
|
|
|
|
2022-01-28 16:54:46 +01:00
|
|
|
{% if id == 0 %}
|
|
|
|
<div style="width:100%" class="mt-3">
|
|
|
|
<label class="control-label" style="color:var(--colorftbodydark)">Filtre CATEGORIES</label>
|
|
|
|
<select id="filtercategorys" multiple="multiple" class="form-control">
|
|
|
|
{% for giteacategory in giteacategorys %}
|
|
|
|
<option value="{{giteacategory}}">{{giteacategory}}</option>
|
|
|
|
{% endfor %}
|
|
|
|
</select>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div style="width:100%" class="mt-3">
|
|
|
|
<label class="control-label" style="color:var(--colorftbodydark)">Filtre PROJETS</label>
|
|
|
|
<select id="filterrepos" multiple="multiple" class="form-control">
|
|
|
|
{% for gitearepo in gitearepos %}
|
|
|
|
<option value="{{gitearepo.id}}">{{gitearepo.full_name}}</option>
|
|
|
|
{% endfor %}
|
|
|
|
</select>
|
|
|
|
</div>
|
|
|
|
{% endif %}
|
2022-01-22 11:18:42 +01:00
|
|
|
|
2022-01-28 16:54:46 +01:00
|
|
|
<div style="width:100%" class="mt-3">
|
|
|
|
<label class="control-label" style="color:var(--colorftbodydark)">Filtre JALONS</label>
|
|
|
|
<select id="filtermilestones" multiple="multiple" class="form-control">
|
|
|
|
{% for giteamilestone in giteamilestones %}
|
|
|
|
<option value="{{giteamilestone.id}}">{{giteamilestone.title}}</option>
|
|
|
|
{% endfor %}
|
|
|
|
</select>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div style="width:100%" class="mt-3">
|
|
|
|
<label class="control-label" style="color:var(--colorftbodydark)">Filtre STATUTS</label>
|
|
|
|
<select id="filtercolumns" multiple="multiple" class="form-control">
|
|
|
|
{% for giteacolumn in giteacolumns %}
|
|
|
|
<option value="{{giteacolumn}}">{{giteacolumn}}</option>
|
|
|
|
{% endfor %}
|
|
|
|
</select>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div style="width:100%" class="mt-3">
|
|
|
|
<label class="control-label" style="color:var(--colorftbodydark)">Filtre EQUIPES</label>
|
|
|
|
<select id="filterteams" multiple="multiple" class="form-control">
|
|
|
|
{% for giteateam in giteateams %}
|
|
|
|
<option value="{{giteateam}}">{{giteateam}}</option>
|
|
|
|
{% endfor %}
|
|
|
|
</select>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div style="width:100%" class="mt-3">
|
|
|
|
<label class="control-label" style="color:var(--colorftbodydark)">Filtre ETIQUETTES</label>
|
|
|
|
<select id="filterlabels" multiple="multiple" class="form-control">
|
|
|
|
{% for gitealabel in gitealabels %}
|
|
|
|
{% if gitealabel not in giteacolumns and gitealabel not in giteateams %}
|
|
|
|
<option value="{{gitealabel}}">{{gitealabel}}</option>
|
|
|
|
{% endif %}
|
|
|
|
{% endfor %}
|
|
|
|
</select>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div style="width:100%" class="mt-3">
|
|
|
|
<label class="control-label" style="color:var(--colorftbodydark)">Filtre AFFECTATIONS</label>
|
|
|
|
<select id="filterassignees" multiple="multiple" class="form-control">
|
|
|
|
{% for giteaassignee in giteaassignees %}
|
|
|
|
<option value="{{giteaassignee.username}}">{{giteaassignee.username}}</option>
|
|
|
|
{% endfor %}
|
|
|
|
</select>
|
|
|
|
</div>
|
2022-01-22 11:18:42 +01:00
|
|
|
</div>
|
|
|
|
|
2022-01-28 16:54:46 +01:00
|
|
|
<div class="pl-3" style="width:100%;">
|
|
|
|
<div class="mt-4 mb-3" style="zoom:80%">
|
|
|
|
<button class="btn btn-success" onClick="showFilters()"><i class="fas fa-filter"></i></button>
|
|
|
|
<span id="textfilters"></span>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<table class="mt-4 table table-striped table-bordered table-hover" id="dataTables" style="width:100%; zoom:80%;">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th class="no-sort"></th>
|
|
|
|
{%if id==0 %}<th style="width:100px">Projet</th>{%endif%}
|
|
|
|
<th style="width:200px">Jalon</th>
|
|
|
|
<th style="width:135px">Statut</th>
|
|
|
|
<th style="width:135px"class="no-string">N°</th>
|
|
|
|
<th style="width:1000px">Titre</th>
|
|
|
|
<th style="width:200px">Equipe</th>
|
|
|
|
<th style="width:135px">Affecté à</th>
|
|
|
|
<th style="width:300px">Etiquettes</th>
|
|
|
|
</tr>
|
|
|
|
</thead>
|
|
|
|
|
|
|
|
<tbody>
|
|
|
|
{% for gitearepo in gitearepos %}
|
|
|
|
{% for giteaissue in gitearepo.issues %}
|
|
|
|
{% if giteaissue.pull_request is null %}
|
|
|
|
{% set dataticket = giteaissue.number %}
|
|
|
|
{% set datarepo = gitearepo.id %}
|
|
|
|
|
|
|
|
{% if giteaissue.milestone %}
|
|
|
|
{% set datamilestone = giteaissue.milestone.id %}
|
|
|
|
{%else%}
|
|
|
|
{% set datamilestone = gitearepo.full_name %}
|
|
|
|
{%endif%}
|
|
|
|
|
|
|
|
{% set statut = "Backlog" %}
|
|
|
|
{% set teams = "" %}
|
|
|
|
{% set datateams = "" %}
|
|
|
|
{% set labels = "" %}
|
|
|
|
{% set datalabels = "" %}
|
|
|
|
{% for label in giteaissue.labels %}
|
|
|
|
{% if label.id in gitearepo.columns %}
|
|
|
|
{% set statut= label.name %}
|
|
|
|
{% elseif label.name in giteateams %}
|
|
|
|
{% set teams=teams~'<span class="btn-link tag mr-1" style="background-color:#'~label.color~'"><i class="fas fa-tag"></i>'~label.name~'</span>' %}
|
|
|
|
{% set datateams=datateams~','~label.name %}
|
|
|
|
{% else %}
|
|
|
|
{% set labels=labels~'<span class="btn-link tag mr-1" style="background-color:#'~label.color~'"><i class="fas fa-tag"></i>'~label.name~'</span>' %}
|
|
|
|
{% set datalabels=datalabels~','~label.name %}
|
|
|
|
{% endif %}
|
|
|
|
{% endfor %}
|
|
|
|
|
|
|
|
{% set dataassignees="" %}
|
2022-01-22 11:18:42 +01:00
|
|
|
{% for assignee in giteaissue.assignees %}
|
2022-01-28 16:54:46 +01:00
|
|
|
{% set dataassignees=dataassignees~','~assignee.username %}
|
|
|
|
{% endfor %}
|
|
|
|
|
|
|
|
<tr data-category="{{gitearepo.category}}" data-repo="{{datarepo}}" data-milestone="{{datamilestone}}" data-ticket="{{dataticket}}" data-column="{{statut}}" data-teams="{{datateams}}" data-labels="{{datalabels}}" data-assignees="{{dataassignees}}">
|
|
|
|
<td>
|
|
|
|
<a target="_blank" class="btn btn-link fa fa-file" href="{{giteaissue.html_url}}"></a>
|
|
|
|
</td>
|
|
|
|
{%if id==0 %}<td>{{ gitearepo.full_name }}</td>{%endif%}
|
|
|
|
<td>{% if giteaissue.milestone %}{{ giteaissue.milestone.title }} {%endif%}</td>
|
|
|
|
<td>{{ statut }}</td>
|
|
|
|
<td>{{ giteaissue.number }}</td>
|
|
|
|
<td>{{ giteaissue.title }}</td>
|
|
|
|
<td>{{ teams|raw }}</td>
|
|
|
|
<td>
|
|
|
|
{% for assignee in giteaissue.assignees %}
|
|
|
|
<img src="{{assignee.avatar_url}}" class="assignee" title="{{assignee.username}}">
|
|
|
|
{% endfor %}
|
|
|
|
</td>
|
|
|
|
<td>{{ labels|raw }}</td>
|
|
|
|
</tr>
|
|
|
|
{% endif %}
|
|
|
|
{% endfor %}
|
|
|
|
{% endfor %}
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
</div>
|
2022-01-22 11:18:42 +01:00
|
|
|
</div>
|
|
|
|
{% endblock %}
|
|
|
|
|
|
|
|
{% block localjavascript %}
|
|
|
|
var table;
|
|
|
|
|
2022-01-28 16:54:46 +01:00
|
|
|
function showFilters() {
|
|
|
|
if($("#filters").hasClass("d-flex")) {
|
|
|
|
toshow=0;
|
|
|
|
$("#filters").addClass("d-none");
|
|
|
|
$("#filters").removeClass("d-flex");
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
toshow=1;
|
|
|
|
$("#filters").addClass("d-flex");
|
|
|
|
$("#filters").removeClass("d-none");
|
|
|
|
}
|
|
|
|
|
|
|
|
$.ajax({
|
|
|
|
method: "POST",
|
|
|
|
url: "{{ path('app_user_preference') }}",
|
|
|
|
data: {
|
|
|
|
key:'showfilters',
|
|
|
|
id:{{id}},
|
|
|
|
value: toshow
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-01-22 11:18:42 +01:00
|
|
|
function showhide() {
|
2022-01-28 16:54:46 +01:00
|
|
|
textfilters="";
|
2022-01-22 11:18:42 +01:00
|
|
|
ticketfilter=$("#filterticket").val();
|
|
|
|
categoryfilters=$("#filtercategorys").val();
|
|
|
|
repofilters=$("#filterrepos").val();
|
|
|
|
milestonefilters=$("#filtermilestones").val();
|
|
|
|
columnfilters=$("#filtercolumns").val();
|
2022-01-28 16:54:46 +01:00
|
|
|
teamfilters=$("#filterteams").val();
|
2022-01-22 11:18:42 +01:00
|
|
|
labelfilters=$("#filterlabels").val();
|
|
|
|
assigneefilters=$("#filterassignees").val();
|
2022-01-28 16:54:46 +01:00
|
|
|
|
2022-01-22 11:18:42 +01:00
|
|
|
$.fn.dataTable.ext.search.push(function(settings, data, dataIndex, rowObj, counter) {
|
|
|
|
el=table.row(dataIndex).nodes().to$();
|
|
|
|
|
|
|
|
{% if id == 0 %}
|
|
|
|
category = $(el).data('category');
|
|
|
|
repo = $(el).data('repo');
|
|
|
|
{% endif %}
|
|
|
|
ticket= $(el).data('ticket');
|
|
|
|
milestone = $(el).data('milestone');
|
|
|
|
column = $(el).data('column');
|
2022-01-28 16:54:46 +01:00
|
|
|
teams = $(el).data('teams').split(',');
|
2022-01-22 11:18:42 +01:00
|
|
|
labels = $(el).data('labels').split(',');
|
|
|
|
assignees = $(el).data('assignees').split(',');
|
2022-01-28 16:54:46 +01:00
|
|
|
|
2022-01-22 11:18:42 +01:00
|
|
|
toreturn=true;
|
|
|
|
|
|
|
|
{% if id == 0 %}
|
|
|
|
if(categoryfilters.length!==0 && jQuery.inArray(category.toString(), categoryfilters )<0) {
|
|
|
|
toreturn=false;
|
|
|
|
}
|
2022-01-28 16:54:46 +01:00
|
|
|
if(categoryfilters.length!==0) {
|
|
|
|
textfilters=textfilters+" CATEGORIES =";
|
|
|
|
$.each(categoryfilters, function( index, value ) {
|
|
|
|
textfilters=textfilters+" "+value;
|
|
|
|
});
|
|
|
|
}
|
2022-01-22 11:18:42 +01:00
|
|
|
|
|
|
|
if(repofilters.length!==0 && jQuery.inArray(repo.toString(), repofilters )<0) {
|
|
|
|
toreturn=false;
|
|
|
|
}
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
if(ticketfilter.length!==0 && ticket.toString()!=ticketfilter) {
|
|
|
|
toreturn=false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(milestonefilters.length!==0 && jQuery.inArray(milestone.toString(), milestonefilters )<0) {
|
|
|
|
toreturn=false;
|
|
|
|
}
|
2022-01-28 16:54:46 +01:00
|
|
|
|
2022-01-22 11:18:42 +01:00
|
|
|
if(columnfilters.length!==0 && jQuery.inArray(column.toString(), columnfilters )<0) {
|
|
|
|
toreturn=false;
|
|
|
|
}
|
|
|
|
|
2022-01-28 16:54:46 +01:00
|
|
|
if(toreturn&&(teamfilters.length!==0||labelfilters.length!==0||assigneefilters.length!==0)) {
|
2022-01-22 11:18:42 +01:00
|
|
|
if(labelfilters.length!==0) {
|
|
|
|
toreturn=false;
|
|
|
|
$.each(labelfilters, function( index, value ) {
|
|
|
|
if(jQuery.inArray(value, labels )>0) {
|
|
|
|
toreturn=true;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-01-28 16:54:46 +01:00
|
|
|
if(teamfilters.length!==0&&toreturn) {
|
|
|
|
toreturn=false;
|
|
|
|
$.each(teamfilters, function( index, value ) {
|
|
|
|
if(jQuery.inArray(value, teams )>0) {
|
|
|
|
toreturn=true;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-01-22 11:18:42 +01:00
|
|
|
if(assigneefilters.length!==0&&toreturn) {
|
|
|
|
toreturn=false;
|
|
|
|
$.each(assigneefilters, function( index, value ) {
|
|
|
|
if(jQuery.inArray(value, assignees )>0) {
|
|
|
|
toreturn=true;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return toreturn;
|
|
|
|
});
|
2022-01-28 16:54:46 +01:00
|
|
|
|
|
|
|
if(ticketfilter.length!==0) {
|
|
|
|
textfilters=textfilters+" <b>TICKET</b> ="+ticketfilter;
|
|
|
|
}
|
|
|
|
|
|
|
|
{% if id == 0 %}
|
|
|
|
if(categoryfilters.length!==0) {
|
|
|
|
data = $("#filtercategorys").select2('data');
|
|
|
|
textfilters=textfilters+" <b>CATEGORIES</b> =";
|
|
|
|
$.each(categoryfilters, function( index, value ) {
|
|
|
|
if(index>0)textfilters=textfilters+" &";
|
|
|
|
textfilters=textfilters+" "+data[index].text;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if(repofilters.length!==0) {
|
|
|
|
data = $("#filterrepos").select2('data');
|
|
|
|
textfilters=textfilters+" <b>PROJETS</b> =";
|
|
|
|
$.each(repofilters, function( index, value ) {
|
|
|
|
if(index>0)textfilters=textfilters+" &";
|
|
|
|
textfilters=textfilters+" "+data[index].text;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
if(milestonefilters.length!==0) {
|
|
|
|
data = $("#filtermilestones").select2('data');
|
|
|
|
textfilters=textfilters+" <b>JALONS</b> =";
|
|
|
|
$.each(milestonefilters, function( index, value ) {
|
|
|
|
if(index>0)textfilters=textfilters+" &";
|
|
|
|
textfilters=textfilters+" "+data[index].text;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if(columnfilters.length!==0) {
|
|
|
|
data = $("#filtercolumns").select2('data');
|
|
|
|
textfilters=textfilters+" <b>STATUS</b> =";
|
|
|
|
$.each(columnfilters, function( index, value ) {
|
|
|
|
if(index>0)textfilters=textfilters+" &";
|
|
|
|
textfilters=textfilters+" "+data[index].text;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if(teamfilters.length!==0) {
|
|
|
|
data = $("#filterteams").select2('data');
|
|
|
|
textfilters=textfilters+" <b>EQUIPES</b> =";
|
|
|
|
$.each(teamfilters, function( index, value ) {
|
|
|
|
if(index>0)textfilters=textfilters+" &";
|
|
|
|
textfilters=textfilters+" "+data[index].text;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if(labelfilters.length!==0) {
|
|
|
|
data = $("#filterlabels").select2('data');
|
|
|
|
textfilters=textfilters+" <b>ETIQUETTES</b> =";
|
|
|
|
$.each(labelfilters, function( index, value ) {
|
|
|
|
if(index>0)textfilters=textfilters+" &";
|
|
|
|
textfilters=textfilters+" "+data[index].text;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if(assigneefilters.length!==0) {
|
|
|
|
data = $("#filterassignees").select2('data');
|
|
|
|
textfilters=textfilters+" <b>AFFECTATIONS</b> =";
|
|
|
|
$.each(assigneefilters, function( index, value ) {
|
|
|
|
if(index>0)textfilters=textfilters+" &";
|
|
|
|
textfilters=textfilters+" "+data[index].text;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
$("#textfilters").html(textfilters);
|
2022-01-22 11:18:42 +01:00
|
|
|
|
|
|
|
table.draw();
|
|
|
|
}
|
|
|
|
|
|
|
|
{% if id == 0 %}
|
|
|
|
function filtercategorys() {
|
|
|
|
$.ajax({
|
|
|
|
method: "POST",
|
|
|
|
url: "{{ path('app_user_preference') }}",
|
|
|
|
data: {
|
|
|
|
key:'filtercategorys',
|
|
|
|
id:{{id}},
|
|
|
|
value: $("#filtercategorys").val()
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
showhide();
|
|
|
|
}
|
|
|
|
|
|
|
|
function filterrepos() {
|
|
|
|
$.ajax({
|
|
|
|
method: "POST",
|
|
|
|
url: "{{ path('app_user_preference') }}",
|
|
|
|
data: {
|
|
|
|
key:'filterrepos',
|
|
|
|
id:{{id}},
|
|
|
|
value: $("#filterrepos").val()
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
showhide();
|
|
|
|
}
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
function filtermilestones() {
|
|
|
|
$.ajax({
|
|
|
|
method: "POST",
|
|
|
|
url: "{{ path('app_user_preference') }}",
|
|
|
|
data: {
|
|
|
|
key:'filtermilestones',
|
|
|
|
id:{{id}},
|
|
|
|
value: $("#filtermilestones").val()
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
showhide();
|
|
|
|
}
|
|
|
|
|
|
|
|
function filtercolumns() {
|
|
|
|
$.ajax({
|
|
|
|
method: "POST",
|
|
|
|
url: "{{ path('app_user_preference') }}",
|
|
|
|
data: {
|
|
|
|
key:'filtercolumns',
|
|
|
|
id:{{id}},
|
|
|
|
value: $("#filtercolumns").val()
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
showhide();
|
|
|
|
}
|
|
|
|
|
2022-01-28 16:54:46 +01:00
|
|
|
function filterteams() {
|
|
|
|
$.ajax({
|
|
|
|
method: "POST",
|
|
|
|
url: "{{ path('app_user_preference') }}",
|
|
|
|
data: {
|
|
|
|
key:'filterteams',
|
|
|
|
id:{{id}},
|
|
|
|
value: $("#filterteams").val()
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
showhide();
|
|
|
|
}
|
|
|
|
|
2022-01-22 11:18:42 +01:00
|
|
|
function filterlabels() {
|
|
|
|
$.ajax({
|
|
|
|
method: "POST",
|
|
|
|
url: "{{ path('app_user_preference') }}",
|
|
|
|
data: {
|
|
|
|
key:'filterlabels',
|
|
|
|
id:{{id}},
|
|
|
|
value: $("#filterlabels").val()
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
showhide();
|
|
|
|
}
|
|
|
|
|
|
|
|
function filterassignees() {
|
|
|
|
$.ajax({
|
|
|
|
method: "POST",
|
|
|
|
url: "{{ path('app_user_preference') }}",
|
|
|
|
data: {
|
|
|
|
key:'filterassignees',
|
|
|
|
id:{{id}},
|
|
|
|
value: $("#filterassignees").val()
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
showhide();
|
|
|
|
}
|
|
|
|
|
|
|
|
$(document).ready(function() {
|
|
|
|
{% if id== 0 %}
|
|
|
|
$('#filtercategorys').select2();
|
|
|
|
{% if filtercategorys %}
|
|
|
|
{% for category in filtercategorys %}
|
|
|
|
$("#filtercategorys").val($("#filtercategorys").val().concat("{{category}}"));
|
|
|
|
{%endfor%}
|
|
|
|
$('#filtercategorys').trigger('change');
|
|
|
|
{% endif %}
|
|
|
|
$('#filtercategorys').on("select2:select", function(e) {
|
|
|
|
filtercategorys();
|
|
|
|
});
|
|
|
|
$('#filtercategorys').on("select2:unselect", function(e) {
|
|
|
|
filtercategorys();
|
|
|
|
});
|
|
|
|
|
|
|
|
$('#filterrepos').select2();
|
|
|
|
{% if filterrepos %}
|
|
|
|
{% for repo in filterrepos %}
|
|
|
|
$("#filterrepos").val($("#filterrepos").val().concat("{{repo}}"));
|
|
|
|
{%endfor%}
|
|
|
|
$('#filterrepos').trigger('change');
|
|
|
|
{% endif %}
|
|
|
|
$('#filterrepos').on("select2:select", function(e) {
|
|
|
|
filterrepos();
|
|
|
|
});
|
|
|
|
$('#filterrepos').on("select2:unselect", function(e) {
|
|
|
|
filterrepos();
|
|
|
|
});
|
|
|
|
{% endif %}
|
|
|
|
|
|
|
|
$("#filterticket").on("keyup", function() {
|
|
|
|
showhide();
|
|
|
|
});
|
|
|
|
|
|
|
|
$('#filtermilestones').select2();
|
|
|
|
{% if filtermilestones %}
|
|
|
|
{% for milestone in filtermilestones %}
|
|
|
|
$("#filtermilestones").val($("#filtermilestones").val().concat("{{milestone}}"));
|
|
|
|
{%endfor%}
|
|
|
|
$('#filtermilestones').trigger('change');
|
|
|
|
{% endif %}
|
|
|
|
$('#filtermilestones').on("select2:select", function(e) {
|
|
|
|
filtermilestones();
|
|
|
|
});
|
|
|
|
$('#filtermilestones').on("select2:unselect", function(e) {
|
|
|
|
filtermilestones();
|
|
|
|
});
|
|
|
|
|
|
|
|
$('#filtercolumns').select2();
|
|
|
|
{% if filtercolumns %}
|
|
|
|
{% for column in filtercolumns %}
|
|
|
|
$("#filtercolumns").val($("#filtercolumns").val().concat("{{column}}"));
|
|
|
|
{%endfor%}
|
|
|
|
$('#filtercolumns').trigger('change');
|
|
|
|
{% endif %}
|
|
|
|
$('#filtercolumns').on("select2:select", function(e) {
|
|
|
|
filtercolumns();
|
|
|
|
});
|
|
|
|
$('#filtercolumns').on("select2:unselect", function(e) {
|
|
|
|
filtercolumns();
|
|
|
|
});
|
|
|
|
|
2022-01-28 16:54:46 +01:00
|
|
|
$('#filterteams').select2();
|
|
|
|
{% if filterteams %}
|
|
|
|
{% for team in filterteams %}
|
|
|
|
$("#filterteams").val($("#filterteams").val().concat("{{team}}"));
|
|
|
|
{%endfor%}
|
|
|
|
$('#filterteams').trigger('change');
|
|
|
|
{% endif %}
|
|
|
|
$('#filterteams').on("select2:select", function(e) {
|
|
|
|
filterteams();
|
|
|
|
});
|
|
|
|
$('#filterteams').on("select2:unselect", function(e) {
|
|
|
|
filterteams();
|
|
|
|
});
|
|
|
|
|
2022-01-22 11:18:42 +01:00
|
|
|
$('#filterlabels').select2();
|
|
|
|
{% if filterlabels %}
|
|
|
|
{% for label in filterlabels %}
|
|
|
|
$("#filterlabels").val($("#filterlabels").val().concat("{{label}}"));
|
|
|
|
{%endfor%}
|
|
|
|
$('#filterlabels').trigger('change');
|
|
|
|
{% endif %}
|
|
|
|
$('#filterlabels').on("select2:select", function(e) {
|
|
|
|
filterlabels();
|
|
|
|
});
|
|
|
|
$('#filterlabels').on("select2:unselect", function(e) {
|
|
|
|
filterlabels();
|
|
|
|
});
|
|
|
|
|
|
|
|
$('#filterassignees').select2();
|
|
|
|
{% if filterassignees %}
|
|
|
|
{% for assignee in filterassignees %}
|
|
|
|
$("#filterassignees").val($("#filterassignees").val().concat("{{assignee}}"));
|
|
|
|
{%endfor%}
|
|
|
|
$('#filterassignees').trigger('change');
|
|
|
|
{% endif %}
|
|
|
|
$('#filterassignees').on("select2:select", function(e) {
|
|
|
|
filterassignees();
|
|
|
|
});
|
|
|
|
$('#filterassignees').on("select2:unselect", function(e) {
|
|
|
|
filterassignees();
|
|
|
|
});
|
|
|
|
|
|
|
|
table = $('#dataTables').DataTable({
|
|
|
|
columnDefs: [ { "targets": "no-sort", "orderable": false }, { "targets": "no-string", "type" : "num" } ],
|
|
|
|
responsive: true,
|
|
|
|
iDisplayLength: 100,
|
|
|
|
order: [[ 1, "asc" ]],
|
|
|
|
});
|
|
|
|
|
2022-01-28 16:54:46 +01:00
|
|
|
{% if not showfilters %}
|
|
|
|
$("#filters").addClass("d-none");
|
|
|
|
$("#filters").removeClass("d-flex");
|
|
|
|
{% endif %}
|
|
|
|
|
2022-01-22 11:18:42 +01:00
|
|
|
showhide();
|
2022-01-28 16:54:46 +01:00
|
|
|
$("#mycontent").show();
|
2022-01-22 11:18:42 +01:00
|
|
|
});
|
|
|
|
{% endblock %}
|