mirror of
https://github.com/YunoHost-Apps/noalyss_ynh.git
synced 2024-09-03 19:46:20 +02:00
424 lines
14 KiB
PHP
424 lines
14 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 Handle the table mod_payment
|
||
|
*/
|
||
|
require_once NOALYSS_INCLUDE.'/lib/iselect.class.php';
|
||
|
require_once NOALYSS_INCLUDE.'/lib/icard.class.php';
|
||
|
require_once NOALYSS_INCLUDE.'/lib/ispan.class.php';
|
||
|
require_once NOALYSS_INCLUDE.'/class/acc_ledger.class.php';
|
||
|
require_once NOALYSS_INCLUDE.'/class/fiche.class.php';
|
||
|
require_once NOALYSS_INCLUDE.'/class/fiche_def.class.php';
|
||
|
require_once NOALYSS_INCLUDE.'/constant.php';
|
||
|
require_once NOALYSS_INCLUDE.'/lib/http_input.class.php';
|
||
|
|
||
|
/*!\brief Handle the table mod_payment
|
||
|
*\note the private data member are accessed via
|
||
|
- mp_id ==> id ( Primary key )
|
||
|
- mp_lib ==> lib (label)
|
||
|
- mp_jrn_def_id ==> ledger (Number of the ledger where to save)
|
||
|
- mp_fd_id ==> fiche_def (fiche class to use)
|
||
|
- mp_qcode ==> qcode (quick_code of the card)
|
||
|
*
|
||
|
*/
|
||
|
class Acc_Payment
|
||
|
{
|
||
|
|
||
|
private static $variable=array("id"=>"mp_id",
|
||
|
"lib"=>"mp_lib",
|
||
|
"qcode"=>"mp_qcode",
|
||
|
"ledger_target"=>"mp_jrn_def_id",
|
||
|
"ledger_source"=>"jrn_def_id",
|
||
|
"fiche_def"=>"mp_fd_id");
|
||
|
|
||
|
|
||
|
private $mp_lib;
|
||
|
private $mp_qcode;
|
||
|
private $mp_jrn_def_if;
|
||
|
private $jrn_def_id;
|
||
|
private $mp_fd_id;
|
||
|
|
||
|
function __construct ($p_cn,$p_init=0)
|
||
|
{
|
||
|
$this->cn=$p_cn;
|
||
|
$this->mp_id=$p_init;
|
||
|
}
|
||
|
public function get_parameter($p_string)
|
||
|
{
|
||
|
if ( array_key_exists($p_string,self::$variable) )
|
||
|
{
|
||
|
$idx=self::$variable[$p_string];
|
||
|
return $this->$idx;
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
throw new Exception("Attribut inexistant $p_string");
|
||
|
}
|
||
|
}
|
||
|
public function set_parameter($p_string,$p_value)
|
||
|
{
|
||
|
if ( array_key_exists($p_string,self::$variable) )
|
||
|
{
|
||
|
$idx=self::$variable[$p_string];
|
||
|
$this->$idx=$p_value;
|
||
|
}
|
||
|
else
|
||
|
throw new Exception("Attribut inexistant $p_string");
|
||
|
|
||
|
|
||
|
}
|
||
|
public function get_info()
|
||
|
{
|
||
|
return var_export(self::$variable,true);
|
||
|
}
|
||
|
public function verify()
|
||
|
{
|
||
|
// Verify that the elt we want to add is correct
|
||
|
}
|
||
|
public function save()
|
||
|
{
|
||
|
/* please adapt */
|
||
|
if ( $this->get_parameter("id") == 0 )
|
||
|
$this->insert();
|
||
|
else
|
||
|
$this->update();
|
||
|
}
|
||
|
|
||
|
public function insert()
|
||
|
{
|
||
|
if ( $this->verify() != 0 ) return;
|
||
|
$sql='INSERT INTO mod_payment(
|
||
|
mp_lib, mp_jrn_def_id, mp_fd_id, mp_qcode,jrn_def_id)
|
||
|
VALUES ($1, $2, $3, upper($4),$5) returning mp_id';
|
||
|
$this->mp_id=$this->cn->exec_sql($sql,array(
|
||
|
$this->mp_lib,
|
||
|
$this->mp_jrn_def_id,
|
||
|
$this->mp_fd_id,
|
||
|
$this->mp_qcode,
|
||
|
$this->jrn_def_id));
|
||
|
}
|
||
|
|
||
|
public function update()
|
||
|
{
|
||
|
if ( $this->verify() != 0 ) return;
|
||
|
|
||
|
$sql="update mod_payment set mp_lib=$1,mp_qcode=$2,mp_jrn_def_id=$3,mp_fd_id=$4,jrn_def_id=$5 ".
|
||
|
" where mp_id = $6";
|
||
|
$res=$this->cn->exec_sql(
|
||
|
$sql,
|
||
|
array($this->mp_lib,
|
||
|
$this->mp_qcode,
|
||
|
$this->mp_jrn_def_id,
|
||
|
$this->mp_fd_id,
|
||
|
$this->jrn_def_id,
|
||
|
$this->mp_id)
|
||
|
);
|
||
|
if ( strlen (trim($this->mp_jrn_def_id))==0)
|
||
|
$this->cn->exec_sql(
|
||
|
'update mod_payment '.
|
||
|
'set mp_jrn_def_id = null where mp_id=$1',
|
||
|
array($this->mp_id));
|
||
|
if ( strlen (trim($this->jrn_def_id))==0)
|
||
|
$this->cn->exec_sql(
|
||
|
'update mod_payment '.
|
||
|
'set mp_jrn_def_id = null where mp_id=$1',
|
||
|
array($this->mp_id));
|
||
|
if ( strlen (trim($this->mp_qcode))==0)
|
||
|
$this->cn->exec_sql(
|
||
|
'update mod_payment '.
|
||
|
'set mp_qcode = null where mp_id=$1',
|
||
|
array($this->mp_id));
|
||
|
if ( strlen (trim($this->mp_fd_id))==0)
|
||
|
$this->cn->exec_sql(
|
||
|
'update mod_payment '.
|
||
|
'set mp_fd_id = null where mp_id=$1',
|
||
|
array($this->mp_id));
|
||
|
|
||
|
}
|
||
|
|
||
|
public function load()
|
||
|
{
|
||
|
$sql='select mp_id,mp_lib,mp_fd_id,mp_jrn_def_id,mp_qcode,jrn_def_id from mod_payment '.
|
||
|
' where mp_id = $1';
|
||
|
$res=$this->cn->exec_sql(
|
||
|
$sql,
|
||
|
array($this->mp_id)
|
||
|
);
|
||
|
|
||
|
if ( Database::num_row($res) == 0 ) return;
|
||
|
$row=Database::fetch_array($res,0);
|
||
|
foreach ($row as $idx=>$value)
|
||
|
{
|
||
|
$this->$idx=$value;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
/**
|
||
|
*@brief remove a middle of payment
|
||
|
*/
|
||
|
public function delete()
|
||
|
{
|
||
|
$sql="delete from mod_payment where mp_id=$1";
|
||
|
$this->cn->exec_sql($sql,array($this->mp_id));
|
||
|
}
|
||
|
/*!\brief retrieve all the data for all ledgers
|
||
|
*\param non
|
||
|
*\return an array of row
|
||
|
*/
|
||
|
public function get_all()
|
||
|
{
|
||
|
$sql='select mp_id,mp_lib '.
|
||
|
' from mod_payment order by mp_lib';
|
||
|
$array=$this->cn->get_array($sql);
|
||
|
$ret=array();
|
||
|
if ( !empty($array) )
|
||
|
{
|
||
|
foreach ($array as $row)
|
||
|
{
|
||
|
$t=new Acc_Payment($this->cn,$row['mp_id']);
|
||
|
$t->load();
|
||
|
$ret[]=$t;
|
||
|
}
|
||
|
}
|
||
|
return $ret;
|
||
|
}
|
||
|
/*!\brief retrieve all the data for a ledger but filter on the
|
||
|
*valid record (jrn and fd not null
|
||
|
*\param non
|
||
|
*\return an array of row
|
||
|
*/
|
||
|
public function get_valide()
|
||
|
{
|
||
|
$sql='select mp_id '.
|
||
|
' from mod_payment '.
|
||
|
' where jrn_def_id=$1 and mp_jrn_def_id is not null and '.
|
||
|
' (mp_fd_id is not null or mp_qcode is not null)';
|
||
|
$array=$this->cn->get_array($sql,array($this->jrn_def_id));
|
||
|
$ret=array();
|
||
|
if ( !empty($array) )
|
||
|
{
|
||
|
foreach ($array as $row)
|
||
|
{
|
||
|
$t=new Acc_Payment($this->cn,$row['mp_id']);
|
||
|
$t->load();
|
||
|
$ret[]=$t;
|
||
|
}
|
||
|
}
|
||
|
return $ret;
|
||
|
}
|
||
|
/*!\brief return a string with a form (into a table)
|
||
|
*\param none
|
||
|
*\return a html string
|
||
|
*/
|
||
|
public function form()
|
||
|
{
|
||
|
//label
|
||
|
$lib=new IText('mp_lib');
|
||
|
$lib->value=$this->mp_lib;
|
||
|
$f_lib=$lib->input();
|
||
|
|
||
|
|
||
|
$ledger_source=new ISelect('jrn_def_id');
|
||
|
$ledger_source->value=$this->cn->make_array("select jrn_def_id,jrn_Def_name from
|
||
|
jrn_def where jrn_def_type in ('ACH','VEN') order by jrn_def_name");
|
||
|
$ledger_source->selected=$this->jrn_def_id;
|
||
|
$f_source=$ledger_source->input();
|
||
|
|
||
|
// type of card
|
||
|
$tcard=new ISelect('mp_fd_id');
|
||
|
$tcard->value=$this->cn->make_array('select fd_id,fd_label from fiche_def join fiche_def_ref '.
|
||
|
' using (frd_id) where frd_id in (25,4) order by fd_label');
|
||
|
$tcard->selected=$this->mp_fd_id;
|
||
|
|
||
|
$f_type_fiche=$tcard->input();
|
||
|
$ledger_record=new ISelect('mp_jrn_def_id');
|
||
|
$ledger_record->value=$this->cn->make_array("select jrn_def_id,jrn_Def_name from
|
||
|
jrn_def where jrn_def_type in ('ODS','FIN')");
|
||
|
$ledger_record->selected=$this->mp_jrn_def_id;
|
||
|
$f_ledger_record=$ledger_record->input();
|
||
|
|
||
|
// the card
|
||
|
$qcode=new ICard();
|
||
|
$qcode->noadd=true;
|
||
|
$qcode->name='mp_qcode';
|
||
|
$list=$this->cn->make_list('select fd_id from fiche_def where frd_id in (25,4)');
|
||
|
$qcode->typecard=$list;
|
||
|
$qcode->dblclick='fill_ipopcard(this);';
|
||
|
$qcode->value=$this->mp_qcode;
|
||
|
|
||
|
$f_qcode=$qcode->input();
|
||
|
|
||
|
$msg="Modification de ".$this->mp_lib;
|
||
|
ob_start();
|
||
|
require_once NOALYSS_TEMPLATE.'/new_mod_payment.php';
|
||
|
$r=ob_get_contents();
|
||
|
ob_end_clean();
|
||
|
return $r;
|
||
|
|
||
|
}
|
||
|
/*!\brief show several lines with radio button to select the payment
|
||
|
*method we want to use, the $_POST['e_mp'] will be set
|
||
|
* \todo this class is used only for storage of the defined payment method, not the payment itself,
|
||
|
* it must be moved to another class 'Operation_Payment'
|
||
|
*\param $p_selected if the id choose
|
||
|
*\param $p_date date of payment
|
||
|
*\param $p_amount amount already paid
|
||
|
*\param $p_comm label of payment
|
||
|
*\return html string
|
||
|
*/
|
||
|
public function select($p_select,$p_amount,$p_date,$p_comm)
|
||
|
{
|
||
|
$r='';
|
||
|
$array=$this->get_valide();
|
||
|
$r.=HtmlInput::hidden('gDossier',dossier::id());
|
||
|
|
||
|
if ( empty($array)==false ) {
|
||
|
$date_pay=new IDate('mp_date');
|
||
|
$date_pay->value=$p_date;
|
||
|
$r.=sprintf(_("Date %s"),
|
||
|
$date_pay->input());
|
||
|
$acompte=new INum('acompte');
|
||
|
$acompte->value=$p_amount;
|
||
|
$r.=_(" Acompte à déduire");
|
||
|
$r.=$acompte->input();
|
||
|
$r.='<p>';
|
||
|
$e_comm_paiement=new IText('e_comm_paiement');
|
||
|
$e_comm_paiement->value=$p_comm;
|
||
|
$e_comm_paiement->table = 0;
|
||
|
$e_comm_paiement->setReadOnly(false);
|
||
|
$e_comm_paiement->size = 60;
|
||
|
$e_comm_paiement->tabindex = 3;
|
||
|
$r.=_(" Libellé du paiement");
|
||
|
$r.=$e_comm_paiement->input();
|
||
|
$r.='</p>';
|
||
|
}
|
||
|
|
||
|
$r.='<ol>';
|
||
|
$r.='<li ><input type="radio" name="e_mp" value="0" checked>'._('Paiement encodé plus tard');
|
||
|
$http=new HttpInput();
|
||
|
if ( empty($array ) == false )
|
||
|
{
|
||
|
foreach ($array as $row)
|
||
|
{
|
||
|
$f='';
|
||
|
/* if the qcode is null the propose a search button to select
|
||
|
the card */
|
||
|
if ( $row->mp_qcode==NULL)
|
||
|
{
|
||
|
$a=new ICard();
|
||
|
$a->jrn=$row->mp_jrn_def_id;
|
||
|
$a->set_attribute('typecard',$row->mp_fd_id);
|
||
|
$a->name='e_mp_qcode_'.$row->mp_id;
|
||
|
$a->set_dblclick("fill_ipopcard(this);");
|
||
|
$a->set_callback('filter_card');
|
||
|
$a->set_function('fill_data');
|
||
|
$a->set_attribute('ipopup','ipopcard');
|
||
|
$a->set_attribute('label',$a->name.'_label');
|
||
|
if ( $p_select == $row->mp_id ) {
|
||
|
$a->value=$http->request("e_mp_qcode_".$p_select, "string","");
|
||
|
}
|
||
|
$s=new ISpan();
|
||
|
$s->name=$a->name.'_label';
|
||
|
$f=_(" paiement par ").$a->input().$s->input();
|
||
|
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
/* if the qcode is not null then add a hidden variable with
|
||
|
the qcode */
|
||
|
|
||
|
$fiche=new Fiche($this->cn);
|
||
|
$fiche->get_by_qcode($row->mp_qcode);
|
||
|
$f=HtmlInput::hidden('e_mp_qcode_'.$row->mp_id,$row->mp_qcode);
|
||
|
|
||
|
// $f.=$fiche->strAttribut(ATTR_DEF_NAME);
|
||
|
}
|
||
|
$check=( $p_select == $row->mp_id)?" checked " : "unchecked";
|
||
|
$r.='<li><input type="radio" name="e_mp" value="'.$row->mp_id.'" '.$check.'>';
|
||
|
$r.=$row->mp_lib.' '.$f;
|
||
|
|
||
|
}
|
||
|
}
|
||
|
$r.='</ol>';
|
||
|
return $r;
|
||
|
}
|
||
|
|
||
|
/*!\brief convert an array into an Acc_Payment object
|
||
|
*\param array to convert
|
||
|
*/
|
||
|
public function from_array($p_array)
|
||
|
{
|
||
|
$idx=array('mp_id','mp_lib','mp_fd_id','mp_jrn_def_id','mp_qcode','jrn_def_id');
|
||
|
foreach ($idx as $l)
|
||
|
if (isset($p_array[$l])) $this->$l=$p_array[$l];
|
||
|
}
|
||
|
/**
|
||
|
*@brief return an html with a form to add a new middle of payment
|
||
|
*/
|
||
|
public function blank()
|
||
|
{
|
||
|
//label
|
||
|
$lib=new IText('mp_lib');
|
||
|
$f_lib=$lib->input();
|
||
|
|
||
|
$ledger_source=new ISelect('jrn_def_id');
|
||
|
$ledger_source->value=$this->cn->make_array("select jrn_def_id,jrn_Def_name from
|
||
|
jrn_def where jrn_def_type in ('ACH','VEN') order by jrn_def_name");
|
||
|
$f_source=$ledger_source->input();
|
||
|
|
||
|
// type of card
|
||
|
$tcard=new ISelect('mp_fd_id');
|
||
|
$tcard->value=$this->cn->make_array('select fd_id,fd_label from fiche_def join fiche_def_ref '.
|
||
|
' using (frd_id) where frd_id in (25,4) order by fd_label');
|
||
|
$f_type_fiche=$tcard->input();
|
||
|
$ledger_record=new ISelect('mp_jrn_def_id');
|
||
|
$ledger_record->value=$this->cn->make_array("select jrn_def_id,jrn_Def_name from
|
||
|
jrn_def where jrn_def_type in ('ODS','FIN')");
|
||
|
$f_ledger_record=$ledger_record->input();
|
||
|
|
||
|
// the card
|
||
|
$qcode=new ICard();
|
||
|
$qcode->noadd=true;
|
||
|
$qcode->name='mp_qcode';
|
||
|
$list=$this->cn->make_list('select fd_id from fiche_def where frd_id in (25,4)');
|
||
|
$qcode->typecard=$list;
|
||
|
$qcode->dblclick='fill_ipopcard(this);';
|
||
|
|
||
|
$f_qcode=$qcode->input();
|
||
|
$msg="Ajout d'un nouveau moyen de paiement";
|
||
|
ob_start();
|
||
|
require_once NOALYSS_TEMPLATE.'/new_mod_payment.php';
|
||
|
$r=ob_get_contents();
|
||
|
ob_end_clean();
|
||
|
return $r;
|
||
|
}
|
||
|
/*!\brief test function
|
||
|
*/
|
||
|
static function test_me()
|
||
|
{
|
||
|
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
|