Skip to content
Snippets Groups Projects
Select Git revision
  • db1071ca2074caa394f4851535f7f27c7c187fe4
  • master default
2 results

EventManagerController.php

Blame
  • element.php 15.19 KiB
    <?php
    /* Copyright (C) 2001-2004 Rodolphe Quiedeville <rodolphe@quiedeville.org>
     * Copyright (C) 2004-2010 Laurent Destailleur  <eldy@users.sourceforge.net>
     * Copyright (C) 2005-2010 Regis Houssin        <regis.houssin@capnetworks.com>
     * Copyright (C) 2012	   Juanjo Menent        <jmenent@2byte.es>
     *
     * 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 3 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, see <http://www.gnu.org/licenses/>.
     */
    
    /**
     *      \file       htdocs/projet/element.php
     *      \ingroup    projet facture
     *		\brief      Page of project referrers
     */
    
    require '../main.inc.php';
    require_once DOL_DOCUMENT_ROOT.'/projet/class/project.class.php';
    require_once DOL_DOCUMENT_ROOT.'/core/class/html.formprojet.class.php';
    require_once DOL_DOCUMENT_ROOT.'/core/lib/project.lib.php';
    if (! empty($conf->propal->enabled))      require_once DOL_DOCUMENT_ROOT.'/comm/propal/class/propal.class.php';
    if (! empty($conf->facture->enabled))     require_once DOL_DOCUMENT_ROOT.'/compta/facture/class/facture.class.php';
    if (! empty($conf->facture->enabled))     require_once DOL_DOCUMENT_ROOT.'/compta/facture/class/facture-rec.class.php';
    if (! empty($conf->commande->enabled))    require_once DOL_DOCUMENT_ROOT.'/commande/class/commande.class.php';
    if (! empty($conf->fournisseur->enabled)) require_once DOL_DOCUMENT_ROOT.'/fourn/class/fournisseur.facture.class.php';
    if (! empty($conf->fournisseur->enabled)) require_once DOL_DOCUMENT_ROOT.'/fourn/class/fournisseur.commande.class.php';
    if (! empty($conf->contrat->enabled))     require_once DOL_DOCUMENT_ROOT.'/contrat/class/contrat.class.php';
    if (! empty($conf->ficheinter->enabled))  require_once DOL_DOCUMENT_ROOT.'/fichinter/class/fichinter.class.php';
    if (! empty($conf->deplacement->enabled)) require_once DOL_DOCUMENT_ROOT.'/compta/deplacement/class/deplacement.class.php';
    if (! empty($conf->agenda->enabled))      require_once DOL_DOCUMENT_ROOT.'/comm/action/class/actioncomm.class.php';
    
    $langs->load("projects");
    $langs->load("companies");
    $langs->load("suppliers");
    if (! empty($conf->facture->enabled))  	$langs->load("bills");
    if (! empty($conf->commande->enabled)) 	$langs->load("orders");
    if (! empty($conf->propal->enabled))   	$langs->load("propal");
    if (! empty($conf->ficheinter->enabled))	$langs->load("interventions");
    
    $projectid=GETPOST('id','int');
    $ref=GETPOST('ref','alpha');
    $action=GETPOST('action','alpha');
    
    if ($projectid == '' && $ref == '')
    {
    	dol_print_error('','Bad parameter');
    	exit;
    }
    
    $mine = $_REQUEST['mode']=='mine' ? 1 : 0;
    //if (! $user->rights->projet->all->lire) $mine=1;	// Special for projects
    
    $project = new Project($db);
    if ($ref)
    {
        $project->fetch(0,$ref);
        $projectid=$project->id;
    }else {
    	$project->fetch($projectid);
    }
    
    // Security check
    $socid=0;
    if ($user->societe_id > 0) $socid=$user->societe_id;
    $result = restrictedArea($user, 'projet', $projectid);
    
    
    /*
     *	View
     */
    
    $help_url="EN:Module_Projects|FR:Module_Projets|ES:M&oacute;dulo_Proyectos";
    llxHeader("",$langs->trans("Referers"),$help_url);
    
    $form = new Form($db);
    $formproject=new FormProjets($db);
    
    $userstatic=new User($db);
    
    $project = new Project($db);
    $project->fetch($projectid,$ref);
    $project->societe->fetch($project->societe->id);
    
    // To verify role of users
    $userAccess = $project->restrictedProjectArea($user);
    
    $head=project_prepare_head($project);
    dol_fiche_head($head, 'element', $langs->trans("Project"),0,($project->public?'projectpub':'project'));
    
    
    print '<table class="border" width="100%">';
    
    $linkback = '<a href="'.DOL_URL_ROOT.'/projet/liste.php">'.$langs->trans("BackToList").'</a>';
    
    print '<tr><td width="30%">'.$langs->trans("Ref").'</td><td>';
    // Define a complementary filter for search of next/prev ref.
    if (! $user->rights->projet->all->lire)
    {
        $projectsListId = $project->getProjectsAuthorizedForUser($user,$mine,0);
        $project->next_prev_filter=" rowid in (".(count($projectsListId)?join(',',array_keys($projectsListId)):'0').")";
    }
    print $form->showrefnav($project, 'ref', $linkback, 1, 'ref', 'ref');
    print '</td></tr>';
    
    print '<tr><td>'.$langs->trans("Label").'</td><td>'.$project->title.'</td></tr>';
    
    print '<tr><td>'.$langs->trans("ThirdParty").'</td><td>';
    if (! empty($project->societe->id)) print $project->societe->getNomUrl(1);
    else print '&nbsp;';
    print '</td></tr>';
    
    // Visibility
    print '<tr><td>'.$langs->trans("Visibility").'</td><td>';
    if ($project->public) print $langs->trans('SharedProject');
    else print $langs->trans('PrivateProject');
    print '</td></tr>';
    
    // Statut
    print '<tr><td>'.$langs->trans("Status").'</td><td>'.$project->getLibStatut(4).'</td></tr>';
    
    // Date start
    print '<tr><td>'.$langs->trans("DateStart").'</td><td>';
    print dol_print_date($object->date_start,'day');
    print '</td></tr>';
    
    // Date end
    print '<tr><td>'.$langs->trans("DateEnd").'</td><td>';
    print dol_print_date($object->date_end,'day');
    print '</td></tr>';
    
    print '</table>';
    
    print '</div>';
    
    
    /*
     * Referers types
     */
    
    $listofreferent=array(
    'propal'=>array(
    	'title'=>"ListProposalsAssociatedProject",
    	'class'=>'Propal',
    	'table'=>'propal',
    	'test'=>$conf->propal->enabled && $user->rights->propale->lire),
    'order'=>array(
    	'title'=>"ListOrdersAssociatedProject",
    	'class'=>'Commande',
    	'table'=>'commande',
    	'test'=>$conf->commande->enabled && $user->rights->commande->lire),
    'invoice'=>array(
    	'title'=>"ListInvoicesAssociatedProject",
    	'class'=>'Facture',
    	'margin'=>'add',
    	'table'=>'facture',
    	'test'=>$conf->facture->enabled && $user->rights->facture->lire),
    'invoice_predefined'=>array(
    	'title'=>"ListPredefinedInvoicesAssociatedProject",
    	'class'=>'FactureRec',
    	'table'=>'facture_rec',
    	'test'=>$conf->facture->enabled && $user->rights->facture->lire),
    'order_supplier'=>array(
    	'title'=>"ListSupplierOrdersAssociatedProject",
    	'class'=>'CommandeFournisseur',
    	'table'=>'commande_fournisseur',
    	'test'=>$conf->fournisseur->enabled && $user->rights->fournisseur->commande->lire),
    'invoice_supplier'=>array(
    	'title'=>"ListSupplierInvoicesAssociatedProject",
    	'class'=>'FactureFournisseur',
    	'margin'=>'minus',
    	'table'=>'facture_fourn',
    	'test'=>$conf->fournisseur->enabled && $user->rights->fournisseur->facture->lire),
    'contract'=>array(
    	'title'=>"ListContractAssociatedProject",
    	'class'=>'Contrat',
    	'table'=>'contrat',
    	'test'=>$conf->contrat->enabled && $user->rights->contrat->lire),
    'intervention'=>array(
    	'title'=>"ListFichinterAssociatedProject",
    	'class'=>'Fichinter',
    	'table'=>'fichinter',
    	'disableamount'=>1,
    	'test'=>$conf->ficheinter->enabled && $user->rights->ficheinter->lire),
    'trip'=>array(
    	'title'=>"ListTripAssociatedProject",
    	'class'=>'Deplacement',
    	'table'=>'deplacement',
    	'margin'=>'minus',
    	'disableamount'=>1,
    	'test'=>$conf->deplacement->enabled && $user->rights->deplacement->lire),
    'agenda'=>array(
    	'title'=>"ListActionsAssociatedProject",
    	'class'=>'ActionComm',
    	'table'=>'actioncomm',
    	'disableamount'=>1,
    	'test'=>$conf->agenda->enabled && $user->rights->agenda->allactions->lire)
    );
    
    if ($action=="addelement")
    {
    	$tablename = GETPOST("tablename");
    	$elementselectid = GETPOST("elementselect");
    	$result=$project->update_element($tablename, $elementselectid);
    	if ($result<0) {
    		setEventMessage($project->error,'errors');
    	}
    }
    
    foreach ($listofreferent as $key => $value)
    {
    	$title=$value['title'];
    	$classname=$value['class'];
    	$tablename=$value['table'];
    	$qualified=$value['test'];
    
    	if ($qualified)
    	{
    		print '<br>';
    
    		print_titre($langs->trans($title));
    
    		$selectList=$formproject->select_element($tablename,$project->societe->id);
    
    		if (!$selectList || ($selectList<0)) {
    			setEventMessage($formproject->error,'errors');
    		} else {
    			print '<form action="'.$_SERVER["PHP_SELF"].'?id='.$projectid.'" method="post">';
    			print '<input type="hidden" name="tablename" value="'.$tablename.'">';
    			print '<input type="hidden" name="action" value="addelement">';
    			print '<table><tr><td>'.$langs->trans("SelectElement").'</td>';
    			print '<td>'.$selectList.'</td>';
    			print '<td><input type="submit" class="button" value="'.dol_escape_htmltag($langs->trans("AddElement")).'"></td>';
    			print '</tr></table>';
    			print '</form>';
    		}
    		print '<table class="noborder" width="100%">';
    		
    		print '<tr class="liste_titre">';
    		print '<td width="100">'.$langs->trans("Ref").'</td>';
    		print '<td width="100" align="center">'.$langs->trans("Date").'</td>';
    		print '<td>'.$langs->trans("ThirdParty").'</td>';
    		if (empty($value['disableamount'])) print '<td align="right" width="120">'.$langs->trans("AmountHT").'</td>';
    		if (empty($value['disableamount'])) print '<td align="right" width="120">'.$langs->trans("AmountTTC").'</td>';
    		print '<td align="right" width="200">'.$langs->trans("Status").'</td>';
    		print '</tr>';
    		$elementarray = $project->get_element_list($key, $tablename);
    		if (count($elementarray)>0 && is_array($elementarray))
    		{
    			$var=true;
    			$total_ht = 0;
    			$total_ttc = 0;
    			$num=count($elementarray);
    			for ($i = 0; $i < $num; $i++)
    			{
    				$element = new $classname($db);
    				$element->fetch($elementarray[$i]);
    				$element->fetch_thirdparty();
    				//print $classname;
    
    				$qualifiedfortotal=true;
    				if ($key == 'invoice')
    				{
    					if ($element->close_code == 'replaced') $qualifiedfortotal=false;	// Replacement invoice
    				}
    				
    				$var=!$var;
    				print "<tr ".$bc[$var].">";
    
    				// Ref
    				print '<td align="left">';
    				print $element->getNomUrl(1);
    				print "</td>\n";
    
    				// Date
    				$date=$element->date;
    				if (empty($date)) $date=$element->datep;
    				if (empty($date)) $date=$element->date_contrat;
    				if (empty($date)) $date=$element->datev; //Fiche inter
    				print '<td align="center">'.dol_print_date($date,'day').'</td>';
    
    				// Third party
                    print '<td align="left">';
                    if (is_object($element->client)) print $element->client->getNomUrl(1,'',48);
    				print '</td>';
    
                    // Amount
    				if (empty($value['disableamount'])) 
    				{
    					print '<td align="right">';
    					if (! $qualifiedfortotal) print '<strike>';
    					print (isset($element->total_ht)?price($element->total_ht):'&nbsp;');
    					if (! $qualifiedfortotal) print '</strike>';
    					print '</td>';
    				}
    
                    // Amount
    				if (empty($value['disableamount'])) 
    				{
    					print '<td align="right">';
    					if (! $qualifiedfortotal) print '<strike>';
    					print (isset($element->total_ttc)?price($element->total_ttc):'&nbsp;');
    					if (! $qualifiedfortotal) print '</strike>';
    					print '</td>';
    				}
    
    				// Status
    				print '<td align="right">'.$element->getLibStatut(5).'</td>';
    
    				print '</tr>';
    
    				if ($qualifiedfortotal)
    				{
    					$total_ht = $total_ht + $element->total_ht;
    					$total_ttc = $total_ttc + $element->total_ttc;
    				}
    			}
    
    			print '<tr class="liste_total"><td colspan="3">'.$langs->trans("Number").': '.$i.'</td>';
    			if (empty($value['disableamount'])) print '<td align="right" width="100">'.$langs->trans("TotalHT").' : '.price($total_ht).'</td>';
    			if (empty($value['disableamount'])) print '<td align="right" width="100">'.$langs->trans("TotalTTC").' : '.price($total_ttc).'</td>';
    			print '<td>&nbsp;</td>';
    			print '</tr>';
    		}
    		print "</table>";
    
    
    		/*
    		 * Barre d'action
    		 */
    		print '<div class="tabsAction">';
    
    		if ($project->statut > 0)
    		{
    			if ($project->societe->prospect || $project->societe->client)
    			{
    				if ($key == 'propal' && ! empty($conf->propal->enabled) && $user->rights->propale->creer)
    				{
    					print '<a class="butAction" href="'.DOL_URL_ROOT.'/comm/propal.php?socid='.$project->societe->id.'&amp;action=create&amp;origin='.$project->element.'&amp;originid='.$project->id.'">'.$langs->trans("AddProp").'</a>';
    				}
    				if ($key == 'order' && ! empty($conf->commande->enabled) && $user->rights->commande->creer)
    				{
    					print '<a class="butAction" href="'.DOL_URL_ROOT.'/commande/fiche.php?socid='.$project->societe->id.'&amp;action=create&amp;origin='.$project->element.'&amp;originid='.$project->id.'">'.$langs->trans("AddCustomerOrder").'</a>';
    				}
    				if ($key == 'invoice' && ! empty($conf->facture->enabled) && $user->rights->facture->creer)
    				{
    					print '<a class="butAction" href="'.DOL_URL_ROOT.'/compta/facture.php?socid='.$project->societe->id.'&amp;action=create&amp;origin='.$project->element.'&amp;originid='.$project->id.'">'.$langs->trans("AddCustomerInvoice").'</a>';
    				}
    			}
    			if ($project->societe->fournisseur)
    			{
    				if ($key == 'order_supplier' && ! empty($conf->fournisseur->enabled) && $user->rights->fournisseur->commande->creer)
    				{
    					print '<a class="butAction" href="'.DOL_URL_ROOT.'/fourn/facture/fiche.php?socid='.$project->societe->id.'&amp;action=create&amp;origin='.$project->element.'&amp;originid='.$project->id.'">'.$langs->trans("AddSupplierInvoice").'</a>';
    				}
    				if ($key == 'invoice_supplier' && ! empty($conf->fournisseur->enabled) && $user->rights->fournisseur->facture->creer)
    				{
    					print '<a class="butAction" href="'.DOL_URL_ROOT.'/fourn/commande/fiche.php?socid='.$project->societe->id.'&amp;action=create&amp;origin='.$project->element.'&amp;originid='.$project->id.'">'.$langs->trans("AddSupplierOrder").'</a>';
    				}
    			}
    		}
    
    		print '</div>';
    	}
    }
    
    // Margin display of the project
    print_titre("Margin");
    print '<table class="noborder">';
    print '<tr class="liste_titre">';
    print '<td align="left" width="200">'.$langs->trans("Element").'</td>';
    print '<td align="right" width="100">'.$langs->trans("Number").'</td>';
    print '<td align="right" width="100">'.$langs->trans("AmountHT").'</td>';
    print '<td align="right" width="100">'.$langs->trans("AmountTTC").'</td>';
    print '</tr>';
    
    
    foreach ($listofreferent as $key => $value)
    {
    	$title=$value['title'];
    	$classname=$value['class'];
    	$tablename=$value['table'];
    	$qualified=$value['test'];
    	$margin = $value['margin'];
    	if (isset($margin))
    	{
    		$elementarray = $project->get_element_list($key, $tablename);
    		if (count($elementarray)>0 && is_array($elementarray))
    		{
    			$var=true;
    			$total_ht = 0;
    			$total_ttc = 0;
    			$num=count($elementarray);
    			for ($i = 0; $i < $num; $i++)
    			{
    				$element = new $classname($db);
    				$element->fetch($elementarray[$i]);
    				$element->fetch_thirdparty();
    				//print $classname;
    				if ($qualified)
    				{
    					$total_ht = $total_ht + $element->total_ht;
    					$total_ttc = $total_ttc + $element->total_ttc;
    				}
    			}
    
    			print '<tr >';
    			print '<td align="left" >'.$classname.'</td>';
    			print '<td align="right">'.$i.'</td>';
    			print '<td align="right">'.price($total_ht).'</td>';
    			print '<td align="right">'.price($total_ttc).'</td>';
    			print '</tr>';
    			if ($margin=="add")
    			{
    				$margin_ht+= $total_ht;
    				$margin_ttc+= $total_ttc;
    			}
    			else
    			{
    				$margin_ht-= $total_ht;
    				$margin_ttc-= $total_ttc;
    			}
    		}
    
    	}
    }
    // and the margin amount total
    print '<tr class="liste_total">';
    print '<td align="right" colspan=2 >'.$langs->trans("Total").'</td>';
    print '<td align="right" >'.price($margin_ht).'</td>';
    print '<td align="right" >'.price($margin_ttc).'</td>';
    print '</tr>';
    
    print "</table>";
    
    
    llxFooter();
    
    $db->close();