2015-02-14 18:39:45 +01:00
< ? php
/* Copyright ( C ) 2003 Rodolphe Quiedeville < rodolphe @ quiedeville . org >
* Copyright ( c ) 2005 - 2008 Laurent Destailleur < eldy @ users . sourceforge . net >
2018-10-27 14:43:12 +02:00
* Copyright ( C ) 2005 - 2009 Regis Houssin < regis . houssin @ inodbox . com >
2015-02-14 18:39:45 +01:00
*
* This program is free software ; you can redistribute it and / or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation ; either version 3 of the License , or
* ( at your option ) any later version .
*
* This program is distributed in the hope that it will be useful ,
* but WITHOUT ANY WARRANTY ; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the
* GNU General Public License for more details .
*
* You should have received a copy of the GNU General Public License
2019-09-23 21:55:30 +02:00
* along with this program . If not , see < https :// www . gnu . org / licenses />.
2015-02-14 18:39:45 +01:00
*/
/**
* \file htdocs / expensereport / class / expensereportstats . class . php
2015-03-17 11:23:45 +01:00
* \ingroup expensereport
2015-02-14 18:39:45 +01:00
* \brief Fichier de la classe de gestion des stats des expensereport et notes de frais
*/
2020-01-30 01:48:28 +01:00
require_once DOL_DOCUMENT_ROOT . '/core/class/stats.class.php' ;
require_once DOL_DOCUMENT_ROOT . '/expensereport/class/expensereport.class.php' ;
2015-02-14 18:39:45 +01:00
/**
* Classe permettant la gestion des stats des expensereports et notes de frais
*/
class ExpenseReportStats extends Stats
{
2020-10-31 14:32:18 +01:00
/**
2018-08-22 18:48:53 +02:00
* @ var string Name of table without prefix where object is stored
*/
public $table_element ;
2015-02-14 18:39:45 +01:00
2020-10-31 14:32:18 +01:00
public $socid ;
public $userid ;
2015-02-14 18:39:45 +01:00
2020-10-31 14:32:18 +01:00
public $from ;
public $field ;
public $where ;
2015-02-14 18:39:45 +01:00
2020-10-31 14:32:18 +01:00
private $datetouse = 'date_valid' ;
2020-01-25 12:10:00 +01:00
2015-02-14 18:39:45 +01:00
/**
* Constructor
*
* @ param DoliDB $db Database handler
* @ param int $socid Id third party
2020-10-31 14:32:18 +01:00
* @ param int $userid Id user for filter
2015-02-14 18:39:45 +01:00
* @ return void
*/
2019-02-25 20:35:59 +01:00
public function __construct ( $db , $socid = 0 , $userid = 0 )
2015-02-14 18:39:45 +01:00
{
2015-02-21 16:15:54 +01:00
global $conf , $user ;
2015-02-14 18:39:45 +01:00
$this -> db = $db ;
2020-10-31 14:32:18 +01:00
$this -> socid = $socid ;
$this -> userid = $userid ;
2015-02-14 18:39:45 +01:00
2020-01-30 01:48:28 +01:00
$object = new ExpenseReport ( $this -> db );
2016-12-03 19:14:16 +01:00
$this -> from = MAIN_DB_PREFIX . $object -> table_element . " as e " ;
2020-01-30 01:48:28 +01:00
$this -> field = 'total_ht' ;
2015-02-14 18:39:45 +01:00
2017-01-22 16:03:08 +01:00
//$this->where = " e.fk_statut > 0";
2017-12-08 16:15:41 +01:00
//$this->where.= " AND e.date_valid > '2000-01-01'"; // To filter only correct "valid date". If date is invalid, the group by on it will fails. Launch a repair.php if you have.
2020-01-30 01:48:28 +01:00
$this -> where .= ' e.entity IN (' . getEntity ( 'expensereport' ) . ')' ;
2017-12-08 16:15:41 +01:00
2015-02-14 18:39:45 +01:00
//$this->where.= " AND entity = ".$conf->entity;
2021-02-25 22:45:02 +01:00
if ( $this -> socid ) {
2021-08-23 17:41:11 +02:00
$this -> where .= " AND e.fk_soc = " . (( int ) $this -> socid );
2015-02-14 18:39:45 +01:00
}
2015-02-21 16:15:54 +01:00
// Only me and subordinates
2021-02-25 22:45:02 +01:00
if ( empty ( $user -> rights -> expensereport -> readall ) && empty ( $user -> rights -> expensereport -> lire_tous )) {
2015-02-21 16:15:54 +01:00
$childids = $user -> getAllChildIds ();
2020-01-30 01:48:28 +01:00
$childids [] = $user -> id ;
2021-03-22 11:30:18 +01:00
$this -> where .= " AND e.fk_user_author IN ( " . $this -> db -> sanitize ( join ( ',' , $childids )) . " ) " ;
2015-02-21 16:15:54 +01:00
}
2021-02-25 22:45:02 +01:00
if ( $this -> userid > 0 ) {
2021-03-22 11:30:18 +01:00
$this -> where .= ' AND e.fk_user_author = ' . (( int ) $this -> userid );
2021-02-25 22:45:02 +01:00
}
2015-02-14 18:39:45 +01:00
}
/**
2015-02-21 15:18:05 +01:00
* Return nb of expense report per year
2015-02-14 18:39:45 +01:00
*
* @ return array Array of values
*/
2019-02-25 20:35:59 +01:00
public function getNbByYear ()
2015-02-14 18:39:45 +01:00
{
2021-08-28 01:45:53 +02:00
$sql = " SELECT YEAR( " . $this -> db -> ifsql ( " e. " . $this -> datetouse . " IS NULL " , " e.date_create " , " e. " . $this -> datetouse ) . " ) as dm, count(*) " ;
2020-01-30 01:48:28 +01:00
$sql .= " FROM " . $this -> from ;
$sql .= " GROUP BY dm DESC " ;
$sql .= " WHERE " . $this -> where ;
2015-02-14 18:39:45 +01:00
return $this -> _getNbByYear ( $sql );
}
/**
* Renvoie le nombre de facture par mois pour une annee donnee
*
2017-12-08 16:15:41 +01:00
* @ param string $year Year to scan
2020-10-31 14:32:18 +01:00
* @ param int $format 0 = Label of abscissa is a translated text , 1 = Label of abscissa is month number , 2 = Label of abscissa is first letter of month
2017-12-08 16:15:41 +01:00
* @ return array Array of values
2015-02-14 18:39:45 +01:00
*/
2019-02-25 20:35:59 +01:00
public function getNbByMonth ( $year , $format = 0 )
2015-02-14 18:39:45 +01:00
{
2021-08-28 01:45:53 +02:00
$sql = " SELECT MONTH( " . $this -> db -> ifsql ( " e. " . $this -> datetouse . " IS NULL " , " e.date_create " , " e. " . $this -> datetouse ) . " ) as dm, count(*) " ;
2020-01-30 01:48:28 +01:00
$sql .= " FROM " . $this -> from ;
2021-03-30 19:12:07 +02:00
$sql .= " WHERE YEAR(e. " . $this -> datetouse . " ) = " . (( int ) $year );
2020-01-30 01:48:28 +01:00
$sql .= " AND " . $this -> where ;
$sql .= " GROUP BY dm " ;
2020-10-31 14:32:18 +01:00
$sql .= $this -> db -> order ( 'dm' , 'DESC' );
2015-02-14 18:39:45 +01:00
2020-01-30 01:48:28 +01:00
$res = $this -> _getNbByMonth ( $year , $sql , $format );
2015-02-14 18:39:45 +01:00
//var_dump($res);print '<br>';
return $res ;
}
/**
* Renvoie le montant de facture par mois pour une annee donnee
*
* @ param int $year Year to scan
2020-10-31 14:32:18 +01:00
* @ param int $format 0 = Label of abscissa is a translated text , 1 = Label of abscissa is month number , 2 = Label of abscissa is first letter of month
2015-02-14 18:39:45 +01:00
* @ return array Array of values
*/
2019-02-25 20:35:59 +01:00
public function getAmountByMonth ( $year , $format = 0 )
2015-02-14 18:39:45 +01:00
{
2021-08-28 01:45:53 +02:00
$sql = " SELECT date_format( " . $this -> db -> ifsql ( " e. " . $this -> datetouse . " IS NULL " , " e.date_create " , " e. " . $this -> datetouse ) . " ,'%m') as dm, sum( " . $this -> field . " ) " ;
2020-01-30 01:48:28 +01:00
$sql .= " FROM " . $this -> from ;
2021-08-28 01:45:53 +02:00
$sql .= " WHERE date_format( " . $this -> db -> ifsql ( " e. " . $this -> datetouse . " IS NULL " , " e.date_create " , " e. " . $this -> datetouse ) . " ,'%Y') = ' " . $this -> db -> escape ( $year ) . " ' " ;
2020-01-30 01:48:28 +01:00
$sql .= " AND " . $this -> where ;
$sql .= " GROUP BY dm " ;
$sql .= $this -> db -> order ( 'dm' , 'DESC' );
2015-02-14 18:39:45 +01:00
2020-01-30 01:48:28 +01:00
$res = $this -> _getAmountByMonth ( $year , $sql , $format );
2015-02-14 18:39:45 +01:00
//var_dump($res);print '<br>';
return $res ;
}
/**
* Return average amount
*
* @ param int $year Year to scan
* @ return array Array of values
*/
2019-02-25 20:35:59 +01:00
public function getAverageByMonth ( $year )
2015-02-14 18:39:45 +01:00
{
2021-08-28 01:45:53 +02:00
$sql = " SELECT date_format( " . $this -> db -> ifsql ( " e. " . $this -> datetouse . " IS NULL " , " e.date_create " , " e. " . $this -> datetouse ) . " ,'%m') as dm, avg( " . $this -> field . " ) " ;
2020-01-30 01:48:28 +01:00
$sql .= " FROM " . $this -> from ;
2021-08-28 01:45:53 +02:00
$sql .= " WHERE date_format( " . $this -> db -> ifsql ( " e. " . $this -> datetouse . " IS NULL " , " e.date_create " , " e. " . $this -> datetouse ) . " ,'%Y') = ' " . $this -> db -> escape ( $year ) . " ' " ;
2020-01-30 01:48:28 +01:00
$sql .= " AND " . $this -> where ;
$sql .= " GROUP BY dm " ;
2020-10-31 14:32:18 +01:00
$sql .= $this -> db -> order ( 'dm' , 'DESC' );
2015-02-14 18:39:45 +01:00
return $this -> _getAverageByMonth ( $year , $sql );
}
/**
* Return nb , total and average
*
* @ return array Array of values
*/
2019-02-25 20:35:59 +01:00
public function getAllByYear ()
2015-02-14 18:39:45 +01:00
{
2021-08-28 01:45:53 +02:00
$sql = " SELECT date_format( " . $this -> db -> ifsql ( " e. " . $this -> datetouse . " IS NULL " , " e.date_create " , " e. " . $this -> datetouse ) . " ,'%Y') as year, count(*) as nb, sum( " . $this -> field . " ) as total, avg( " . $this -> field . " ) as avg " ;
2020-01-30 01:48:28 +01:00
$sql .= " FROM " . $this -> from ;
$sql .= " WHERE " . $this -> where ;
$sql .= " GROUP BY year " ;
2020-10-31 14:32:18 +01:00
$sql .= $this -> db -> order ( 'year' , 'DESC' );
2015-02-14 18:39:45 +01:00
2020-10-31 14:32:18 +01:00
return $this -> _getAllByYear ( $sql );
}
2015-02-14 18:39:45 +01:00
}