db=$p_cn; $this->d_id=$p_d_id; $this->counter=0; } /*!\brief insert a minimal document and set the d_id */ function blank() { $this->d_id=$this->db->get_next_seq("document_d_id_seq"); // affect a number $this->d_number=$this->db->get_next_seq("seq_doc_type_".$this->md_type); $sql=sprintf('insert into document(d_id,ag_id,d_number) values(%d,%d,%d)', $this->d_id, $this->ag_id, $this->d_number); $this->db->exec_sql($sql); } function compute_filename($pj,$filename) { foreach (array('/','*','<','>',';',',','\\','.',':') as $i) { $pj= str_replace($i, "-",$pj); } // save the suffix $pos_prefix=strrpos($filename,"."); if ($pos_prefix == 0) $pos_prefix=strlen($filename); $filename_no=substr($filename,0,$pos_prefix); $filename_suff=substr($filename,$pos_prefix,strlen($filename)); $new_filename= strtolower($filename_no."-".$pj.$filename_suff); return $new_filename; } /*! * \brief Generate the document, Call $this-\>Replace to replace * tag by value *@param p_array contains the data normally it is the $_POST *@param contains the new filename * \return an array : the url where the generated doc can be found, the name * of the file and his mimetype */ function Generate($p_array,$p_filename="") { // create a temp directory in /tmp to unpack file and to parse it $dirname=tempnam($_ENV['TMP'],'doc_'); unlink($dirname); mkdir ($dirname); // Retrieve the lob and save it into $dirname $this->db->start(); $dm_info="select md_name,md_type,md_lob,md_filename,md_mimetype from document_modele where md_id=".$this->md_id; $Res=$this->db->exec_sql($dm_info); $row=Database::fetch_array($Res,0); $this->d_lob=$row['md_lob']; $this->d_filename=$row['md_filename']; $this->d_mimetype=$row['md_mimetype']; $this->d_name=$row['md_name']; chdir($dirname); $filename=$row['md_filename']; $exp=$this->db->lo_export($row['md_lob'],$dirname.DIRECTORY_SEPARATOR.$filename); if ( $exp === false ) echo_warning( __FILE__.":".__LINE__."Export NOK $filename"); $type="n"; // if the doc is a OOo, we need to unzip it first // and the name of the file to change is always content.xml if ( strpos($row['md_mimetype'],'vnd.oasis') != 0 ) { ob_start(); $zip = new Zip_Extended; if ($zip->open($filename) === TRUE) { $zip->extractTo($dirname.DIRECTORY_SEPARATOR); $zip->close(); } else { echo __FILE__.":".__LINE__."cannot unzip model ".$filename; } // Remove the file we do not need anymore unlink($filename); ob_end_clean(); $file_to_parse="content.xml"; $type="OOo"; } else $file_to_parse=$filename; // affect a number $this->d_number=$this->db->get_next_seq("seq_doc_type_".$row['md_type']); // parse the document - return the doc number ? $this->ParseDocument($dirname,$file_to_parse,$type,$p_array); $this->db->commit(); // if the doc is a OOo, we need to re-zip it if ( strpos($row['md_mimetype'],'vnd.oasis') != 0 ) { ob_start(); $zip = new Zip_Extended; $res = $zip->open($filename, ZipArchive::CREATE); if($res !== TRUE) { throw new Exception ( __FILE__.":".__LINE__."cannot recreate zip"); } $zip->add_recurse_folder($dirname.DIRECTORY_SEPARATOR); $zip->close(); ob_end_clean(); $file_to_parse=$filename; } if ( $p_filename !="") { $this->d_filename=$this->compute_filename($p_filename, $this->d_filename); } $this->SaveGenerated($dirname.DIRECTORY_SEPARATOR.$file_to_parse); // Invoice $ret='Document généré'; @rmdir($dirname); return $ret; } /*! ParseDocument * \brief This function parse a document and replace all * the predefined tags by a value. This functions * generate diffent documents (invoice, order, letter) * with the info from the database * * \param $p_dir directory name * \param $p_file filename * \param $p_type For the OOo document the tag are < and > instead of < and > * \param $p_array variable from $_POST */ function ParseDocument($p_dir,$p_file,$p_type,$p_array) { /*!\note Replace in the doc the tags by their values. * - MY_* table parameter * - ART_VEN* table quant_sold for invoice * - CUST_* table quant_sold and fiche for invoice * - e_* for the invoice in the $_POST */ // open the document $infile_name=$p_dir.DIRECTORY_SEPARATOR.$p_file; $h=fopen($infile_name,"r"); // check if tmpdir exist otherwise create it $temp_dir=$_SERVER["DOCUMENT_ROOT"].DIRECTORY_SEPARATOR.'tmp'; if ( is_dir($temp_dir) == false ) { if ( mkdir($temp_dir) == false ) { $msg=_("Ne peut pas créer le répertoire ".$temp_dir); throw new Exception($msg); } } // Compute output_name $output_name=tempnam($temp_dir,"gen_doc_"); $output_file=fopen($output_name,"w+"); // check if the opening is sucessfull if ( $h === false ) { echo __FILE__.":".__LINE__."cannot open $p_dir $p_file "; $msg=_("Ne peut pas ouvrir $p_dir $p_file"); throw new Exception($msg); } if ( $output_file == false) { $msg=_("Ne peut pas ouvrir $p_dir $p_file"); echo $msg; throw new Exception($msg); } // compute the regex if ( $p_type=='OOo') { $regex="/=*<<[A-Z]+_*[A-Z]*_*[A-Z]*_*[A-Z]*_*[0-9]*>>/i"; $lt="<"; $gt=">"; } else { $regex="/=*<<[A-Z]+_*[A-Z]*_*[A-Z]*_*[A-Z]*_*[0-9]*>>/i"; $lt="<"; $gt=">"; } //read the file while(! feof($h)) { // replace the tag $buffer=fgets($h); // search in the buffer the magic << and >> // while preg_match_all finds something to replace while ( preg_match_all ($regex,$buffer,$f) >0 ) { foreach ( $f as $apattern ) { foreach($apattern as $pattern) { $to_remove=$pattern; // we remove the < and > from the pattern $tag=str_replace($lt,'',$pattern); $tag=str_replace($gt,'',$tag); // if the pattern if found we replace it $value=$this->Replace($tag,$p_array); if ( strpos($value,'ERROR') != false ) $value=""; /* * Change type of cell to numeric * allow numeric cel in ODT for the formatting and formula */ if ( is_numeric($value) && $p_type=='OOo') { $searched='/office:value-type="string">'.$pattern.'/'; $replaced='office:value-type="float" office:value="'.$value.'">'.$pattern; $buffer=preg_replace($searched, $replaced, $buffer,1); } // replace into the $buffer // take the position in the buffer $pos=strpos($buffer,$to_remove); // get the length of the string to remove $len=strlen($to_remove); if ( $p_type=='OOo' ) { $value=str_replace('&','&',$value); $value=str_replace('<','<',$value); $value=str_replace('>','>',$value); $value=str_replace('"','"',$value); $value=str_replace("'",''',$value); } $buffer=substr_replace($buffer,$value,$pos,$len); // if the pattern if found we replace it } } } // write into the output_file fwrite($output_file,$buffer); } fclose($h); fclose($output_file); if ( ($ret=copy ($output_name,$infile_name)) == FALSE ) { echo _('Ne peut pas sauver '.$output_name.' vers '.$infile_name.' code d\'erreur ='.$ret); } } /*! SaveGenerated * \brief Save the generated Document * \param $p_file is the generated file * * * \return 0 if no error otherwise 1 */ function SaveGenerated($p_file) { // We save the generated file $doc=new Document($this->db); $this->db->start(); $this->d_lob=$this->db->lo_import($p_file); if ( $this->d_lob == false ) { echo "ne peut pas importer [$p_file]"; return 1; } $sql="insert into document(ag_id,d_lob,d_number,d_filename,d_mimetype) values ($1,$2,$3,$4,$5)"; $this->db->exec_sql($sql, array($this->ag_id, $this->d_lob, $this->d_number, $this->d_filename, $this->d_mimetype)); $this->d_id=$this->db->get_current_seq("document_d_id_seq"); // Clean the file unlink ($p_file); $this->db->commit(); return 0; } /*! Upload * \brief Upload a file into document * all the needed data are in $_FILES we don't increment the seq * \param $p_file : array containing by default $_FILES * * \return */ function Upload($p_ag_id) { // nothing to save if ( sizeof($_FILES) == 0 ) return; /* for several files */ /* $_FILES is now an array */ // Start Transaction $this->db->start(); $name=$_FILES['file_upload']['name']; for ($i = 0; $i < sizeof($name);$i++) { $new_name=tempnam($_ENV['TMP'],'doc_'); // check if a file is submitted if ( strlen($_FILES['file_upload']['tmp_name'][$i]) != 0 ) { // upload the file and move it to temp directory if ( move_uploaded_file($_FILES['file_upload']['tmp_name'][$i],$new_name)) { $oid=$this->db->lo_import($new_name); // check if the lob is in the database if ( $oid == false ) { $this->db->rollback(); return 1; } } // the upload in the database is successfull $this->d_lob=$oid; $this->d_filename=$_FILES['file_upload']['name'][$i]; $this->d_mimetype=$_FILES['file_upload']['type'][$i]; $this->d_description= strip_tags($_POST['input_desc'][$i]); // insert into the table $sql="insert into document (ag_id, d_lob,d_filename,d_mimetype,d_number,d_description) values ($1,$2,$3,$4,$5,$6)"; $this->db->exec_sql($sql,array($p_ag_id,$this->d_lob,$this->d_filename,$this->d_mimetype,1,$this->d_description)); } } /* end for */ $this->db->commit(); } /** * Copy a existing OID (LOB) into the table document * @note use of global variable $cn which is the db connx to the current folder * @param type $p_ag_id Follow_Up::ag_id * @param type $p_lob oid of existing document * @param type $p_filename filename of existing document * @param type $p_mimetype mimetype of existing document * @param type $p_description Description of existing document (default empty) */ static function insert_existing_document($p_ag_id, $p_lob, $p_filename, $p_mimetype, $p_description = "") { global $cn; // insert into the table $sql = "insert into document (ag_id, d_lob,d_filename,d_mimetype,d_number,d_description) values ($1,$2,$3,$4,$5,$6)"; $cn->exec_sql($sql, array($p_ag_id, $p_lob, $p_filename, $p_mimetype, 1, $p_description)); } /*! a_ref * \brief create and compute a string for reference the doc * * \return a string */ function anchor() { if ( $this->d_id == 0 ) return ''; $image=''; $r=""; $r=''.$image.''; return $r; } /** Get * \brief Send the document */ function Send() { // retrieve the template and generate document $this->db->start(); $ret=$this->db->exec_sql( "select d_id,d_lob,d_filename,d_mimetype from document where d_id=".$this->d_id ); if ( Database::num_row ($ret) == 0 ) return; $row=Database::fetch_array($ret,0); //the document is saved into file $tmp $tmp=tempnam($_ENV['TMP'],'document_'); $this->db->lo_export($row['d_lob'],$tmp); $this->d_mimetype=$row['d_mimetype']; $this->d_filename=$row['d_filename']; // send it to stdout ini_set('zlib.output_compression','Off'); header("Pragma: public"); header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); header("Cache-Control: must-revalidate"); header('Content-type: '.$this->d_mimetype); header('Content-Disposition: attachment;filename="'.$this->d_filename.'"',FALSE); header("Accept-Ranges: bytes"); $file=fopen($tmp,'r'); while ( !feof ($file) ) { echo fread($file,8192); } fclose($file); unlink ($tmp); $this->db->commit(); } /*!\brief get all the document of a given action *\param $ag_id the ag_id from action::ag_id (primary key) *\return an array of objects document or an empty array if nothing found */ function get_all($ag_id) { $res=$this->db->get_array('select d_id, ag_id, d_lob, d_number, d_filename,'. ' d_mimetype,d_description from document where ag_id=$1',array($ag_id)); $a=array(); for ($i=0;$idb); $doc->d_id=$res[$i]['d_id']; $doc->ag_id=$res[$i]['ag_id']; $doc->d_lob=$res[$i]['d_lob']; $doc->d_number=$res[$i]['d_number']; $doc->d_filename=$res[$i]['d_filename']; $doc->d_mimetype=$res[$i]['d_mimetype']; $doc->d_description=$row['d_description']; $a[$i]=clone $doc; } return $a; } /*!\brief Get complete all the data member thx info from the database */ function get() { $sql="select * from document where d_id=".$this->d_id; $ret=$this->db->exec_sql($sql); if ( Database::num_row($ret) == 0 ) return; $row=Database::fetch_array($ret,0); $this->ag_id=$row['ag_id']; $this->d_mimetype=$row['d_mimetype']; $this->d_filename=$row['d_filename']; $this->d_lob=$row['d_lob']; $this->d_number=$row['d_number']; $this->d_description=$row['d_description']; } /*! * \brief replace the TAG by the real value, this value can be into * the database or in $_POST * The possible tags are * - [CUST_NAME] customer's name * - [CUST_ADDR_1] customer's address line 1 * - [CUST_CP] customer's ZIP code * - [CUST_CO] customer's country * - [CUST_CITY] customer's city * - [CUST_VAT] customer's VAT * - [MARCH_NEXT] end this item and increment the counter $i * - [DATE_LIMIT] * - [VEN_ART_NAME] * - [VEN_ART_PRICE] * - [VEN_ART_QUANT] * - [VEN_ART_TVA_CODE] * - [VEN_ART_STOCK_CODE] * - [VEN_HTVA] * - [VEN_TVAC] * - [VEN_TVA] * - [TOTAL_VEN_HTVA] * - [DATE_CALC] * - [DATE] * - [DATE_LIMIT] * - [DATE_LIMIT_CALC] * - [NUMBER] * - [MY_NAME] * - [MY_CP] * - [MY_COMMUNE] * - [MY_TVA] * - [MY_STREET] * - [MY_NUMBER] * - [TVA_CODE] * - [TVA_RATE] * - [BON_COMMANDE] * - [OTHER_INFO] * - [CUST_NUM] * - [CUST_BANQUE_NAME] * - [CUST_BANQUE_NO] * - [USER] * - [REFERENCE] * - [BENEF_NAME] * - [BENEF_BANQUE_NAME] * - [BENEF_BANQUE_NO] * - [BENEF_ADDR_1] * - [BENEF_CP] * - [BENEF_CO] * - [BENEF_CITY] * - [BENEF_VAT] * - [ACOMPTE] * - [TITLE] * - [DESCRIPTION] * * \param $p_tag TAG * \param $p_array data from $_POST * \return String which must replace the tag */ function Replace($p_tag,$p_array) { global $g_parameter; $p_tag=strtoupper($p_tag); $p_tag=str_replace('=','',$p_tag); $r="Tag inconnu"; switch ($p_tag) { case 'DATE': $r=(isset ($p_array['ag_timestamp']))?$p_array['ag_timestamp']:$p_array['e_date']; break; case 'DATE_CALC': $r=' Date inconnue '; // Date are in $p_array['ag_date'] // or $p_array['e_date'] if ( isset ($p_array['ag_timestamp'])) { $date=format_date($p_array['ag_timestamp'],'DD.MM.YYYY','YYYY-MM-DD'); $r=$date; } if ( isset ($p_array['e_date'])) { $date=format_date($p_array['e_date'],'DD.MM.YYYY','YYYY-MM-DD'); $r=$date; } break; // // the company priv case 'MY_NAME': $r=$g_parameter->MY_NAME; break; case 'MY_CP': $r=$g_parameter->MY_CP; break; case 'MY_COMMUNE': $r=$g_parameter->MY_COMMUNE; break; case 'MY_TVA': $r=$g_parameter->MY_TVA; break; case 'MY_STREET': $r=$g_parameter->MY_STREET; break; case 'MY_NUMBER': $r=$g_parameter->MY_NUMBER; break; case 'MY_TEL': $r=$g_parameter->MY_TEL; break; case 'MY_FAX': $r=$g_parameter->MY_FAX; break; case 'MY_PAYS': $r=$g_parameter->MY_PAYS; break; // customer /*\note The CUST_* are retrieved thx the $p_array['tiers'] * which contains the quick_code */ case 'SOLDE': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_dest'])?$p_array['qcode_dest']:$p_array['e_client']; $tiers->get_by_qcode($qcode,false); $p=$tiers->strAttribut(ATTR_DEF_ACCOUNT); $poste=new Acc_Account_Ledger($this->db,$p); $r=$poste->get_solde(' true' ); break; case 'CUST_NAME': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_dest'])?$p_array['qcode_dest']:$p_array['e_client']; $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_NAME); break; case 'CUST_ADDR_1': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_dest'])?$p_array['qcode_dest']:$p_array['e_client']; $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_ADRESS); break ; case 'CUST_CP': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_dest'])?$p_array['qcode_dest']:$p_array['e_client']; $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_CP); break; case 'CUST_CITY': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_dest'])?$p_array['qcode_dest']:$p_array['e_client']; $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_CITY); break; case 'CUST_CO': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_dest'])?$p_array['qcode_dest']:$p_array['e_client']; $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_PAYS); break; // Marchandise in $p_array['e_march*'] // \see user_form_achat.php or user_form_ven.php case 'CUST_VAT': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_dest'])?$p_array['qcode_dest']:$p_array['e_client']; $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_NUMTVA); break; case 'CUST_NUM': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_dest'])?$p_array['qcode_dest']:$p_array['e_client']; $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_NUMBER_CUSTOMER); break; case 'CUST_BANQUE_NO': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_dest'])?$p_array['qcode_dest']:$p_array['e_client']; $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_BQ_NO); break; case 'CUST_BANQUE_NAME': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_dest'])?$p_array['qcode_dest']:$p_array['e_client']; $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_BQ_NAME); break; /* -------------------------------------------------------------------------------- */ /* BENEFIT (fee notes */ case 'BENEF_NAME': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_benef'])?$p_array['qcode_benef']:''; if ( $qcode=='') { $r=''; break; } $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_NAME); break; case 'BENEF_ADDR_1': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_benef'])?$p_array['qcode_benef']:''; if ( $qcode=='') { $r=''; break; } $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_ADRESS); break ; case 'BENEF_CP': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_benef'])?$p_array['qcode_benef']:''; if ( $qcode=='') { $r=''; break; } $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_CP); break; case 'BENEF_CITY': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_benef'])?$p_array['qcode_benef']:''; if ( $qcode=='') { $r=''; break; } $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_CITY); break; case 'BENEF_CO': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_benef'])?$p_array['qcode_benef']:''; if ( $qcode=='') { $r=''; break; } $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_PAYS); break; // Marchandise in $p_array['e_march*'] // \see user_form_achat.php or user_form_ven.php case 'BENEF_VAT': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_benef'])?$p_array['qcode_benef']:''; if ( $qcode=='') { $r=''; break; } $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_NUMTVA); break; case 'BENEF_NUM': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_benef'])?$p_array['qcode_benef']:''; if ( $qcode=='') { $r=''; break; } $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_NUMBER_CUSTOMER); break; case 'BENEF_BANQUE_NO': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_benef'])?$p_array['qcode_benef']:''; if ( $qcode=='') { $r=''; break; } $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_BQ_NO); break; case 'BENEF_BANQUE_NAME': $tiers=new Fiche($this->db); $qcode=isset($p_array['qcode_benef'])?$p_array['qcode_benef']:''; if ( $qcode=='') { $r=''; break; } $tiers->get_by_qcode($qcode,false); $r=$tiers->strAttribut(ATTR_DEF_BQ_NAME); break; // Marchandise in $p_array['e_march*'] // \see user_form_achat.php or user_form_ven.php case 'NUMBER': $r=$this->d_number; break; case 'USER' : return $_SESSION['use_name'].', '.$_SESSION['use_first_name']; break; case 'REFERENCE': $act=new Follow_Up($this->db); $act->ag_id=$this->ag_id; $act->get(); $r=$act->ag_ref; break; /* * - [VEN_ART_NAME] * - [VEN_ART_PRICE] * - [VEN_ART_QUANT] * - [VEN_ART_TVA_CODE] * - [VEN_ART_STOCK_CODE] * - [VEN_HTVA] * - [VEN_TVAC] * - [VEN_TVA] * - [TOTAL_VEN_HTVA] * - [DATE_LIMIT] */ case 'DATE_LIMIT_CALC': extract ($p_array); $id='e_ech' ; if ( !isset (${$id}) ) return ""; $r=format_date(${$id},'DD.MM.YYYY','YYYY-MM-DD'); break; case 'DATE_LIMIT': extract ($p_array); $id='e_ech' ; if ( !isset (${$id}) ) return ""; $r=${$id}; break; case 'MARCH_NEXT': $this->counter++; $r=''; break; case 'VEN_ART_NAME': extract ($p_array); $id='e_march'.$this->counter; // check if the march exists if ( ! isset (${$id})) return ""; // check that something is sold if ( ${'e_march'.$this->counter.'_price'} != 0 && ${'e_quant'.$this->counter} != 0 ) { $f=new Fiche($this->db); $f->get_by_qcode(${$id},false); $r=$f->strAttribut(ATTR_DEF_NAME); } else $r = ""; break; case 'VEN_ART_LABEL': extract ($p_array); $id='e_march'.$this->counter."_label"; // check if the march exists if (! isset (${$id}) || (isset (${$id}) && strlen(trim(${$id})) == 0)) { $id = 'e_march' . $this->counter; // check if the march exists if (!isset(${$id})) $r= ""; else { // check that something is sold if (${'e_march' . $this->counter . '_price'} != 0 && ${'e_quant' . $this->counter} != 0) { $f = new Fiche($this->db); $f->get_by_qcode(${$id}, false); $r = $f->strAttribut(ATTR_DEF_NAME); } else $r = ""; } } else $r=${'e_march'.$this->counter.'_label'}; break; case 'VEN_ART_STOCK_CODE': extract ($p_array); $id = 'e_march' . $this->counter; // check if the march exists if (!isset(${$id})) $r= ""; else { // check that something is sold if (${'e_march' . $this->counter . '_price'} != 0 && ${'e_quant' . $this->counter} != 0) { $f = new Fiche($this->db); $f->get_by_qcode(${$id}, false); $r = $f->strAttribut(ATTR_DEF_STOCK); $r=($r == NOTFOUND)?'':$r; } } break; case 'VEN_ART_PRICE': extract ($p_array); $id='e_march'.$this->counter.'_price' ; if ( !isset (${$id}) ) return ""; if (${$id} == 0 ) return ""; $r=${$id}; break; case 'TVA_RATE': case 'VEN_ART_TVA_RATE': extract ($p_array); $id='e_march'.$this->counter.'_tva_id'; if ( !isset (${$id}) ) return ""; if ( ${$id} == -1 || ${$id}=='' ) return ""; $march_id='e_march'.$this->counter.'_price' ; if ( ! isset (${$march_id})) return ''; $tva=new Acc_Tva($this->db); $tva->set_parameter("id",${$id}); if ( $tva->load() == -1) return ''; return $tva->get_parameter("rate"); break; case 'TVA_CODE': case 'VEN_ART_TVA_CODE': extract ($p_array); $id='e_march'.$this->counter.'_tva_id'; if ( !isset (${$id}) ) return ""; if ( ${$id} == -1 ) return ""; $qt='e_quant'.$this->counter; $price='e_march'.$this->counter.'_price' ; if ( ${$price} == 0 || ${$qt} == 0 || strlen(trim( $price )) ==0 || strlen(trim($qt)) ==0) return ""; $r=${$id}; break; case 'TVA_LABEL': extract ($p_array); $id='e_march'.$this->counter.'_tva_id'; if ( !isset (${$id}) ) return ""; $march_id='e_march'.$this->counter.'_price' ; if ( ! isset (${$march_id})) return ''; if ( ${$march_id} == 0) return ''; $tva=new Acc_Tva($this->db,${$id}); if ($tva->load() == -1 ) return ""; $r=$tva->get_parameter('label'); break; /* total VAT for one sold */ case 'TVA_AMOUNT': case 'VEN_TVA': extract ($p_array); $qt='e_quant'.$this->counter; $price='e_march'.$this->counter.'_price' ; $tva='e_march'.$this->counter.'_tva_id'; /* if we do not use vat this var. is not set */ if ( !isset(${$tva}) ) return ''; if ( !isset (${'e_march'.$this->counter}) ) return ""; // check that something is sold if ( ${$price} == 0 || ${$qt} == 0 || strlen(trim( $price )) ==0 || strlen(trim($qt)) ==0) return ""; $r=${'e_march'.$this->counter.'_tva_amount'}; break; /* TVA automatically computed */ case 'VEN_ART_TVA': extract ($p_array); $qt='e_quant'.$this->counter; $price='e_march'.$this->counter.'_price' ; $tva='e_march'.$this->counter.'_tva_id'; if ( !isset (${'e_march'.$this->counter}) ) return ""; // check that something is sold if ( ${$price} == 0 || ${$qt} == 0 || strlen(trim( $price )) ==0 || strlen(trim($qt)) ==0) return ""; $oTva=new Acc_Tva($this->db,${$tva}); if ($oTva->load() == -1 ) return ""; $r=round(${$price},2)*$oTva->get_parameter('rate'); $r=round($r,2); break; case 'VEN_ART_TVAC': extract ($p_array); $qt='e_quant'.$this->counter; $price='e_march'.$this->counter.'_price' ; $tva='e_march'.$this->counter.'_tva_id'; if ( !isset (${'e_march'.$this->counter}) ) return ""; // check that something is sold if ( ${$price} == 0 || ${$qt} == 0 || strlen(trim( $price )) ==0 || strlen(trim($qt)) ==0) return ""; if ( ! isset (${$tva}) ) return ''; $tva=new Acc_Tva($this->db,${$tva}); if ($tva->load() == -1 ) { $r=round(${$price},2); } else { $r=round(${$price}*$tva->get_parameter('rate')+${$price},2); } break; case 'VEN_ART_QUANT': extract ($p_array); $id='e_quant'.$this->counter; if ( !isset (${$id}) ) return ""; // check that something is sold if ( ${'e_march'.$this->counter.'_price'} == 0 || ${'e_quant'.$this->counter} == 0 || strlen(trim( ${'e_march'.$this->counter.'_price'} )) ==0 || strlen(trim(${'e_quant'.$this->counter})) ==0 ) return ""; $r=${$id}; break; case 'VEN_HTVA': extract ($p_array); $id='e_march'.$this->counter.'_price' ; $quant='e_quant'.$this->counter; if ( !isset (${$id}) ) return ""; // check that something is sold if ( ${'e_march'.$this->counter.'_price'} == 0 || ${'e_quant'.$this->counter} == 0 || strlen(trim( ${'e_march'.$this->counter.'_price'} )) ==0 || strlen(trim(${'e_quant'.$this->counter})) ==0) return ""; bcscale(4); $r=bcmul(${$id},${$quant}); $r=round($r,2); break; case 'VEN_TVAC': extract ($p_array); $id='e_march'.$this->counter.'_tva_amount' ; $price='e_march'.$this->counter.'_price' ; $quant='e_quant'.$this->counter; if ( ! isset(${'e_march'.$this->counter.'_price'})|| !isset(${'e_quant'.$this->counter})) return ""; // check that something is sold if ( ${'e_march'.$this->counter.'_price'} == 0 || ${'e_quant'.$this->counter} == 0 ) return ""; bcscale(4); // if TVA not exist if ( ! isset(${$id})) $r= bcmul(${$price},${$quant}); else{ $r= bcmul(${$price},${$quant}); $r=bcadd($r,${$id}); } $r=round($r,2); return $r; break; case 'TOTAL_VEN_HTVA': extract($p_array); bcscale(4); $sum=0.0; for ($i=0;$i<$nb_item;$i++) { $sell='e_march'.$i.'_price'; $qt='e_quant'.$i; if ( ! isset (${$sell}) ) break; if ( strlen(trim(${$sell})) == 0 || strlen(trim(${$qt})) == 0 || ${$qt}==0 || ${$sell}==0) continue; $tmp1=bcmul(${$sell},${$qt}); $sum=bcadd($sum,$tmp1); } $r=round($sum,2); break; case 'TOTAL_VEN_TVAC': extract($p_array); $sum=0.0; bcscale(4); for ($i=0;$i<$nb_item;$i++) { $tva='e_march'.$i.'_tva_amount'; $tva_amount=0; /* if we do not use vat this var. is not set */ if ( isset(${$tva}) ) { $tva_amount=${$tva}; } $sell=${'e_march'.$i.'_price'}; $qt=${'e_quant'.$i}; $tot=bcmul($sell,$qt); $tot=bcadd($tot,$tva_amount); $sum=bcadd($sum,$tot); } $r=round($sum,2); break; case 'TOTAL_TVA': extract($p_array); $sum=0.0; for ($i=0;$i<$nb_item;$i++) { $tva='e_march'.$i.'_tva_amount'; if (! isset(${$tva})) $tva_amount=0.0; else $tva_amount=$ { $tva }; $sum+=$tva_amount; $sum=round($sum,2); } $r=$sum; break; case 'BON_COMMANDE': if ( isset($p_array['bon_comm'])) return $p_array['bon_comm']; else return ""; break; case 'PJ': if ( isset($p_array['e_pj'])) return $p_array['e_pj']; else return ""; case 'OTHER_INFO': if ( isset($p_array['other_info'])) return $p_array['other_info']; else return ""; break; case 'COMMENT': if ( isset($p_array['e_comm'])) return $p_array['e_comm']; break; case 'ACOMPTE': if ( isset($p_array['acompte'])) return $p_array['acompte']; return "0"; break; case 'STOCK_NAME': if ( ! isset ($p_array['repo'])) return ""; $ret=$this->db->get_value('select r_name from public.stock_repository where r_id=$1',array($p_array['repo'])); return $ret; case 'STOCK_ADRESS': if ( ! isset ($p_array['repo'])) return ""; $ret=$this->db->get_value('select r_adress from public.stock_repository where r_id=$1',array($p_array['repo'])); return $ret; case 'STOCK_COUNTRY': if ( ! isset ($p_array['repo'])) return ""; $ret=$this->db->get_value('select r_country from public.stock_repository where r_id=$1',array($p_array['repo'])); return $ret; case 'STOCK_CITY': if ( ! isset ($p_array['repo'])) return ""; $ret=$this->db->get_value('select r_city from public.stock_repository where r_id=$1',array($p_array['repo'])); return $ret; case 'STOCK_PHONE': if ( ! isset ($p_array['repo'])) return ""; $ret=$this->db->get_value('select r_phone from public.stock_repository where r_id=$1',array($p_array['repo'])); return $ret; case 'TITLE': $title=HtmlInput::default_value_request("ag_title", ""); return $title; } /* * retrieve the value of ATTR for e_march */ if (preg_match('/^ATTR/', $p_tag) == 1) { // Retrieve f_id if ( isset ($p_array['e_march'.$this->counter])) { $id = $p_array['e_march' . $this->counter]; $r=$this->replace_special_tag($id,$p_tag); } } /* * retrieve the value of ATTR for e_march */ if (preg_match('/^BENEFATTR/', $p_tag) == 1) { $qcode=isset($p_array['qcode_benef'])?$p_array['qcode_benef']:''; // Retrieve f_id $r=$this->replace_special_tag($qcode,$p_tag); } if (preg_match('/^CUSTATTR/', $p_tag) == 1) { if ( isset($p_array['qcode_dest']) || isset($p_array['e_client']) ) { $qcode=(isset($p_array['qcode_dest']))?$p_array['qcode_dest']:$p_array['e_client']; $r=$this->replace_special_tag($qcode,$p_tag); } } return $r; } /*!\brief remove a row from the table document, the lob object is not deleted * because can be linked elsewhere */ function remove() { $d_lob=$this->db->get_value('select d_lob from document where d_id=$1', array($this->d_id)); $sql='delete from document where d_id='.$this->d_id; $this->db->exec_sql($sql); if ( $d_lob != 0 ) $this->db->lo_unlink($d_lob); } /*!\brief Move a document from the table document into the concerned row * the document is not copied : it is only a link * * \param $p_internal internal code * */ function MoveDocumentPj($p_internal) { $sql="update jrn set jr_pj=$1,jr_pj_name=$2,jr_pj_type=$3 where jr_internal=$4"; $this->db->exec_sql($sql,array($this->d_lob,$this->d_filename,$this->d_mimetype,$p_internal)); // clean the table document $sql='delete from document where d_id='.$this->d_id; $this->db->exec_sql($sql); } /** *Replace a special tag *TAGxxxx with the value from fiche_detail, the xxxx * is the ad_value * @param $p_qcode qcode of the card * @param $p_tag tag to parse * @return the ad_value contained in fiche_detail or for the type "select" the * label */ function replace_special_tag($p_qcode, $p_tag) { // check if the march exists if ($p_qcode == "") return ""; $f = new Fiche($this->db); $found = $f->get_by_qcode($p_qcode, false); // if not found exit if ($found == 1) return ""; // get the ad_id $attr=preg_replace("/^.*ATTR/","",$p_tag); if (isNumber($attr) == 0) return ""; $ad_type=$this->db->get_value("select ad_type from attr_def where ad_id=$1",array($attr)); // get ad_value $ad_value=$this->db->get_value("select ad_value from fiche_detail where f_id=$1 and ad_id=$2",array($f->id,$attr)); // if ad_id is type select execute select and get value if ( $ad_type=="select") { $sql=$this->db->get_value("select ad_extra from attr_def where ad_id=$1",array($attr)); $array= $this->db->make_array($sql); for ($a=0;$adb->exec_sql('update document set d_description = $1 where d_id=$2', array($p_desc,$this->d_id)); } }