fix stat
This commit is contained in:
parent
0d9caea067
commit
88ffe47f6e
|
@ -679,6 +679,8 @@ class ScrumController extends AbstractController
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getEstim($scrum) {
|
private function getEstim($scrum) {
|
||||||
|
|
||||||
|
|
||||||
// Initialisation de l'enregistrement
|
// Initialisation de l'enregistrement
|
||||||
$em = $this->getDoctrine()->getManager();
|
$em = $this->getDoctrine()->getManager();
|
||||||
$firstcolumn=$em->getRepository('App:Scrumcolumn')->findOneBy(["scrum"=>$scrum], ['rowid' => 'ASC']);
|
$firstcolumn=$em->getRepository('App:Scrumcolumn')->findOneBy(["scrum"=>$scrum], ['rowid' => 'ASC']);
|
||||||
|
@ -694,10 +696,25 @@ class ScrumController extends AbstractController
|
||||||
$tbestim=[];
|
$tbestim=[];
|
||||||
|
|
||||||
$viewclosed = $this->get('session')->get("viewclosed");
|
$viewclosed = $this->get('session')->get("viewclosed");
|
||||||
|
if($viewclosed=="false") {
|
||||||
|
$giteamilestones=$this->giteaservice->getMilestones($scrum->getGiteajson()["owner"]["login"],$scrum->getGiteajson()["name"],"?state=open");
|
||||||
|
$giteamilestones=array_column($giteamilestones,"id");
|
||||||
|
}
|
||||||
|
|
||||||
foreach($issues as $issue) {
|
foreach($issues as $issue) {
|
||||||
|
// bypass jalon closed
|
||||||
|
if($viewclosed=="false") {
|
||||||
|
|
||||||
|
/*
|
||||||
|
if(array_key_exists("milestone",$issue->getGiteajson()) && !empty($issue->getGiteajson()["milestone"]) && $issue->getGiteajson()["milestone"])
|
||||||
|
dump($issue->getGiteajson()["milestone"]["title"]);
|
||||||
|
*/
|
||||||
|
if(array_key_exists("milestone",$issue->getGiteajson()) && !empty($issue->getGiteajson()["milestone"]) && !in_array($issue->getGiteajson()["milestone"]["id"],$giteamilestones))
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
// bypass closed
|
|
||||||
if($viewclosed=="false"&&($issue->getGiteastate()=="closed"||($issue->getScrumsprint()&&$issue->getScrumsprint()->getClosed()))) continue;
|
//if($viewclosed=="false"&&($issue->getGiteastate()=="closed"||($issue->getScrumsprint()&&$issue->getScrumsprint()->getClosed()))) continue;
|
||||||
|
|
||||||
// Ids
|
// Ids
|
||||||
$idcol=($issue->getScrumcolumn()?$issue->getScrumcolumn()->getId():$firstcolumn->getId());
|
$idcol=($issue->getScrumcolumn()?$issue->getScrumcolumn()->getId():$firstcolumn->getId());
|
||||||
|
@ -777,14 +794,22 @@ class ScrumController extends AbstractController
|
||||||
$tbestim[$idjal]["sprints"][$idspr]["nbiss"]++;
|
$tbestim[$idjal]["sprints"][$idspr]["nbiss"]++;
|
||||||
$tbestim[$idjal]["sprints"][$idspr]["columns"][$idcol]["nbiss"]++;
|
$tbestim[$idjal]["sprints"][$idspr]["columns"][$idcol]["nbiss"]++;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
$this->formatDec($tbestim[$idjal]["nbjrs"]);
|
$this->formatDec($tbestim[$idjal]["nbjrs"]);
|
||||||
$this->formatDec($tbestim[$idjal]["columns"][$idcol]["nbjrs"]);
|
$this->formatDec($tbestim[$idjal]["columns"][$idcol]["nbjrs"]);
|
||||||
$this->formatDec($tbestim[$idjal]["sprints"][$idspr]["nbjrs"]);
|
$this->formatDec($tbestim[$idjal]["sprints"][$idspr]["nbjrs"]);
|
||||||
$this->formatDec($tbestim[$idjal]["sprints"][$idspr]["columns"][$idcol]["nbjrs"]);
|
$this->formatDec($tbestim[$idjal]["sprints"][$idspr]["columns"][$idcol]["nbjrs"]);
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
// dd("stop");
|
||||||
|
|
||||||
|
$keysort = array_column($tbestim, 'nmjal');
|
||||||
|
array_multisort($keysort, SORT_DESC, $tbestim);
|
||||||
|
foreach($tbestim as $keyj => $jalon) {
|
||||||
|
$keysort = array_column($jalon["sprints"],"nmspr");
|
||||||
|
array_multisort($keysort, SORT_DESC, $tbestim[$keyj]["sprints"]);
|
||||||
|
}
|
||||||
return $tbestim;
|
return $tbestim;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -80,9 +80,9 @@
|
||||||
<div id="floatdonut{{ jalon.idjal }}" class="flot-chart-content"></div>
|
<div id="floatdonut{{ jalon.idjal }}" class="flot-chart-content"></div>
|
||||||
<div style="min-width:250px; color: #ffffff; padding: 3px;">
|
<div style="min-width:250px; color: #ffffff; padding: 3px;">
|
||||||
{% for column in jalon.columns %}
|
{% for column in jalon.columns %}
|
||||||
<div style="padding: 3px; background-color:#{{column.color}}">{{column.nmcol}}<span class="float-right">{{(filterbynumber?column.nbiss:column.nbjrs)}} = {{((filterbynumber?column.nbiss:column.nbjrs) * 100 / (filterbynumber?jalon.nbiss:jalon.nbjrs))|number_format}}%</<span></div>
|
<div style="padding: 3px; background-color:#{{column.color}}">{{column.nmcol}}<span class="float-right">{{(filterbynumber=="true"?column.nbiss:column.nbjrs)}} = {{((filterbynumber=="true"?column.nbiss:column.nbjrs) * 100 / (filterbynumber=="true"?jalon.nbiss:jalon.nbjrs))|number_format}}%</<span></div>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
<div style="padding: 3px;color: #000">TOTAL<span class="float-right">{{(filterbynumber?jalon.nbiss:jalon.nbjrs)}} = 100%</<span></div>
|
<div style="padding: 3px;color: #000">TOTAL<span class="float-right">{{(filterbynumber=="true"?jalon.nbiss:jalon.nbjrs)}} = 100%</<span></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<div class="d-flex flex-wrap justify-content-center">
|
<div class="d-flex flex-wrap justify-content-center">
|
||||||
|
@ -94,9 +94,9 @@
|
||||||
<div id="floatdonut{{ jalon.idjal~"-"~sprint.idspr }}" class="flot-chart-subcontent" style="float:left"></div>
|
<div id="floatdonut{{ jalon.idjal~"-"~sprint.idspr }}" class="flot-chart-subcontent" style="float:left"></div>
|
||||||
<div class="mt-3" style="color: #ffffff;">
|
<div class="mt-3" style="color: #ffffff;">
|
||||||
{% for column in sprint.columns %}
|
{% for column in sprint.columns %}
|
||||||
<div style="padding: 3px; background-color:#{{column.color}}">{{column.nmcol}}<span class="float-right">{{(filterbynumber?column.nbiss:column.nbjrs)}} = {{((filterbynumber?column.nbiss:column.nbjrs) * 100 / (filterbynumber?sprint.nbiss:sprint.nbjrs))|number_format}}%</<span></div>
|
<div style="padding: 3px; background-color:#{{column.color}}">{{column.nmcol}}<span class="float-right">{{(filterbynumber=="true"?column.nbiss:column.nbjrs)}} = {{((filterbynumber=="true"?column.nbiss:column.nbjrs) * 100 / (filterbynumber=="true"?sprint.nbiss:sprint.nbjrs))|number_format}}%</<span></div>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
<div style="padding: 3px;color: #000">TOTAL<span class="float-right">{{(filterbynumber?sprint.nbiss:sprint.nbjrs)}} = 100%</<span></div>
|
<div style="padding: 3px;color: #000">TOTAL<span class="float-right">{{(filterbynumber=="true"?sprint.nbiss:sprint.nbjrs)}} = 100%</<span></div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -300,16 +300,18 @@
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
console.log({{filterbynumber}});
|
console.log("BY number = {{ (filterbynumber=="true" ? 'filtre par nbticket':'filtre par poids') }}");
|
||||||
{% for sprint in jalon.sprints %}
|
{% for sprint in jalon.sprints %}
|
||||||
|
console.log("Sprint = {{sprint.nmspr}}");
|
||||||
|
|
||||||
{% for column in sprint.columns %}
|
{% for column in sprint.columns %}
|
||||||
console.log({{ (filterbynumber ? column.nbiss:column.nbjrs) }});
|
console.log({{ (filterbynumber=="true" ? column.nbiss:column.nbjrs) }});
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
var data = [
|
var data = [
|
||||||
{% for column in sprint.columns %}
|
{% for column in sprint.columns %}
|
||||||
{
|
{
|
||||||
label: "{{ column.nmcol}}",
|
label: "{{ column.nmcol}}",
|
||||||
data: {{ (filterbynumber ? column.nbiss:column.nbjrs) }},
|
data: {{ (filterbynumber=="true" ? column.nbiss:column.nbjrs) }},
|
||||||
color: "#{{ column.color }}",
|
color: "#{{ column.color }}",
|
||||||
},
|
},
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
|
Loading…
Reference in New Issue