From 82363addbb055beda5c13aaaccd8b472a131d6a0 Mon Sep 17 00:00:00 2001 From: Rodolphe Quiedeville Date: Tue, 15 Mar 2005 12:43:17 +0000 Subject: [PATCH] Nouveau fichier --- .../stats/ProcessGraphClients.class.php | 155 ++++++++++++++++++ 1 file changed, 155 insertions(+) create mode 100644 htdocs/telephonie/stats/ProcessGraphClients.class.php diff --git a/htdocs/telephonie/stats/ProcessGraphClients.class.php b/htdocs/telephonie/stats/ProcessGraphClients.class.php new file mode 100644 index 00000000000..8aef2d416f1 --- /dev/null +++ b/htdocs/telephonie/stats/ProcessGraphClients.class.php @@ -0,0 +1,155 @@ + + * + * 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 2 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, write to the Free Software + * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. + * + * $Id$ + * $Source$ + * + * + * Generation des graphiques clients + * + * + */ +require ("../../master.inc.php"); + +require_once (DOL_DOCUMENT_ROOT."/telephonie/lignetel.class.php"); +require_once (DOL_DOCUMENT_ROOT."/telephonie/facturetel.class.php"); +require_once (DOL_DOCUMENT_ROOT."/telephonie/telephonie-tarif.class.php"); +require_once (DOL_DOCUMENT_ROOT."/telephonie/communication.class.php"); + +require_once (DOL_DOCUMENT_ROOT."/telephonie/stats/graph/ca.class.php"); +require_once (DOL_DOCUMENT_ROOT."/telephonie/stats/graph/gain.class.php"); +require_once (DOL_DOCUMENT_ROOT."/telephonie/stats/graph/heureappel.class.php"); +require_once (DOL_DOCUMENT_ROOT."/telephonie/stats/graph/joursemaine.class.php"); +require_once (DOL_DOCUMENT_ROOT."/telephonie/stats/graph/camoyen.class.php"); +require_once (DOL_DOCUMENT_ROOT."/telephonie/stats/graph/appelsdureemoyenne.class.php"); +require_once (DOL_DOCUMENT_ROOT."/telephonie/stats/graph/comm.nbmensuel.class.php"); + +require_once (DOL_DOCUMENT_ROOT."/telephonie/stats/graph/camenbert.class.php"); + +/* + * Process + * + */ + +class ProcessGraphClients +{ + var $ident; + + function ProcessGraphClients( $ident , $cpc) + { + $this->ident = $ident; + $this->cpc = $cpc; + $this->db = new DoliDb('','','','','',1); + } + + function go() + { + dolibarr_syslog("Debut client ".$this->ident); + $error = 0; + + $img_root = DOL_DATA_ROOT."/graph/telephonie/"; + + $min = $this->ident * $this->cpc; + $max = ($this->ident + 1 ) * $this->cpc; + + /* + * Lecture des clients + * + */ + $sql = "SELECT s.idp as socidp, s.nom, count(l.ligne) as ligne"; + $sql .= " FROM ".MAIN_DB_PREFIX."societe as s"; + $sql .= ",".MAIN_DB_PREFIX."telephonie_societe_ligne as l"; + $sql .= " WHERE l.fk_client_comm = s.idp "; + $sql .= " AND s.idp >= ".$min; + $sql .= " AND s.idp < ".$max; + $sql .= " GROUP BY s.idp"; + + if ($this->db->query($sql)) + { + $clients = array(); + + $num = $this->db->num_rows(); + print "$this->ident : $num client a traiter ($min - $max)\n"; + $i = 0; + + while ($i < $num) + { + $obj = $this->db->fetch_object(); + + $dir = $img_root . "client/".substr($obj->socidp,0,1)."/".$obj->socidp."/"; + + $clients[$i] = $obj->socidp; + + $i++; + } + } + + if (sizeof($clients)) + { + foreach ($clients as $client) + { + //print "."; + + $img_root = DOL_DATA_ROOT."/graph/".substr($client,-1)."/telephonie/client/"; + + $file = $img_root . $client."/graphca.png"; + $graphca = new GraphCa($this->db, $file); + $graphca->client = $client; + $graphca->GraphDraw(); + + $file = $img_root . $client."/graphgain.png"; + + $graphgain = new GraphGain ($this->db, $file); + $graphgain->client = $client; + $graphgain->show_console = 0 ; + $graphgain->GraphDraw(); + + if ($graphgain->total_cout > 0) + { + $marge = ( $graphgain->total_gain / $graphgain->total_cout * 100); + } + + $sql = "INSERT INTO ".MAIN_DB_PREFIX."telephonie_client_stats (fk_client_comm, gain, ca, cout, marge)"; + $sql .= " VALUES (".$client.",'".ereg_replace(",",".",$graphgain->total_gain)."'"; + $sql .= ",'".ereg_replace(",",".",$graphgain->total_ca)."'"; + $sql .= ",'".ereg_replace(",",".",$graphgain->total_cout)."'"; + $sql .= ",'".ereg_replace(",",".",$marge)."')"; + $this->db->query($sql); + + + $file = $img_root . $client."/graphappelsdureemoyenne.png"; + + $graphgain = new GraphAppelsDureeMoyenne ($this->db, $file); + $graphgain->client = $client; + $graphgain->show_console = 0 ; + $graphgain->GraphDraw(); + + $file = $img_root . $client."/nb-comm-mensuel.png"; + + $graphx = new GraphCommNbMensuel ($this->db, $file); + $graphx->client = $client; + $graphx->show_console = 0 ; + $graphx->Graph(); + + } + } + + dolibarr_syslog("Fin client ".$this->ident); + + } +} +?>