2020-02-07 10:58:17 +01:00
< ? php
2020-02-08 13:44:31 +01:00
/* Copyright ( C ) 2020 Laurent Destailleur < eldy @ users . sourceforge . net >
2020-02-07 10:58:17 +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
* along with this program . If not , see < http :// www . gnu . org / licenses />.
2020-02-11 10:38:09 +01:00
*
* This tool can be included into a list page with
* define ( 'USE_CUSTOME_REPORT_AS_INCLUDE' , 1 );
* include DOL_DOCUMENT_ROOT . '/core/customreports.php' ;
2020-02-07 10:58:17 +01:00
*/
/**
* \file htdocs / core / customreports . php
2020-02-08 17:46:41 +01:00
* \ingroup core
2020-02-07 10:58:17 +01:00
* \brief Page to make custom reports
*/
2020-02-13 10:44:08 +01:00
if ( ! defined ( 'USE_CUSTOME_REPORT_AS_INCLUDE' ))
2020-02-07 10:58:17 +01:00
{
2020-02-11 10:38:09 +01:00
require '../main.inc.php' ;
require_once DOL_DOCUMENT_ROOT . " /core/lib/admin.lib.php " ;
require_once DOL_DOCUMENT_ROOT . " /core/lib/company.lib.php " ;
require_once DOL_DOCUMENT_ROOT . " /core/class/dolgraph.class.php " ;
require_once DOL_DOCUMENT_ROOT . " /core/class/doleditor.class.php " ;
// Get parameters
$action = GETPOST ( 'action' , 'aZ09' ) ? GETPOST ( 'action' , 'aZ09' ) : 'view' ; // The action 'add', 'create', 'edit', 'update', 'view', ...
$massaction = GETPOST ( 'massaction' , 'alpha' ); // The bulk action (combo box choice into lists)
2020-02-13 10:44:08 +01:00
$mode = GETPOST ( 'mode' , 'alpha' ) ? GETPOST ( 'mode' , 'alpha' ) : 'graph' ;
2020-02-11 10:38:09 +01:00
$objecttype = GETPOST ( 'objecttype' , 'aZ09' );
$tabfamily = GETPOST ( 'tabfamily' , 'aZ09' );
if ( empty ( $objecttype )) $objecttype = 'thirdparty' ;
$search_filters = GETPOST ( 'search_filters' , 'array' );
$search_measures = GETPOST ( 'search_measures' , 'array' );
$search_xaxis = GETPOST ( 'search_xaxis' , 'array' );
$search_yaxis = GETPOST ( 'search_yaxis' , 'array' );
$search_graph = GETPOST ( 'search_graph' , 'none' );
// Load variable for pagination
$limit = GETPOST ( 'limit' , 'int' ) ? GETPOST ( 'limit' , 'int' ) : $conf -> liste_limit ;
$sortfield = GETPOST ( 'sortfield' , 'alpha' );
$sortorder = GETPOST ( 'sortorder' , 'alpha' );
$page = GETPOST ( 'page' , 'int' );
if ( empty ( $page ) || $page == - 1 || GETPOST ( 'button_search' , 'alpha' ) || GETPOST ( 'button_removefilter' , 'alpha' ) || ( empty ( $toselect ) && $massaction === '0' )) { $page = 0 ; } // If $page is not defined, or '' or -1 or if we click on clear filters or if we select empty mass action
$offset = $limit * $page ;
$pageprev = $page - 1 ;
$pagenext = $page + 1 ;
$diroutputmassaction = $conf -> user -> dir_temp . '/' . $user -> id . '/customreport' ;
2020-02-07 10:58:17 +01:00
}
2020-02-11 10:38:09 +01:00
// Load traductions files requiredby by page
$langs -> loadLangs ( array ( " companies " , " other " , " exports " ));
2020-02-07 10:58:17 +01:00
$extrafields = new ExtraFields ( $db );
$hookmanager -> initHooks ( array ( 'customreport' )); // Note that conf->hooks_modules contains array
$title = '' ;
$picto = '' ;
$head = array ();
$object = null ;
$ObjectClassName = '' ;
2020-02-08 17:46:41 +01:00
// Objects available by default
2020-02-07 10:58:17 +01:00
$arrayoftype = array (
2020-02-08 13:44:31 +01:00
'thirdparty' => array ( 'label' => 'ThirdParties' , 'ObjectClassName' => 'Societe' , 'enabled' => $conf -> societe -> enabled , 'ClassPath' => DOL_DOCUMENT_ROOT . " /societe/class/societe.class.php " ),
'contact' => array ( 'label' => 'Contacts' , 'ObjectClassName' => 'Contact' , 'enabled' => $conf -> societe -> enabled , 'ClassPath' => DOL_DOCUMENT_ROOT . " /contact/class/contact.class.php " ),
'contract' => array ( 'label' => 'Contracts' , 'ObjectClassName' => 'Contrat' , 'enabled' => $conf -> contrat -> enabled , 'ClassPath' => DOL_DOCUMENT_ROOT . " /contrat/class/contrat.class.php " , 'langs' => 'contract' ),
'invoice' => array ( 'label' => 'Invoices' , 'ObjectClassName' => 'Facture' , 'enabled' => $conf -> facture -> enabled , 'ClassPath' => DOL_DOCUMENT_ROOT . " /compta/facture/class/facture.class.php " ),
'invoice_template' => array ( 'label' => 'PredefinedInvoices' , 'ObjectClassName' => 'FactureRec' , 'enabled' => $conf -> facture -> enabled , 'ClassPath' => DOL_DOCUMENT_ROOT . " /compta/class/facturerec.class.php " ),
'bom' => array ( 'label' => 'BOM' , 'ObjectClassName' => 'Bom' , 'enabled' => $conf -> bom -> enabled ),
'mo' => array ( 'label' => 'MO' , 'ObjectClassName' => 'Mo' , 'enabled' => $conf -> mo -> enabled , 'ClassPath' => DOL_DOCUMENT_ROOT . " /mrp/class/mo.class.php " ),
'ticket' => array ( 'label' => 'Ticket' , 'ObjectClassName' => 'Ticket' , 'enabled' => $conf -> ticket -> enabled ),
'member' => array ( 'label' => 'Adherent' , 'ObjectClassName' => 'Adherent' , 'enabled' => $conf -> adherent -> enabled , 'ClassPath' => DOL_DOCUMENT_ROOT . " /adherents/class/adherent.class.php " , 'langs' => 'members' ),
'cotisation' => array ( 'label' => 'Subscriptions' , 'ObjectClassName' => 'Subscription' , 'enabled' => $conf -> adherent -> enabled , 'ClassPath' => DOL_DOCUMENT_ROOT . " /adherents/class/subscription.class.php " , 'langs' => 'members' ),
2020-02-07 10:58:17 +01:00
);
// Complete $arrayoftype
$parameters = array ( 'objecttype' => $objecttype , 'tabfamily' => $tabfamily );
$reshook = $hookmanager -> executeHooks ( 'loadDataForCustomReports' , $parameters , $object , $action ); // Note that $action and $object may have been modified by some hooks
if ( $reshook < 0 ) setEventMessages ( $hookmanager -> error , $hookmanager -> errors , 'errors' );
2020-02-07 11:53:09 +01:00
elseif ( is_array ( $hookmanager -> resArray )) {
2020-02-13 10:44:08 +01:00
if ( ! empty ( $hookmanager -> resArray [ 'title' ])) { // Add entries for tabs
2020-02-07 10:58:17 +01:00
$title = $hookmanager -> resArray [ 'title' ];
}
2020-02-13 10:44:08 +01:00
if ( ! empty ( $hookmanager -> resArray [ 'picto' ])) { // Add entries for tabs
2020-02-07 10:58:17 +01:00
$picto = $hookmanager -> resArray [ 'picto' ];
}
2020-02-13 10:44:08 +01:00
if ( ! empty ( $hookmanager -> resArray [ 'head' ])) { // Add entries for tabs
2020-02-07 10:58:17 +01:00
$head = array_merge ( $head , $hookmanager -> resArray [ 'head' ]);
}
2020-02-13 10:44:08 +01:00
if ( ! empty ( $hookmanager -> resArray [ 'arrayoftype' ])) { // Add entries from hook
foreach ( $hookmanager -> resArray [ 'arrayoftype' ] as $key => $val ) {
2020-02-07 11:53:09 +01:00
$arrayoftype [ $key ] = $val ;
2020-02-07 10:58:17 +01:00
}
}
2020-02-13 10:44:08 +01:00
if ( ! empty ( $hookmanager -> resArray [ 'modenotusedforlist' ])) { // Show objecttype selection even if objecttype is set
2020-02-11 10:38:09 +01:00
$modenotusedforlist = $hookmanager -> resArray [ 'modenotusedforlist' ];
}
2020-02-07 10:58:17 +01:00
}
if ( $objecttype ) {
try {
2020-02-08 13:44:31 +01:00
if ( $arrayoftype [ $objecttype ][ 'langs' ]) {
$langs -> load ( $arrayoftype [ $objecttype ][ 'langs' ]);
}
if ( $arrayoftype [ $objecttype ][ 'ClassPath' ]) {
include_once $arrayoftype [ $objecttype ][ 'ClassPath' ];
} else {
include_once DOL_DOCUMENT_ROOT . " / " . $objecttype . " /class/ " . $objecttype . " .class.php " ;
}
2020-02-07 10:58:17 +01:00
$ObjectClassName = $arrayoftype [ $objecttype ][ 'ObjectClassName' ];
$object = new $ObjectClassName ( $db );
}
2020-02-13 10:44:08 +01:00
catch ( Exception $e ) {
2020-02-07 10:58:17 +01:00
print 'Failed to load class for type ' . $objecttype ;
}
}
2020-02-07 11:53:09 +01:00
// Security check
$socid = 0 ;
if ( $user -> socid > 0 ) // Protection if external user
{
//$socid = $user->socid;
accessforbidden ();
}
$result = restrictedArea ( $user , $object -> element , 0 , '' );
2020-02-07 10:58:17 +01:00
// Fetch optionals attributes and labels
$extrafields -> fetch_name_optionals_label ( $object -> table_element );
//$extrafields->fetch_name_optionals_label($object->table_element_line);
$search_array_options = $extrafields -> getOptionalsFromPost ( $object -> table_element , '' , 'search_' );
2020-02-13 10:44:08 +01:00
$search_component_params = array ( '' );
2020-02-07 10:58:17 +01:00
/*
* Actions
*/
/*
* View
*/
2020-02-13 10:44:08 +01:00
$form = new Form ( $db );
2020-02-07 10:58:17 +01:00
2020-02-13 10:44:08 +01:00
if ( ! defined ( 'USE_CUSTOME_REPORT_AS_INCLUDE' )) {
2020-02-11 10:38:09 +01:00
llxHeader ( '' , $langs -> transnoentitiesnoconv ( 'CustomReports' ), '' );
2020-02-07 10:58:17 +01:00
2020-02-11 10:38:09 +01:00
dol_fiche_head ( $head , 'customreports' , $title , - 1 , $picto );
2020-02-08 17:46:41 +01:00
}
2020-02-07 10:58:17 +01:00
2020-02-11 10:38:09 +01:00
// Check parameters
if ( $action == 'viewgraph' ) {
2020-02-13 10:44:08 +01:00
if ( ! count ( $search_measures )) {
2020-02-11 10:38:09 +01:00
setEventMessages ( $langs -> trans ( " AtLeastOneMeasureIsRequired " ), null , 'warnings' );
} elseif ( $mode == 'graph' && count ( $search_xaxis ) > 1 ) {
setEventMessages ( $langs -> trans ( " OnlyOneFieldForXAxisIsPossible " ), null , 'warnings' );
$search_xaxis = array ( 0 => $search_xaxis [ 0 ]);
}
2020-02-13 10:44:08 +01:00
if ( ! count ( $search_xaxis )) {
2020-02-11 10:38:09 +01:00
setEventMessages ( $langs -> trans ( " AtLeastOneXAxisIsRequired " ), null , 'warnings' );
} elseif ( $mode == 'graph' && $search_graph == 'bars' && count ( $search_measures ) > 3 ) {
setEventMessages ( $langs -> trans ( " GraphInBarsAreLimitedTo3Measures " ), null , 'warnings' );
$search_graph = 'lines' ;
}
}
2020-02-07 10:58:17 +01:00
2020-02-13 10:44:08 +01:00
$tmparray = dol_getdate ( dol_now ());
$endyear = $tmparray [ 'year' ];
$endmonth = $tmparray [ 'mon' ];
$datelastday = dol_get_last_day ( $endyear , $endmonth , 1 );
$startyear = $endyear - 2 ;
2020-02-07 10:58:17 +01:00
$param = '' ;
$arrayofmesures = array ( 't.count' => 'Count' );
$arrayofxaxis = array ();
$arrayofyaxis = array ();
print '<form method="post" action="' . $_SERVER [ 'PHP_SELF' ] . '">' ;
print '<input type="hidden" name="token" value="' . $_SESSION [ 'newtoken' ] . '">' ;
2020-02-11 10:38:09 +01:00
print '<input type="hidden" name="action" value="viewgraph">' ;
2020-02-08 14:49:26 +01:00
print '<input type="hidden" name="tabfamily" value="' . $tabfamily . '">' ;
2020-02-07 10:58:17 +01:00
print '<div class="liste_titre liste_titre_bydiv centpercent">' ;
// Select object
print '<div class="divadvancedsearchfield center floatnone">' ;
print '<div class="inline-block"><span class="opacitymedium">' . $langs -> trans ( " StatisticsOn " ) . '</span></div> ' ;
2020-02-11 10:38:09 +01:00
$newarrayoftype = array ();
2020-02-13 10:44:08 +01:00
foreach ( $arrayoftype as $key => $val ) {
2020-02-11 10:38:09 +01:00
if ( dol_eval ( $val [ 'enabled' ], 1 )) {
$newarrayoftype [ $key ] = $arrayoftype [ $key ];
}
}
print $form -> selectarray ( 'objecttype' , $newarrayoftype , $objecttype , 0 , 0 , 0 , '' , 1 , 0 , 0 , '' , '' , 1 );
2020-02-07 10:58:17 +01:00
if ( empty ( $conf -> use_javascript_ajax )) print '<input type="submit" class="button" name="changeobjecttype" value="' . $langs -> trans ( " Refresh " ) . '">' ;
else {
print ' < script type = " text/javascript " language = " javascript " >
jQuery ( document ) . ready ( function () {
jQuery ( " #objecttype " ) . change ( function () {
console . log ( " Reload for " + jQuery ( " #objecttype " ) . val ());
2020-02-13 10:44:08 +01:00
location . href = " '. $_SERVER["PHP_SELF"] .'?objecttype= " + jQuery ( " #objecttype " ) . val () + " '.( $tabfamily ? '&tabfamily='. $tabfamily : '').' " ;
2020-02-07 10:58:17 +01:00
});
});
</ script > ' ;
}
print '</div><div class="clearboth"></div>' ;
// Add Filter
print '<div class="divadvancedsearchfield quatrevingtpercent">' ;
print $form -> searchComponent ( array ( $object -> element => $object -> fields ), $search_component_params );
print '</div>' ;
// Measures
print '<div class="divadvancedsearchfield clearboth">' ;
2020-02-13 10:44:08 +01:00
foreach ( $object -> fields as $key => $val ) {
2020-02-07 10:58:17 +01:00
if ( $val [ 'isameasure' ]) {
$arrayofmesures [ 't.' . $key . '-sum' ] = $langs -> trans ( $val [ 'label' ]) . ' <span class="opacitymedium">(' . $langs -> trans ( " Sum " ) . ')</span>' ;
$arrayofmesures [ 't.' . $key . '-average' ] = $langs -> trans ( $val [ 'label' ]) . ' <span class="opacitymedium">(' . $langs -> trans ( " Average " ) . ')</span>' ;
2020-02-07 11:53:09 +01:00
$arrayofmesures [ 't.' . $key . '-min' ] = $langs -> trans ( $val [ 'label' ]) . ' <span class="opacitymedium">(' . $langs -> trans ( " Minimum " ) . ')</span>' ;
$arrayofmesures [ 't.' . $key . '-max' ] = $langs -> trans ( $val [ 'label' ]) . ' <span class="opacitymedium">(' . $langs -> trans ( " Maximum " ) . ')</span>' ;
2020-02-07 10:58:17 +01:00
}
}
// Add measure from extrafields
if ( $object -> isextrafieldmanaged ) {
2020-02-13 10:44:08 +01:00
foreach ( $extrafields -> attributes [ $object -> table_element ][ 'label' ] as $key => $val ) {
if ( ! empty ( $extrafields -> attributes [ $object -> table_element ][ 'totalizable' ][ $key ])) {
2020-02-07 10:58:17 +01:00
$arrayofmesures [ 'te.' . $key . '-sum' ] = $langs -> trans ( $extrafields -> attributes [ $object -> table_element ][ 'label' ][ $key ]) . ' <span class="opacitymedium">(' . $langs -> trans ( " Sum " ) . ')</span>' ;
$arrayofmesures [ 'te.' . $key . '-average' ] = $langs -> trans ( $extrafields -> attributes [ $object -> table_element ][ 'label' ][ $key ]) . ' <span class="opacitymedium">(' . $langs -> trans ( " Average " ) . ')</span>' ;
2020-02-07 11:53:09 +01:00
$arrayofmesures [ 'te.' . $key . '-min' ] = $langs -> trans ( $extrafields -> attributes [ $object -> table_element ][ 'label' ][ $key ]) . ' <span class="opacitymedium">(' . $langs -> trans ( " Minimum " ) . ')</span>' ;
$arrayofmesures [ 'te.' . $key . '-max' ] = $langs -> trans ( $extrafields -> attributes [ $object -> table_element ][ 'label' ][ $key ]) . ' <span class="opacitymedium">(' . $langs -> trans ( " Maximum " ) . ')</span>' ;
2020-02-07 10:58:17 +01:00
}
}
}
print '<div class="inline-block opacitymedium"><span class="fas fa-chart-line paddingright" title="' . $langs -> trans ( " Measures " ) . '"></span>' . $langs -> trans ( " Measures " ) . '</div> ' ;
2020-02-12 22:10:26 +01:00
print $form -> multiselectarray ( 'search_measures' , $arrayofmesures , $search_measures , 0 , 0 , 'minwidth500' , 1 );
2020-02-07 10:58:17 +01:00
print '</div>' ;
// XAxis
print '<div class="divadvancedsearchfield">' ;
2020-02-13 10:44:08 +01:00
foreach ( $object -> fields as $key => $val ) {
if ( ! $val [ 'measure' ]) {
2020-02-08 11:32:38 +01:00
if ( in_array ( $key , array (
'id' , 'ref_int' , 'ref_ext' , 'rowid' , 'entity' , 'last_main_doc' , 'logo' , 'logo_squarred' , 'extraparams' ,
'parent' , 'photo' , 'socialnetworks' , 'webservices_url' , 'webservices_key' ))) continue ;
2020-02-13 10:44:08 +01:00
if ( isset ( $val [ 'enabled' ]) && ! dol_eval ( $val [ 'enabled' ], 1 )) continue ;
if ( isset ( $val [ 'visible' ]) && ! dol_eval ( $val [ 'visible' ], 1 )) continue ;
if ( preg_match ( '/^fk_/' , $key ) && ! preg_match ( '/^fk_statu/' , $key )) continue ;
2020-02-08 13:44:31 +01:00
if ( preg_match ( '/^pass/' , $key )) continue ;
2020-02-07 10:58:17 +01:00
if ( in_array ( $val [ 'type' ], array ( 'html' , 'text' ))) continue ;
if ( in_array ( $val [ 'type' ], array ( 'timestamp' , 'date' , 'datetime' ))) {
$arrayofxaxis [ 't.' . $key . '-year' ] = array ( 'label' => $langs -> trans ( $val [ 'label' ]) . ' (' . $langs -> trans ( " Year " ) . ')' , 'position' => $val [ 'position' ]);
$arrayofxaxis [ 't.' . $key . '-month' ] = array ( 'label' => $langs -> trans ( $val [ 'label' ]) . ' (' . $langs -> trans ( " Month " ) . ')' , 'position' => $val [ 'position' ]);
$arrayofxaxis [ 't.' . $key . '-day' ] = array ( 'label' => $langs -> trans ( $val [ 'label' ]) . ' (' . $langs -> trans ( " Day " ) . ')' , 'position' => $val [ 'position' ]);
} else {
$arrayofxaxis [ 't.' . $key ] = array ( 'label' => $val [ 'label' ], 'position' => ( int ) $val [ 'position' ]);
}
}
// Add measure from extrafields
if ( $object -> isextrafieldmanaged ) {
2020-02-13 10:44:08 +01:00
foreach ( $extrafields -> attributes [ $object -> table_element ][ 'label' ] as $key => $val ) {
if ( ! empty ( $extrafields -> attributes [ $object -> table_element ][ 'totalizable' ][ $key ])) {
2020-02-07 10:58:17 +01:00
$arrayofxaxis [ 'te.' . $key ] = array ( 'label' => $extrafields -> attributes [ $object -> table_element ][ 'label' ][ $key ], 'position' => ( int ) $extrafields -> attributes [ $object -> table_element ][ 'pos' ][ $key ]);
}
}
}
}
$arrayofxaxis = dol_sort_array ( $arrayofxaxis , 'position' );
$arrayofxaxislabel = array ();
2020-02-13 10:44:08 +01:00
foreach ( $arrayofxaxis as $key => $val ) {
2020-02-07 10:58:17 +01:00
$arrayofxaxislabel [ $key ] = $val [ 'label' ];
}
print '<div class="inline-block opacitymedium"><span class="fas fa-ruler-horizontal paddingright" title="' . $langs -> trans ( " XAxis " ) . '"></span>' . $langs -> trans ( " XAxis " ) . '</div> ' ;
print $form -> multiselectarray ( 'search_xaxis' , $arrayofxaxislabel , $search_xaxis , 0 , 0 , 'minwidth500' , 1 );
print '</div>' ;
// YAxis
if ( $mode == 'grid' ) {
print '<div class="divadvancedsearchfield">' ;
2020-02-13 10:44:08 +01:00
foreach ( $object -> fields as $key => $val ) {
if ( ! $val [ 'measure' ]) {
2020-02-07 10:58:17 +01:00
if ( in_array ( $key , array ( 'id' , 'rowid' , 'entity' , 'last_main_doc' , 'extraparams' ))) continue ;
if ( preg_match ( '/^fk_/' , $key )) continue ;
if ( in_array ( $val [ 'type' ], array ( 'html' , 'text' ))) continue ;
if ( in_array ( $val [ 'type' ], array ( 'timestamp' , 'date' , 'datetime' ))) {
$arrayofyaxis [ 't.' . $key . '-year' ] = array ( 'label' => $langs -> trans ( $val [ 'label' ]) . ' (' . $langs -> trans ( " Year " ) . ')' , 'position' => $val [ 'position' ]);
$arrayofyaxis [ 't.' . $key . '-month' ] = array ( 'label' => $langs -> trans ( $val [ 'label' ]) . ' (' . $langs -> trans ( " Month " ) . ')' , 'position' => $val [ 'position' ]);
$arrayofyaxis [ 't.' . $key . '-day' ] = array ( 'label' => $langs -> trans ( $val [ 'label' ]) . ' (' . $langs -> trans ( " Day " ) . ')' , 'position' => $val [ 'position' ]);
} else {
$arrayofyaxis [ 't.' . $key ] = array ( 'label' => $val [ 'label' ], 'position' => ( int ) $val [ 'position' ]);
}
}
// Add measure from extrafields
if ( $object -> isextrafieldmanaged ) {
2020-02-13 10:44:08 +01:00
foreach ( $extrafields -> attributes [ $object -> table_element ][ 'label' ] as $key => $val ) {
if ( ! empty ( $extrafields -> attributes [ $object -> table_element ][ 'totalizable' ][ $key ])) {
2020-02-07 10:58:17 +01:00
$arrayofyaxis [ 'te.' . $key ] = array ( 'label' => $extrafields -> attributes [ $object -> table_element ][ 'label' ][ $key ], 'position' => ( int ) $extrafields -> attributes [ $object -> table_element ][ 'pos' ][ $key ]);
}
}
}
}
$arrayofyaxis = dol_sort_array ( $arrayofyaxis , 'position' );
$arrayofyaxislabel = array ();
2020-02-13 10:44:08 +01:00
foreach ( $arrayofyaxis as $key => $val ) {
2020-02-07 10:58:17 +01:00
$arrayofyaxislabel [ $key ] = $val [ 'label' ];
}
print '<div class="inline-block opacitymedium"><span class="fas fa-ruler-vertical paddingright" title="' . $langs -> trans ( " YAxis " ) . '"></span>' . $langs -> trans ( " YAxis " ) . '</div> ' ;
print $form -> multiselectarray ( 'search_yaxis' , $arrayofyaxislabel , $search_yaxis , 0 , 0 , 'minwidth100' , 1 );
print '</div>' ;
}
if ( $mode == 'graph' ) {
print '<div class="divadvancedsearchfield">' ;
2020-02-08 17:46:41 +01:00
$arrayofgraphs = array ( 'bars' => 'Bars' , 'lines' => 'Lines' ); // also 'pies'
2020-02-07 10:58:17 +01:00
print '<div class="inline-block opacitymedium"><span class="fas fa-chart-area paddingright" title="' . $langs -> trans ( " Graph " ) . '"></span>' . $langs -> trans ( " Graph " ) . '</div> ' ;
2020-02-08 17:46:41 +01:00
print $form -> selectarray ( 'search_graph' , $arrayofgraphs , $search_graph , 0 , 0 , 0 , 'minwidth100' , 1 );
2020-02-07 10:58:17 +01:00
print '</div>' ;
}
print '<div class="divadvancedsearchfield">' ;
print '<input type="submit" class="button" value="' . $langs -> trans ( " Refresh " ) . '">' ;
print '</div>' ;
print '</div>' ;
print '</form>' ;
// Generate the SQL request
$sql = '' ;
2020-02-13 10:44:08 +01:00
if ( ! empty ( $search_measures ) && ! empty ( $search_xaxis ))
2020-02-07 10:58:17 +01:00
{
$fieldid = 'rowid' ;
$sql = 'SELECT ' ;
2020-02-13 10:44:08 +01:00
foreach ( $search_xaxis as $key => $val ) {
2020-02-07 10:58:17 +01:00
if ( preg_match ( '/\-year$/' , $val )) {
$tmpval = preg_replace ( '/\-year$/' , '' , $val );
$sql .= 'DATE_FORMAT(' . $tmpval . " , '%Y') as x_ " . $key . ', ' ;
} elseif ( preg_match ( '/\-month$/' , $val )) {
$tmpval = preg_replace ( '/\-month$/' , '' , $val );
$sql .= 'DATE_FORMAT(' . $tmpval . " , '%Y-%m') as x_ " . $key . ', ' ;
} elseif ( preg_match ( '/\-day$/' , $val )) {
$tmpval = preg_replace ( '/\-day$/' , '' , $val );
$sql .= 'DATE_FORMAT(' . $tmpval . " , '%Y-%m-%d') as x_ " . $key . ', ' ;
}
else $sql .= $val . ' as x_' . $key . ', ' ;
}
2020-02-13 10:44:08 +01:00
foreach ( $search_measures as $key => $val ) {
2020-02-07 10:58:17 +01:00
if ( $val == 't.count' ) $sql .= 'COUNT(t.' . $fieldid . ') as y_' . $key . ', ' ;
elseif ( preg_match ( '/\-sum$/' , $val )) {
2020-02-13 10:44:08 +01:00
$tmpval = preg_replace ( '/\-sum$/' , '' , $val );
2020-02-07 10:58:17 +01:00
$sql .= 'SUM(' . $db -> ifsql ( $tmpval . ' IS NULL' , '0' , $tmpval ) . ') as y_' . $key . ', ' ;
}
elseif ( preg_match ( '/\-average$/' , $val )) {
2020-02-13 10:44:08 +01:00
$tmpval = preg_replace ( '/\-average$/' , '' , $val );
2020-02-07 10:58:17 +01:00
$sql .= 'AVG(' . $db -> ifsql ( $tmpval . ' IS NULL' , '0' , $tmpval ) . ') as y_' . $key . ', ' ;
}
2020-02-07 13:01:07 +01:00
elseif ( preg_match ( '/\-min$/' , $val )) {
$tmpval = preg_replace ( '/\-min$/' , '' , $val );
$sql .= 'MIN(' . $db -> ifsql ( $tmpval . ' IS NULL' , '0' , $tmpval ) . ') as y_' . $key . ', ' ;
}
elseif ( preg_match ( '/\-max$/' , $val )) {
2020-02-13 10:44:08 +01:00
$tmpval = preg_replace ( '/\-max$/' , '' , $val );
2020-02-07 13:01:07 +01:00
$sql .= 'MAX(' . $db -> ifsql ( $tmpval . ' IS NULL' , '0' , $tmpval ) . ') as y_' . $key . ', ' ;
}
2020-02-07 10:58:17 +01:00
}
$sql = preg_replace ( '/,\s*$/' , '' , $sql );
$sql .= ' FROM ' . MAIN_DB_PREFIX . $object -> table_element . ' as t' ;
// Add measure from extrafields
if ( $object -> isextrafieldmanaged ) {
$sql .= ' LEFT JOIN ' . MAIN_DB_PREFIX . $object -> table_element . '_extrafields as te ON te.fk_object = t.' . $fieldid ;
}
2020-02-08 13:44:31 +01:00
if ( $object -> ismultientitymanaged ) {
if ( $object -> ismultientitymanaged == 1 ) {
// Nothing here
} else {
$tmparray = explode ( '@' , $object -> ismultientitymanaged );
$sql .= ' INNER JOIN ' . MAIN_DB_PREFIX . $tmparray [ 1 ] . ' as parenttable ON t.' . $tmparray [ 0 ] . ' = parenttable.rowid' ;
$sql .= ' AND parenttable.entity IN (' . getEntity ( $tmparray [ 1 ]) . ')' ;
}
}
2020-02-07 10:58:17 +01:00
$sql .= ' WHERE 1 = 1' ;
2020-02-08 13:44:31 +01:00
if ( $object -> ismultientitymanaged == 1 ) {
$sql .= ' AND entity IN (' . getEntity ( $object -> element ) . ')' ;
}
2020-02-13 10:44:08 +01:00
foreach ( $search_filters as $key => $val ) {
2020-02-07 12:51:08 +01:00
// TODO
2020-02-07 10:58:17 +01:00
}
$sql .= ' GROUP BY ' ;
2020-02-13 10:44:08 +01:00
foreach ( $search_xaxis as $key => $val ) {
2020-02-07 10:58:17 +01:00
if ( preg_match ( '/\-year$/' , $val )) {
$tmpval = preg_replace ( '/\-year$/' , '' , $val );
$sql .= 'DATE_FORMAT(' . $tmpval . " , '%Y'), " ;
} elseif ( preg_match ( '/\-month$/' , $val )) {
$tmpval = preg_replace ( '/\-month$/' , '' , $val );
$sql .= 'DATE_FORMAT(' . $tmpval . " , '%Y-%m'), " ;
} elseif ( preg_match ( '/\-day$/' , $val )) {
$tmpval = preg_replace ( '/\-day$/' , '' , $val );
$sql .= 'DATE_FORMAT(' . $tmpval . " , '%Y-%m-%d'), " ;
}
else $sql .= $val . ', ' ;
}
$sql = preg_replace ( '/,\s*$/' , '' , $sql );
$sql .= ' ORDER BY ' ;
2020-02-13 10:44:08 +01:00
foreach ( $search_xaxis as $key => $val ) {
2020-02-07 10:58:17 +01:00
if ( preg_match ( '/\-year$/' , $val )) {
$tmpval = preg_replace ( '/\-year$/' , '' , $val );
$sql .= 'DATE_FORMAT(' . $tmpval . " , '%Y'), " ;
} elseif ( preg_match ( '/\-month$/' , $val )) {
$tmpval = preg_replace ( '/\-month$/' , '' , $val );
$sql .= 'DATE_FORMAT(' . $tmpval . " , '%Y-%m'), " ;
} elseif ( preg_match ( '/\-day$/' , $val )) {
$tmpval = preg_replace ( '/\-day$/' , '' , $val );
$sql .= 'DATE_FORMAT(' . $tmpval . " , '%Y-%m-%d'), " ;
}
else $sql .= $val . ', ' ;
}
$sql = preg_replace ( '/,\s*$/' , '' , $sql );
}
2020-02-13 10:44:08 +01:00
$legend = array ();
foreach ( $search_measures as $key => $val ) {
2020-02-07 10:58:17 +01:00
$legend [] = $langs -> trans ( $arrayofmesures [ $val ]);
}
// Execute the SQL request
$totalnbofrecord = 0 ;
$data = array ();
if ( $sql ) {
$resql = $db -> query ( $sql );
2020-02-13 10:44:08 +01:00
if ( ! $resql ) {
2020-02-07 10:58:17 +01:00
dol_print_error ( $db );
}
2020-02-13 10:44:08 +01:00
while ( $obj = $db -> fetch_object ( $resql )) {
2020-02-07 10:58:17 +01:00
// $this->data = array(array(0=>'labelxA',1=>yA1,...,n=>yAn), array('labelxB',yB1,...yBn)); // or when there is n series to show for each x
2020-02-13 10:44:08 +01:00
foreach ( $search_xaxis as $xkey => $xval ) {
2020-02-07 10:58:17 +01:00
$fieldforxkey = 'x_' . $xkey ;
$xlabel = $obj -> $fieldforxkey ;
$xvalwithoutprefix = preg_replace ( '/^[a-z]+\./' , '' , $xval );
2020-02-13 10:44:08 +01:00
if ( ! empty ( $object -> fields [ $xvalwithoutprefix ][ 'arrayofkeyval' ])) {
2020-02-07 10:58:17 +01:00
$xlabel = $object -> fields [ $xvalwithoutprefix ][ 'arrayofkeyval' ][ $obj -> $fieldforxkey ];
}
$xarray = array ( 0 => (( $xlabel || $xlabel == '0' ) ? dol_trunc ( $xlabel , 20 , 'middle' ) : $langs -> trans ( " NotDefined " )));
2020-02-13 10:44:08 +01:00
foreach ( $search_measures as $key => $val ) {
2020-02-07 10:58:17 +01:00
$fieldfory = 'y_' . $key ;
$xarray [] = $obj -> $fieldfory ;
}
$data [] = $xarray ;
}
}
$totalnbofrecord = count ( $data );
}
2020-02-13 10:44:08 +01:00
print '<div class="customreportsoutput' . ( $totalnbofrecord ? '' : ' customreportsoutputnotdata' ) . '">' ;
2020-02-07 10:58:17 +01:00
if ( $mode == 'grid' ) {
2020-02-07 12:51:08 +01:00
// TODO
2020-02-07 10:58:17 +01:00
}
if ( $mode == 'graph' ) {
$WIDTH = '80%' ;
$HEIGHT = 200 ;
// Show graph
$px1 = new DolGraph ();
$mesg = $px1 -> isGraphKo ();
2020-02-13 10:44:08 +01:00
if ( ! $mesg )
2020-02-07 10:58:17 +01:00
{
$px1 -> SetData ( $data );
unset ( $data );
$arrayoftypes = array ();
2020-02-13 10:44:08 +01:00
foreach ( $search_measures as $key => $val ) {
2020-02-07 10:58:17 +01:00
$arrayoftypes [] = $search_graph ;
}
$px1 -> SetLegend ( $legend );
$px1 -> SetMinValue ( $px1 -> GetFloorMinValue ());
$px1 -> SetMaxValue ( $px1 -> GetCeilMaxValue ());
$px1 -> SetWidth ( $WIDTH );
$px1 -> SetHeight ( $HEIGHT );
$px1 -> SetYLabel ( $langs -> trans ( " Y " ));
$px1 -> SetShading ( 3 );
$px1 -> SetHorizTickIncrement ( 1 );
$px1 -> SetCssPrefix ( " cssboxes " );
$px1 -> SetType ( $arrayoftypes );
2020-02-13 10:44:08 +01:00
$px1 -> mode = 'depth' ;
2020-02-07 10:58:17 +01:00
$px1 -> SetTitle ( '' );
2020-02-13 10:44:08 +01:00
$dir = $conf -> user -> dir_temp ;
2020-02-07 10:58:17 +01:00
dol_mkdir ( $dir );
$filenamenb = $dir . '/customreport_' . $object -> element . '.png' ;
$fileurlnb = DOL_URL_ROOT . '/viewimage.php?modulepart=user&file=customreport_' . $object -> element . '.png' ;
$px1 -> draw ( $filenamenb , $fileurlnb );
print $px1 -> show ( $totalnbofrecord ? 0 : $langs -> trans ( " SelectYourGraphOptionsFirst " ));
}
}
if ( $sql ) {
// Show admin info
2020-02-11 10:38:09 +01:00
print '<br>' . info_admin ( $langs -> trans ( " SQLUsedForExport " ) . ':<br> ' . $sql , 0 , 0 , 1 , '' , 'TechnicalInformation' );
2020-02-07 10:58:17 +01:00
}
print '<div>' ;
2020-02-13 10:44:08 +01:00
if ( ! defined ( 'USE_CUSTOME_REPORT_AS_INCLUDE' )) {
2020-02-11 10:38:09 +01:00
dol_fiche_end ();
}
2020-02-07 10:58:17 +01:00
// End of page
llxFooter ();
$db -> close ();