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/opening.inc.php

265 lines
7.6 KiB
PHP
Raw Normal View History

2015-09-27 00:35:53 +02:00
<?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 The opening of the exercices. it takes the saldo of the
* choosen foolder / exercice and import it as a misc operation in the
* current folder
*
*
*
*/
if ( ! defined ('ALLOWED') ) die('Appel direct ne sont pas permis');
require_once NOALYSS_INCLUDE.'/class_iselect.php';
require_once NOALYSS_INCLUDE.'/class_acc_ledger.php';
$p_mesg="";
$sa = (isset($_REQUEST['sa'])) ? $_REQUEST['sa'] : '';
$g_user->Check();
require_once NOALYSS_INCLUDE.'/user_menu.php';
// Correct (last step)
if (isset($_POST['correct']))
{
$ledger = new Acc_Ledger($cn, $_REQUEST['p_jrn']);
require_once NOALYSS_INCLUDE.'/operation_ods_new.inc.php';
return;
}
// confirm before saving
if ( isset($_POST['summary']))
{
try {
$ledger = new Acc_Ledger($cn, $_REQUEST['p_jrn']);
$ledger->with_concerned=false;
$ledger->verify($_POST);
require_once NOALYSS_INCLUDE.'/operation_ods_confirm.inc.php';
} catch (Exception $e)
{
echo alert($e->getMessage());
require('operation_ods_new.inc.php');
}
return;
}
// record
if (isset($_POST['save']))
{
$array = $_POST;
$ledger = new Acc_Ledger($cn, $_REQUEST['p_jrn']);
$ledger->with_concerned=false;
try
{
$ledger->save($array);
$jr_id = $cn->get_value('select jr_id from jrn where jr_internal=$1', array($ledger->internal));
echo '<h2> Op&eacute;ration enregistr&eacute;e Piece ' . h($ledger->pj) . '</h2>';
if (strcmp($ledger->pj, $_POST['e_pj']) != 0)
{
echo '<h3 class="notice">' . _('Attention numéro pièce existante, elle a du être adaptée') . '</h3>';
}
printf('<a class="detail" style="display:inline" href="javascript:modifyOperation(%d,%d)">%s</a><hr>', $jr_id, dossier::id(), $ledger->internal);
// show feedback
echo '<div id="jrn_name_div">'; echo '<h2 id="jrn_name" style="display:inline">' . $ledger->get_name() . '</h2>'; echo '</div>';
echo $ledger->confirm($_POST, true);
}
catch (Exception $e)
{
require('operation_ods_new.inc.php');
alert($e->getMessage());
}
return;
}
/* --------------------------------------------------
* step 1 if nothing is asked we show the available folders
*/
if ($sa == '')
{
echo '<div class="content">';
echo '<h1 class="legend"> Etape 1 </h1>';
echo 'Choisissez le dossier où sont les soldes à importer';
$avail = $g_user->get_available_folder();
if (empty($avail))
{
echo '*** Aucun dossier ***';
return;
}
echo '<form class="print" method="post">';
echo HtmlInput::hidden('ac', $_REQUEST['ac']);
echo HtmlInput::hidden('sa', 'step2');
echo dossier::hidden();
$wAvail = new ISelect();
/* compute select list */
$array = array();
$i = 0;
foreach ($avail as $r)
{
$array[$i]['value'] = $r['dos_id'];
$array[$i]['label'] = $r['dos_name'];
$i++;
}
$wAvail->value = $array;
echo 'Choix du dossier :' . $wAvail->input('f');
echo HtmlInput::submit('ok', 'Continuer');
echo '</form>';
echo '</div>';
echo '</div>';
return;
}
/* --------------------------------------------------
* Step 2 choose now the exercice of this folder
*/
$back = 'do.php?ac=' . $_REQUEST['ac'] . '&' . dossier::get();
if ($sa == 'step2')
{
echo '<div class="content">' .
'<div><h1 class="legend">Etape 2</h1>' .
'<h2 class="info">' . dossier::name($_REQUEST['f']) . '</h2>' .
'<form class="print" method="post">' .
' Choisissez l\'exercice du dossier ';
echo dossier::hidden();
echo HtmlInput::hidden('ac', $_REQUEST['ac']);
echo HtmlInput::hidden('sa', 'step3');
echo HtmlInput::hidden('f', $_REQUEST['f']);
$cn = new Database($_REQUEST['f']);
$periode = $cn->make_array("select distinct p_exercice,p_exercice from parm_periode order by p_exercice");
$w = new ISelect();
$w->table = 0;
$w->label = 'Periode';
$w->readonly = false;
$w->value = $periode;
$w->name = "p_periode";
echo 'P&eacute;riode : ' . $w->input();
echo HtmlInput::submit('ok', 'Continuer');
echo dossier::hidden();
echo "</form>";
echo HtmlInput::button_anchor('Retour', $back);
exit(0);
}
/* --------------------------------------------------
* select the ledger where we will import the data
*/
if ($sa == 'step3')
{
echo '<div class="content">' .
'<div><h1 class="legend">Etape 3</h1>' .
'<h2 class="info">' . dossier::name($_REQUEST['f']) . '</h2>' .
'<form class="print" method="post">' .
' Choisissez le journal qui contiendra l\'opération d\'ouverture ';
echo dossier::hidden();
echo HtmlInput::hidden('p_action', 'ouv');
echo HtmlInput::hidden('sa', 'step4');
echo HtmlInput::hidden('f', $_REQUEST['f']);
echo HtmlInput::hidden('p_periode', $_REQUEST['p_periode']);
$wLedger = new ISelect();
$g_user = new User(new Database(dossier::id()));
$avail = $g_user->get_ledger('ODS');
/* compute select list */
$array = array();
$i = 0;
foreach ($avail as $r)
{
$array[$i]['value'] = $r['jrn_def_id'];
$array[$i]['label'] = $r['jrn_def_name'];
$i++;
}
$wLedger->value = $array;
echo $wLedger->input('p_jrn');
echo HtmlInput::submit('ok', 'Continuer');
echo HtmlInput::hidden('ac', $_REQUEST['ac']);
echo dossier::hidden();
echo "</form>";
echo HtmlInput::button_anchor('Retour', $back . '&sa=step2&f=' . $_REQUEST['f']);
exit(0);
}
/* --------------------------------------------------
* Step 4 we import data from the selected folder and year and
* transform it into a misc operation
*/
if ($sa == 'step4')
{
echo '<div class="content">';
echo '<div><h1 class="legend"> Dernière étape</h1>';
$cn_target = new Database($_REQUEST['f']);
$saldo = new Acc_Ledger($cn_target, 0);
$array = $saldo->get_saldo_exercice($_REQUEST['p_periode']);
/* we need to transform the array into a Acc_Ledger array */
$result = array();
$result['desc'] = 'Ecriture d\'ouverture';
$result['nb_item'] = sizeof($array);
$result['p_jrn'] = $_REQUEST['p_jrn'];
$idx = 0;
foreach ($array as $row)
{
$qcode = 'qc_' . $idx;
$poste = 'poste' . $idx;
$amount = 'amount' . $idx;
$ck = 'ck' . $idx;
$result[$qcode] = $row['j_qcode'];
if (trim($row['j_qcode']) == '')
$result[$poste] = $row['j_poste'];
$result[$amount] = abs($row['solde']);
if ($row['solde'] > 0)
$result[$ck] = 'on';
$idx++;
}
$cn = new Database(dossier::id());
$jrn = new Acc_Ledger($cn, $_REQUEST['p_jrn']);
echo '<form class="print" method="post">';
echo HtmlInput::hidden('ac', $_REQUEST['ac']);
echo HtmlInput::hidden('sa', 'step5');
echo HtmlInput::hidden('f', $_REQUEST['f']);
echo HtmlInput::hidden('p_periode',$_REQUEST['p_periode']);
echo dossier::hidden();
echo HtmlInput::hidden('p_jrn', $_REQUEST['p_jrn']);
echo $jrn->input($result, 0);
echo '<hr>';
echo '<h2 class="notice">Ne corrigez pas encore, cliquez continuer pour passer à l\'étape suivante</h2>';
echo HtmlInput::submit('correct_it', 'Continuer');
echo '</form>';
echo HtmlInput::button_anchor('Retour', $back);
echo '</div>';
}
// if sa=step4 then record it
//
if ($_REQUEST['sa'] == 'step5')
{
$ledger = new Acc_Ledger($cn, $_REQUEST['p_jrn']);
require_once NOALYSS_INCLUDE.'/operation_ods_new.inc.php';
}