%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /var/www/projetos/suporte.iigd.com.br/plugins/dashboard/front/graphs/inc/
Upload File :
Create Path :
Current File : /var/www/projetos/suporte.iigd.com.br/plugins/dashboard/front/graphs/inc/grafbar_grupo_mes.inc.php

<?php

if($data_ini == $data_fin) {
	$datas = "LIKE '".$data_ini."%'";	
}	

else {
	$datas = "BETWEEN '".$data_ini." 00:00:00' AND '".$data_fin." 23:59:59'";	
}


# entity
$sql_e = "SELECT value FROM glpi_plugin_dashboard_config WHERE name = 'entity' AND users_id = ".$_SESSION['glpiID']."";
$result_e = $DB->query($sql_e);
$sel_ent = $DB->result($result_e,0,'value');

if($sel_ent == '' || $sel_ent == -1) {
	
	//get user entities
	$entities = $_SESSION['glpiactiveentities'];
	$ent = implode(",",$entities);
	$entidade = "AND glpi_tickets.entities_id IN (".$ent.")";
}

else {
	$entidade = "AND glpi_tickets.entities_id IN (".$sel_ent.")";
}


$sql_gid = "SELECT DISTINCT glpi_groups_tickets.`groups_id` AS gid, count(glpi_groups_tickets.id) AS conta
FROM `glpi_groups_tickets` , glpi_tickets, glpi_groups
WHERE glpi_groups_tickets.`groups_id` = glpi_groups.id
AND glpi_groups_tickets.`tickets_id` = glpi_tickets.id
AND glpi_tickets.is_deleted = 0
AND (glpi_tickets.date ".$datas." OR glpi_tickets.closedate ".$datas." )
".$entidade."
GROUP BY gid
ORDER BY conta DESC ";

$query_gid = $DB->query($sql_gid);

$contador = $DB->numrows($query_gid);

//chart height
if($contador > 5) {	
	$height = '900';	
}
else {
	$height = '500';
}


echo "
<script type='text/javascript'>

$(function () {
	// Create the chart
	$('#graf1').highcharts({
    	chart: {
        	type: 'bar',
        	height: ".$height."
    	},
    	title: {
        	text: ''
    	},
    	subtitle: {
        	text: 'Click the bars to view details. '
    	},
    	xAxis: {
        	type: 'category'
    	},
    	yAxis: {
        	title: {
            	text: '". __('Tickets','dashboard')."'
        	}

    	},
    	legend: {
        	enabled: false
    	},
    	plotOptions: {
        	series: {
            	borderWidth: 0,
            	dataLabels: {
                	enabled: true,
                	format: '{point.y}'
            	}
        	}
    	},

    	tooltip: {
        	headerFormat: '<span style=\"font-size:11px\">{series.name}</span><br>',
        	pointFormat: '<span style=\"color:{point.color}\">{point.name}</span>: <b>{point.y:.2f}%</b> of total<br/>'
    	},

	series: [{
        	name: 'Groups',
        	colorByPoint: true,
        	data: [ ";
    
    			//$DB->dataSeek($query_gid, 0) ;  
				while ($row = $DB->fetchAssoc($query_gid)) {				
						
					$query = "SELECT count( glpi_groups_tickets.id ) AS conta, glpi_groups.name AS name
					FROM `glpi_groups_tickets` , glpi_tickets, glpi_groups
					WHERE glpi_groups_tickets.`groups_id` = glpi_groups.id
					AND glpi_groups_tickets.`tickets_id` = glpi_tickets.id
					AND glpi_tickets.is_deleted = 0
					AND glpi_groups.id = ".$row['gid']."
					AND glpi_tickets.date ".$datas."
					".$entidade." ";
					
					$result = $DB->query($query);
					$grupos = $DB->fetchAssoc($result);
					
					echo "
					{
						name: '".$grupos['name']."',
						y: ".$grupos['conta'].",
						drilldown: '".$grupos['name']."'
					},
					";
				}     		
        		
echo "
		]
    	}],
    	drilldown: {
        	series: [ ";


				$DB->dataSeek($query_gid, 0) ;  
				while ($row = $DB->fetchAssoc($query_gid)) {					
					
					$query = "SELECT 
					SUM(case when glpi_groups_tickets.type = 1 then 1 else 0 end) AS req,
					SUM(case when glpi_groups_tickets.type = 2 then 1 else 0 end) AS tec,
					SUM(case when glpi_groups_tickets.type = 3 then 1 else 0 end) AS obs,
					count(glpi_groups_tickets.id) AS conta,
					glpi_groups.name AS name
					FROM `glpi_groups_tickets`, glpi_tickets, glpi_groups
					WHERE glpi_groups_tickets.`groups_id` = glpi_groups.id
					AND glpi_groups_tickets.`tickets_id` = glpi_tickets.id
					AND glpi_tickets.is_deleted = 0
					AND glpi_groups.id = ".$row['gid']."
					AND glpi_tickets.date ".$datas."
					".$entidade."	 ";
					
					$result = $DB->query($query);
					$grupos = $DB->fetchAssoc($result);
					
					echo "
					{
						name: '".$grupos['name']."',
						id: '".$grupos['name']."',
						data: [
							[
								'". __('Requester')."',
								".$grupos['req']."
							
							],
												[
								'". __('Technician')."',
								".$grupos['tec']."
							
							],
												[
								'". __('Watcher')."',
								".$grupos['obs']."
							
							]							
							
						]
						},
					";
								
				}  
        
echo "        	
]
    	}
	});
});

</script> ";

		//}
		?>

Zerion Mini Shell 1.0