1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/noalyss_ynh.git synced 2024-09-03 19:46:20 +02:00
noalyss_ynh/sources/include/class_anc_account.php
2015-09-27 00:54:25 +02:00

349 lines
9.8 KiB
PHP

<?php
/*
* This file is part of NOALYSS.
*
* NOALYSS 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.
*
* NOALYSS 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 NOALYSS; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
// Copyright Author Dany De Bontridder danydb@aevalys.eu
/*!\file
*\brief contains the object for the poste_analytique (table poste_analytique)
*/
/*!\brief contains the object for the poste_analytique (table poste_analytique)
*
*/
require_once NOALYSS_INCLUDE.'/class_ihidden.php';
require_once NOALYSS_INCLUDE.'/class_itext.php';
require_once NOALYSS_INCLUDE.'/class_iselect.php';
require_once NOALYSS_INCLUDE.'/class_ispan.php';
require_once NOALYSS_INCLUDE.'/class_database.php';
require_once NOALYSS_INCLUDE.'/class_anc_plan.php';
class Anc_Account
{
var $id; /*!< $id is po_id */
var $name; /*!< po_name */
var $pa_id; /*!< pa_id fk to the plan_analytique(pa_id) */
var $amount; /*!< po_amount just an amount */
var $description; /*!< po_description description of the post */
var $db; /*!< database connection*/
var $ga_id; /*!< FK to the table groupe analytique */
function Anc_Account($p_db,$p_id=0)
{
$this->db=$p_db;
$this->id=$p_id;
$this->ga_id=null;
}
/*! \brief retrieve data from the database and
* fill the object
* \param $p_where the where clause
*/
private function fetch_from_db($p_where)
{
$sql="select po_id,
po_name ,
pa_id,
po_amount,
po_description,
ga_id
from poste_analytique
where ".
$p_where;
$ret=$this->db->exec_sql($sql);
if ( Database::num_row($ret) == 0 )return null;
$line=Database::fetch_array($ret);
$this->id=$line['po_id'];
$this->name=$line['po_name'];
$this->pa_id=$line['pa_id'];
$this->amount=$line['po_amount'];
$this->description=$line['po_description'];
$this->ga_id=$line['ga_id'];
}
function get_by_id()
{
$this->fetch_from_db("po_id=".$this->id);
}
/*!
* \brief retrieve data thanks the name
* \param $p_name name of the analytic account
*
*/
function get_by_name($p_name)
{
$p_name=sql_string($p_name);
if ( $p_name == null )
$p_name=$this->name;
$this->fetch_from_db("po_name='".$p_name."'");
echo "id = ".$this->id;
}
function add()
{
$this->format_data();
if ( strlen($this->name) == 0)
return;
if ( $this->ga_id == null || strlen(trim($this->ga_id)) == 0 )
$ga_id=NULL;
else
$ga_id=$this->ga_id;
$sql="insert into poste_analytique (
po_name ,
pa_id,
po_amount,
po_description,
ga_id
) values ($1,$2,$3,$4,$5)";
try
{
$this->db->exec_sql($sql,array($this->name,$this->pa_id,$this->amount,$this->description,$ga_id));
}
catch (Exception $e)
{
if ( DEBUG ) print_r($e);
echo "<p class=\"notice\">Doublon : l'enregistrement n'est pas sauve</p>";
}
}
static function make_array_name($cn,$pa_id)
{
$a=$cn->make_array("select po_name,po_name from poste_analytique ".
" where ".
" pa_id = $1 order by po_name ",0,array($pa_id));
return $a;
}
function update()
{
$this->format_data();
if ( strlen($this->name) == 0)
return;
$sql="update poste_analytique ".
" set po_name=$1".
" ,pa_id=$2".
" ,po_amount=$3".
" ,po_description=$4".
" ,ga_id=$5".
" where po_id=$6";
try
{
$this->db->exec_sql($sql,array($this->name,$this->pa_id,$this->amount,
$this->description,$this->ga_id,$this->id));
}
catch (Exception $e)
{
echo "<p class=\"notice\">Doublon : l'enregistrement n'est pas sauve</p>";
}
}
private function format_data()
{
$this->name=$this->name;
$this->pa_id=$this->pa_id;
$this->amount=$this->amount;
if (strlen($this->amount) == 0 )
$this->amount=0.0;
if ( isNumber($this->amount) ==0 )
$this->amount=0;
$this->description=$this->description;
}
function delete()
{
$sql="delete from poste_analytique where po_id=".$this->id;
$this->db->exec_sql($sql);
}
/*!
* \brief return an array of object Poste_Analytique
*
*/
function get_list()
{
$sql="select po_id,
po_name ,
pa_id,
po_amount,
po_description,
ga_id
from poste_analytique ".
" order by po_name";
$ex=$this->db->exec_sql($sql);
$ret=Database::fetch_all($ex);
if ( $ret == null )
return null;
$array=array();
foreach ($ret as $line)
{
$object=new Anc_Account($this->db);
$object->id=$line['po_id'];
$object->name=$line['po_name'];
$object->pa_id=$line['pa_id'];
$object->amount=$line['po_amount'];
$object->description=$line['po_description'];
$object->ga_id=$line['ga_id'];
$array[]=clone $object;
}
return $array;
}
function display_list()
{
$array=$this->get_list();
if ( empty($array) )
{
echo "Vide";
return;
}
foreach ($array as $line)
{
echo $line->id." / ".$line->name." / ".$line->description."/".
$line->amount." / ".$line->pa_id."/".$line->ga_id."<br>";
}
}
function debug()
{
echo "id ".$this->id."<br>";
echo "name ".$this->name."<br>";
echo "pa_id ".$this->pa_id."<br>";
echo "amount ".$this->amount."<br>";
echo "description ".$this->description."<br>";
echo "ga_id ".$this->ga_id."<br>";
}
function form()
{
$r='';
$wName=new IText("po_name",$this->name);
$wAmount=new INum("po_amount",$this->amount);
$wDescription=new IText("po_description",$this->description);
$aGroup_analytic=$this->db->make_array("select ga_id,ga_id from groupe_analytique where pa_id=".$this->pa_id,1);
if ( count($aGroup_analytic) > 1 )
{
$wGa_id=new ISelect("ga_id");
$wGa_id->value=$aGroup_analytic;
$wGa_id->selected=$this->ga_id;
$wGa_id->table=1;
}
else
{
$wGa_id=new ISpan();
}
$pa=new Anc_Plan($this->db,$this->pa_id);
$pa->get();
$wPaName=new IText("",$pa->name);
$wPaName->table=1;
$wPaName->readOnly=true;
$wName->table=1;
$wAmount->table=1;
$wDescription->table=1;
$r.=HtmlInput::hidden("pa_id",$this->pa_id);
$r.=HtmlInput::hidden("po_id",$this->id);
$r.="<table>";
$r.="<tr>";
$r.=td(_('Nom'));
$r.=$wName->input();
$r.="</tr>";
$r.="<tr>";
$r.=td(_('Montant'));
$r.=$wAmount->input();
$r.="</tr>";
$r.="<tr>";
$r.=td(_('Description'));
$r.=$wDescription->input();
$r.="</tr>";
$r.="<tr>";
$r.=td(_('Plan Analytique'));
$r.=$wPaName->input();
$r.="</tr>";
$r.="<tr>";
$r.=td(_('Groupe'));
$r.=$wGa_id->input();
$r.="</tr>";
$r.="</table>";
return $r;
}
function get_from_array($p_array)
{
$this->name=(isset ($p_array['po_name']))?$p_array['po_name']:"";
$this->description=(isset ($p_array['po_description']))?$p_array['po_description']:"";
$this->pa_id=(isset ($p_array['pa_id']))?$p_array['pa_id']:"";
$this->amount=(isset ($p_array['po_amount']))?$p_array['po_amount']:0;
$this->id=(isset ($p_array['po_id']))?$p_array['po_id']:-1;
// $this->ga_id=(isset($p_array['ga_id']) && $p_array['ga_id'] == "-1" )?null:2;
$this->ga_id=(isset($p_array['ga_id']) && $p_array['ga_id'] != "-1" )?$p_array['ga_id']:null;
}
static function test_me()
{
$cn=new Database(dossier::id());
$pa_id=$cn->get_value("select max(pa_id) from plan_analytique");
$o=new Anc_Account($cn);
echo "<h1>Poste_Analytique</h1>";
echo "<h2>get_list</h2>";
$ee=$o->get_list();
print_r($ee);
//var_dump($ee);
echo "<h2>Add some </h2>";
$o->pa_id=$pa_id;
$o->name="test1";
$o->add();
$o->name="test2";
$o->add();
$o->name="test3";
$o->add();
$o->name="test4";
$o->add();
$o->name="test5";
$o->add();
echo "<h2> remove test1</h2>";
$o->get_by_name("test1");
$o->delete();
$o->display_list();
$o->get_by_name("test4");
echo "<hr>".$o->id."<hr>";
$o->name="Test Four";
$o->update();
$o->display_list();
$o->delete();
$o->display_list();
}
}
?>