mirror of
https://github.com/YunoHost-Apps/noalyss_ynh.git
synced 2024-09-03 19:46:20 +02:00
341 lines
11 KiB
PHP
341 lines
11 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 file included to manage all the sold operation
|
|
*/
|
|
if ( ! defined ('ALLOWED') ) die('Appel direct ne sont pas permis');
|
|
require_once NOALYSS_INCLUDE.'/class_icheckbox.php';
|
|
require_once NOALYSS_INCLUDE.'/class_acc_ledger_sold.php';
|
|
require_once NOALYSS_INCLUDE.'/class_pre_op_ven.php';
|
|
require_once NOALYSS_INCLUDE.'/class_document.php';
|
|
require_once NOALYSS_INCLUDE.'/class_acc_ledger_info.php';
|
|
require_once NOALYSS_INCLUDE.'/class_ipopup.php';
|
|
|
|
$gDossier=dossier::id();
|
|
$cn=new Database(dossier::id());
|
|
//menu = show a list of ledger
|
|
$str_dossier=dossier::get();
|
|
$ac="ac=".$_REQUEST['ac'];
|
|
global $g_parameter;
|
|
$p_msg="";
|
|
//----------------------------------------------------------------------
|
|
// Encode a new invoice
|
|
// empty form for encoding
|
|
//----------------------------------------------------------------------
|
|
|
|
$Ledger=new Acc_Ledger_Sold($cn,0);
|
|
|
|
// Check privilege
|
|
if ( isset($_REQUEST['p_jrn']) &&
|
|
$g_user->check_jrn($_REQUEST['p_jrn']) != 'W' )
|
|
{
|
|
|
|
NoAccess();
|
|
exit -1;
|
|
}
|
|
|
|
/* if a new invoice is encoded, we display a form for confirmation */
|
|
if ( isset ($_POST['view_invoice'] ) )
|
|
{
|
|
$Ledger=new Acc_Ledger_Sold($cn,$_POST['p_jrn']);
|
|
try
|
|
{
|
|
$Ledger->verify($_POST);
|
|
}
|
|
catch (Exception $e)
|
|
{
|
|
alert($e->getMessage());
|
|
$p_msg=$e->getMessage();
|
|
$correct=1;
|
|
}
|
|
// if correct is not set it means it is correct
|
|
if ( ! isset($correct))
|
|
{
|
|
echo '<div class="content">';
|
|
|
|
echo '<div id="confirm_div_id" style="width: 47%; float: left;">';
|
|
echo h1(_("Confirmation"));
|
|
echo '</div>';
|
|
|
|
echo '<div id="warning_ven_id" class="notice" style="width: 50%; margin-left: 0px; float: right;">';
|
|
echo h2(_("Attention, cette opération n'est pas encore sauvée : vous devez encore confirmer"),' class="notice"');
|
|
echo '</div>';
|
|
|
|
echo '<div id="confirm_div_id" style="width: 100%; float: left;">';
|
|
echo '<form class="print" enctype="multipart/form-data" method="post">';
|
|
echo dossier::hidden();
|
|
echo $Ledger->confirm($_POST );
|
|
echo HtmlInput::hidden('ac',$_REQUEST['ac']);
|
|
?>
|
|
<div id="tab_id" >
|
|
<script>
|
|
var a_tab = ['modele_div_id','repo_div_id','facturation_div_id','reverse_div_id'];
|
|
</script>
|
|
<ul class="tabs">
|
|
<li class="tabs_selected"><a href="javascript:void(0)" title="<?php echo _("Générer une facture ou charger un document")?>" onclick="unselect_other_tab(this.parentNode.parentNode);this.parentNode.className='tabs_selected';show_tabs(a_tab,'facturation_div_id')"><?php echo _('Facture')?></a></li>
|
|
<li class="tabs"> <a href="javascript:void(0)" title="<?php echo _("Choix du dépôt")?>" onclick="unselect_other_tab(this.parentNode.parentNode);this.parentNode.className='tabs_selected';show_tabs(a_tab,'repo_div_id')"> <?php echo _('Dépôt')?> </a></li>
|
|
<li class="tabs"> <a href="javascript:void(0)" title="<?php echo _("Modèle à sauver")?>" onclick="unselect_other_tab(this.parentNode.parentNode);this.parentNode.className='tabs_selected';show_tabs(a_tab,'modele_div_id')"> <?php echo _('Modèle')?> </a></li>
|
|
<li class="tabs"> <a href="javascript:void(0)" title="<?php echo _("Extourne")?>" onclick="unselect_other_tab(this.parentNode.parentNode);this.parentNode.className='tabs_selected';show_tabs(a_tab,'reverse_div_id')"> <?php echo _('Extourne')?> </a></li>
|
|
</ul>
|
|
<?php
|
|
echo $Ledger->select_depot(false, -1);
|
|
echo $Ledger->extra_info();
|
|
echo '<div id="modele_div_id" style="display:none;height:185px;height:10rem">';
|
|
echo Pre_operation::save_propose();
|
|
echo '</div>';
|
|
|
|
|
|
echo '<div id="reverse_div_id" style="display:none;height:185px;height:10rem">';
|
|
$reverse_date=new IDate('reverse_date');
|
|
$reverse_ck=new ICheckBox('reverse_ck');
|
|
echo _('Extourne opération')." ".$reverse_ck->input()." ";
|
|
echo $reverse_date->input();
|
|
echo '</div>';
|
|
|
|
echo HtmlInput::hidden('ac',$_REQUEST['ac']);
|
|
echo HtmlInput::submit("record",_("Enregistrement"),'onClick="return verify_ca(\'\');"');
|
|
echo HtmlInput::submit('correct',_("Corriger"));
|
|
echo '</form>';
|
|
echo '</div>';
|
|
echo '</div>'; /* tab_id */
|
|
?>
|
|
<script>
|
|
$('repo_div_id').hide();
|
|
$('modele_div_id').hide();
|
|
show_tab(a_tab,'facturation_div_id');
|
|
</script>
|
|
<?php
|
|
echo '</div>';
|
|
return;
|
|
}
|
|
}
|
|
//------------------------------
|
|
/* Record the invoice */
|
|
//------------------------------
|
|
|
|
if ( isset($_POST['record']) )
|
|
{
|
|
// Check privilege
|
|
if ( $g_user->check_jrn($_REQUEST['p_jrn']) != 'W' )
|
|
{
|
|
|
|
NoAccess();
|
|
exit -1;
|
|
}
|
|
|
|
$Ledger=new Acc_Ledger_Sold($cn,$_POST['p_jrn']);
|
|
try
|
|
{
|
|
$Ledger->verify($_POST);
|
|
}
|
|
catch (Exception $e)
|
|
{
|
|
alert($e->getMessage());
|
|
$correct=1;
|
|
}
|
|
|
|
if ( ! isset($correct))
|
|
{
|
|
if ( is_msie() == 0 )
|
|
echo '<div style="position:absolute" class="content">';
|
|
else
|
|
echo '<div class="content">';
|
|
|
|
$Ledger=new Acc_Ledger_Sold($cn,$_POST['p_jrn']);
|
|
$internal=$Ledger->insert($_POST);
|
|
|
|
/* Save the predefined operation */
|
|
if ( isset($_POST['opd_name']) && trim($_POST['opd_name']) != "" )
|
|
{
|
|
$opd=new Pre_op_ven($cn);
|
|
$opd->get_post();
|
|
$opd->save();
|
|
}
|
|
|
|
/* Show button */
|
|
echo '<h1 style="float:right;margin-right:20%"> Enregistrement </h1>';
|
|
|
|
echo $Ledger->confirm($_POST,true);
|
|
/* Show link for Invoice */
|
|
if (isset ($Ledger->doc) )
|
|
{
|
|
echo '<h2>Document </h2>';
|
|
echo $Ledger->doc;
|
|
}
|
|
|
|
|
|
/* Save the additional information into jrn_info */
|
|
$obj=new Acc_Ledger_Info($cn);
|
|
$obj->save_extra($Ledger->jr_id,$_POST);
|
|
// extourne
|
|
if (isset($_POST['reverse_ck']))
|
|
{
|
|
$p_date=HtmlInput::default_value_post('reverse_date', '');
|
|
if (isDate($p_date)==$p_date)
|
|
{
|
|
// reverse the operation
|
|
try
|
|
{
|
|
$Ledger->reverse($p_date);
|
|
echo '<p>';
|
|
echo _('Extourné au ').$p_date;
|
|
echo '</p>';
|
|
|
|
}
|
|
catch (Exception $e)
|
|
{
|
|
echo '<p class="notice">'._('Opération non extournée').
|
|
$e->getMessage().
|
|
'</p>';
|
|
}
|
|
}
|
|
else
|
|
{
|
|
// warning because date is invalid
|
|
echo '<p class="notice">'._('Date invalide, opération non extournée').'</p>';
|
|
}
|
|
}
|
|
|
|
echo $Ledger->button_new_operation();
|
|
|
|
echo '</div>';
|
|
return;
|
|
}
|
|
}
|
|
// ------------------------------
|
|
/* Display a blank form or a form with predef operation */
|
|
// ------------------------------
|
|
|
|
$array=(isset($_POST['correct'])||isset ($correct))?$_POST:null;
|
|
$Ledger=new Acc_Ledger_Sold($cn,0);
|
|
//
|
|
// pre defined operation
|
|
//
|
|
if ( is_msie() == 0 )
|
|
echo '<div style="position:absolute" class="content">';
|
|
else
|
|
echo '<div class="content">';
|
|
|
|
if (!isset($_REQUEST ['p_jrn']))
|
|
{
|
|
$def_ledger=$Ledger->get_first('ven', 2);
|
|
if (empty($def_ledger))
|
|
{
|
|
exit('Pas de journal disponible');
|
|
}
|
|
$Ledger->id=$def_ledger['jrn_def_id'];
|
|
}
|
|
else
|
|
$Ledger->id=$_REQUEST ['p_jrn'];
|
|
if (isset($_REQUEST['p_jrn_predef']))
|
|
{
|
|
$Ledger->id=$_REQUEST['p_jrn_predef'];
|
|
}
|
|
|
|
echo '<div id="predef_form">';
|
|
echo HtmlInput::hidden('p_jrn_predef', $Ledger->id);
|
|
$op=new Pre_op_ven($cn);
|
|
$op->set('ledger',$Ledger->id);
|
|
$op->set('ledger_type',"VEN");
|
|
$op->set('direct','f');
|
|
$url=http_build_query(array('p_jrn_predef'=>$Ledger->id,'ac'=>$_REQUEST['ac'],'gDossier'=>dossier::id()));
|
|
echo $op->form_get('do.php?'.$url);
|
|
echo '</div>';
|
|
|
|
echo '<div class="content">';
|
|
echo '<p class="notice">'.$p_msg.'</p>';
|
|
try
|
|
{
|
|
echo "<FORM class=\"print\" NAME=\"form_detail\" METHOD=\"POST\" >";
|
|
/* request for a predefined operation */
|
|
if (isset($_REQUEST['pre_def'])&&!isset($_POST['correct']))
|
|
{
|
|
// used a predefined operation
|
|
//
|
|
$op=new Pre_op_ven($cn);
|
|
$op->set_od_id($_REQUEST['pre_def']);
|
|
$p_post=$op->compute_array();
|
|
$Ledger->id=$_REQUEST ['p_jrn_predef'];
|
|
|
|
echo $Ledger->input($p_post);
|
|
echo '<div class="content">';
|
|
echo $Ledger->input_paid();
|
|
echo '</div>';
|
|
echo '<script>';
|
|
echo 'compute_all_ledger();';
|
|
echo '</script>';
|
|
}
|
|
else if (isset($_GET['create_invoice']))
|
|
{
|
|
$array=$Ledger->convert_from_follow($_GET ['ag_id']);
|
|
echo HtmlInput::hidden("ledger_type", "VEN");
|
|
echo HtmlInput::hidden("ac", $_REQUEST['ac']);
|
|
echo HtmlInput::hidden("sa", "p");
|
|
echo $Ledger->input($array);
|
|
echo '<div class="content">';
|
|
echo $Ledger->input_paid();
|
|
echo '</div>';
|
|
echo '<script>';
|
|
echo 'compute_all_ledger();';
|
|
echo '</script>';
|
|
}
|
|
else
|
|
{
|
|
echo HtmlInput::hidden("ledger_type", "VEN");
|
|
echo HtmlInput::hidden("ac", $_REQUEST['ac']);
|
|
echo HtmlInput::hidden("sa", "p");
|
|
|
|
echo $Ledger->input($array);
|
|
echo '<div class="content">';
|
|
echo $Ledger->input_paid();
|
|
echo '</div>';
|
|
echo '<script>';
|
|
echo 'compute_all_ledger();';
|
|
echo '</script>';
|
|
}
|
|
}
|
|
catch (Exception $e)
|
|
{
|
|
alert($e->getMessage());
|
|
return;
|
|
}
|
|
echo '<div class="content">';
|
|
|
|
|
|
echo HtmlInput::button('act',_('Actualiser'),'onClick="compute_all_ledger();"');
|
|
echo HtmlInput::submit("view_invoice",_("Enregistrer"));
|
|
echo HtmlInput::reset(_('Effacer '));
|
|
echo '</div>';
|
|
echo "</FORM>";
|
|
|
|
/* if we suggest the pj n# the run the script */
|
|
if ( $g_parameter->MY_PJ_SUGGEST=='Y')
|
|
{
|
|
echo '<script> update_pj()</script>';
|
|
}
|
|
if (!isset($_POST['e_date']) && $g_parameter->MY_DATE_SUGGEST=='Y')
|
|
{
|
|
echo create_script(" get_last_date()");
|
|
}
|
|
echo create_script(" update_name()");
|
|
return;
|
|
?>
|