noalyss  Version-6.7.2
Public Member Functions | Static Public Member Functions | Data Fields
Document Class Reference

Class Document corresponds to the table document. More...

Public Member Functions

 anchor ()
 create and compute a string for reference the doc <A ...>
 blank ()
 insert a minimal document and set the d_id
 compute_filename ($pj, $filename)
 Document ($p_cn, $p_d_id=0)
 Generate ($p_array, $p_filename="")
 Generate the document, Call $this->Replace to replace tag by value.
 get ()
 Get complete all the data member thx info from the database.
 get_all ($ag_id)
 get all the document of a given action
 MoveDocumentPj ($p_internal)
 Move a document from the table document into the concerned row the document is not copied : it is only a link.
 ParseDocument ($p_dir, $p_file, $p_type, $p_array)
 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.
 remove ()
 remove a row from the table document, the lob object is not deleted because can be linked elsewhere
 Replace ($p_tag, $p_array)
 replace the TAG by the real value, this value can be into the database or in $_POST The possible tags are
 replace_special_tag ($p_qcode, $p_tag)
 Replace a special tag *TAGxxxx with the value from fiche_detail, the xxxx is the ad_value.
 SaveGenerated ($p_file)
 Save the generated Document.
 Send ()
 Get.
 update_description ($p_desc)
 Upload ($p_ag_id)
 Upload a file into document all the needed data are in $_FILES we don't increment the seq.

Static Public Member Functions

static insert_existing_document ($p_ag_id, $p_lob, $p_filename, $p_mimetype, $p_description="")
 Copy a existing OID (LOB) into the table document.

Data Fields

 $ag_id
 $d_description
 $d_filename
 $d_id
 $d_lob
 $d_mimetype
 $d_number
 $db
 $md_id

Detailed Description

Class Document corresponds to the table document.

Definition at line 32 of file class_document.php.


Member Function Documentation

create and compute a string for reference the doc <A ...>

a_ref

Returns:
a string

Definition at line 404 of file class_document.php.

References $r, and get().

    {
        if ( $this->d_id == 0 )
            return '';
        $image='<IMG SRC="image/insert_table.gif" title="'.$this->d_filename.'" border="0">';
        $r="";
        $r='<A class="mtitle" HREF="show_document.php?d_id='.$this->d_id.'&'.dossier::get().'">'.$image.'</A>';
        return $r;
    }

insert a minimal document and set the d_id

Definition at line 53 of file class_document.php.

References $sql, ag_id, and db.

    {
        $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);

    }
Document::compute_filename ( pj,
filename 
)

Definition at line 65 of file class_document.php.

References $filename.

Referenced by Generate().

        {
                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;
        }
Document::Document ( p_cn,
p_d_id = 0 
)

Definition at line 46 of file class_document.php.

References db.

Referenced by get_all(), and SaveGenerated().

    {
        $this->db=$p_cn;
        $this->d_id=$p_d_id;
    }
Document::Generate ( p_array,
p_filename = "" 
)

Generate the document, Call $this->Replace to replace tag by value.

Parameters:
p_arraycontains the data normally it is the $_POST
containsthe new filename
Returns:
an array : the url where the generated doc can be found, the name of the file and his mimetype

Definition at line 86 of file class_document.php.

References $_ENV, $dirname, $filename, $p_array, $res, $Res, $ret, $row, $type, compute_filename(), db, echo, echo_warning(), exit, Database\fetch_array(), get(), ParseDocument(), and SaveGenerated().

    {
        // 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)
              {
                echo __FILE__.":".__LINE__."cannot recreate zip";
                exit;
              }
            $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='<A class="mtitle" HREF="show_document.php?d_id='.$this->d_id.'&'.dossier::get().'">Document g&eacute;n&eacute;r&eacute;</A>';
        @rmdir($dirname);
        return $ret;
    }

Get complete all the data member thx info from the database.

Definition at line 478 of file class_document.php.

References $ret, $row, $sql, ag_id, db, Database\fetch_array(), and Database\num_row().

Referenced by anchor(), and Generate().

    {
        $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'];

    }
Document::get_all ( ag_id)

get all the document of a given action

Parameters:
$ag_idthe ag_id from action::ag_id (primary key)
Returns:
an array of objects document or an empty array if nothing found

Definition at line 456 of file class_document.php.

References $a, $ag_id, $doc, $res, $row, db, and Document().

    {
        $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;$i<sizeof($res); $i++ )
        {
            $doc=new Document($this->db);
            $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;
    }
static Document::insert_existing_document ( p_ag_id,
p_lob,
p_filename,
p_mimetype,
p_description = "" 
) [static]

Copy a existing OID (LOB) into the table document.

Note:
use of global variable $cn which is the db connx to the current folder
Parameters:
type$p_ag_idFollow_Up::ag_id
type$p_loboid of existing document
type$p_filenamefilename of existing document
type$p_mimetypemimetype of existing document
type$p_descriptionDescription of existing document (default empty)

Definition at line 391 of file class_document.php.

References $cn, and $sql.

    {
        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));
    }
Document::MoveDocumentPj ( p_internal)

Move a document from the table document into the concerned row the document is not copied : it is only a link.

Parameters:
$p_internalinternal code

Definition at line 1205 of file class_document.php.

References $sql, and db.

    {
        $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);


    }
Document::ParseDocument ( p_dir,
p_file,
p_type,
p_array 
)

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.

ParseDocument

Parameters:
$p_dirdirectory name
$p_filefilename
$p_typeFor the OOo document the tag are &lt and &gt instead of < and >
$p_arrayvariable from $_POST
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

Definition at line 181 of file class_document.php.

References $f, $p_array, $ret, $tag, $value, echo, exit, and Replace().

Referenced by Generate().

    {

        /*!\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 )
            {
                echo "Ne peut pas créer le répertoire ".$temp_dir;
                exit();
            }
        }
        // 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 ";
            exit();
        }
        if ( $output_file == false)
        {
            echo "ne peut pas ouvrir le fichier de sortie";
            exit();
        }
        // compute the regex
        if ( $p_type=='OOo')
        {
            $regex="/=*&lt;&lt;[A-Z]+_*[A-Z]*_*[A-Z]*_*[A-Z]*_*[0-9]*&gt;&gt;/i";
            $lt="&lt;";
            $gt="&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"><text:p>'.$pattern.'/';
                            $replaced='office:value-type="float" office:value="'.$value.'"><text:p>'.$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('&','&amp;',$value);
                            $value=str_replace('<','&lt;',$value);
                            $value=str_replace('>','&gt;',$value);
                            $value=str_replace('"','&quot;',$value);
                            $value=str_replace("'",'&apos;',$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);
        }


    }

remove a row from the table document, the lob object is not deleted because can be linked elsewhere

Definition at line 1190 of file class_document.php.

References $d_lob, $sql, and db.

    {
      $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);
    }
Document::Replace ( p_tag,
p_array 
)

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_TVA_AMOUNT]
  • [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]
Parameters:
$p_tagTAG
$p_arraydata from $_POST
Returns:
String which must replace the tag

Definition at line 551 of file class_document.php.

References $act, $date, $f, $g_parameter, $id, $p_array, $poste, $qcode, $r, $ret, $tot, ag_id, db, HtmlInput\default_value_request(), format_date(), replace_special_tag(), and trim().

Referenced by ParseDocument().

    {
                global $g_parameter;
        $p_tag=strtoupper($p_tag);
        $p_tag=str_replace('=','',$p_tag);
        $r="Tag inconnu";
        static $counter=0;
        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_TVA_AMOUNT]
             *  - [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':
            $counter++;
            $r='';
            break;

        case 'VEN_ART_NAME':
            extract ($p_array);
            $id='e_march'.$counter;
            // check if the march exists
            if ( ! isset (${$id})) return "";
            // check that something is sold
            if ( ${'e_march'.$counter.'_price'} != 0 && ${'e_quant'.$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'.$counter."_label";
            // check if the march exists

            if (! isset (${$id}) || (isset (${$id}) && strlen(trim(${$id})) == 0))
                {
                    $id = 'e_march' . $counter;
                    // check if the march exists
                    if (!isset(${$id}))
                        $r= "";
                    else 
                    {
                    // check that something is sold
                        if (${'e_march' . $counter . '_price'} != 0 && ${'e_quant' . $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'.$counter.'_label'};
            break;

        case 'VEN_ART_PRICE':
            extract ($p_array);
            $id='e_march'.$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'.$counter.'_tva_id';
            if ( !isset (${$id}) ) return "";
            if ( ${$id} == -1 || ${$id}=='' ) return "";
            $march_id='e_march'.$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'.$counter.'_tva_id';
            if ( !isset (${$id}) ) return "";
            if ( ${$id} == -1 ) return "";
            $qt='e_quant'.$counter;
            $price='e_march'.$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'.$counter.'_tva_id';
            if ( !isset (${$id}) ) return "";
            $march_id='e_march'.$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':
            extract ($p_array);
            $qt='e_quant'.$counter;
            $price='e_march'.$counter.'_price' ;
            $tva='e_march'.$counter.'_tva_id';
            /* if we do not use vat this var. is not set */
            if ( !isset(${$tva}) ) return '';
            if ( !isset (${'e_march'.$counter}) ) return "";
            // check that something is sold
            if ( ${$price} == 0 || ${$qt} == 0
                    || strlen(trim( $price )) ==0
                    || strlen(trim($qt)) ==0)
                return "";
            $r=${'e_march'.$counter.'_tva_amount'};
            break;
            /* TVA automatically computed */
        case 'VEN_ART_TVA':
            extract ($p_array);
            $qt='e_quant'.$counter;
            $price='e_march'.$counter.'_price' ;
            $tva='e_march'.$counter.'_tva_id';
            if ( !isset (${'e_march'.$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'.$counter;
            $price='e_march'.$counter.'_price' ;
            $tva='e_march'.$counter.'_tva_id';
            if ( !isset (${'e_march'.$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'.$counter;
            if ( !isset (${$id}) ) return "";
            // check that something is sold
            if ( ${'e_march'.$counter.'_price'} == 0
                    || ${'e_quant'.$counter} == 0
                    || strlen(trim( ${'e_march'.$counter.'_price'} )) ==0
                    || strlen(trim(${'e_quant'.$counter})) ==0 )
                return "";
            $r=${$id};
            break;

        case 'VEN_HTVA':
            extract ($p_array);
            $id='e_march'.$counter.'_price' ;
            $quant='e_quant'.$counter;
            if ( !isset (${$id}) ) return "";

            // check that something is sold
            if ( ${'e_march'.$counter.'_price'} == 0 || ${'e_quant'.$counter} == 0
                    || strlen(trim( ${'e_march'.$counter.'_price'} )) ==0
                    || strlen(trim(${'e_quant'.$counter})) ==0)
                return "";
                        bcscale(4);
            $r=bcmul(${$id},${$quant});
                        $r=round($r,2);
            break;

        case 'VEN_TVAC':
            extract ($p_array);
            $id='e_march'.$counter.'_tva_amount' ;
            $price='e_march'.$counter.'_price' ;
            $quant='e_quant'.$counter;
            if ( ! isset(${'e_march'.$counter.'_price'})|| !isset(${'e_quant'.$counter}))     return "";
            // check that something is sold
            if ( ${'e_march'.$counter.'_price'} == 0 || ${'e_quant'.$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'.$counter]))
            {
                $id = $p_array['e_march' . $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;
    }
Document::replace_special_tag ( p_qcode,
p_tag 
)

Replace a special tag *TAGxxxx with the value from fiche_detail, the xxxx is the ad_value.

Parameters:
$p_qcodeqcode of the card
$p_tagtag to parse
Returns:
the ad_value contained in fiche_detail or for the type "select" the label

Definition at line 1224 of file class_document.php.

References $a, $array, $f, $sql, db, and isNumber().

Referenced by Replace().

    {
        // 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;$a<count ($array);$a++)
            {
                if ($array[$a]['value']==$ad_value)
                    return $array[$a]['label'];
            }

        }
        // if ad_id is not type select get value
        return $ad_value;
    }
Document::SaveGenerated ( p_file)

Save the generated Document.

SaveGenerated

Parameters:
$p_fileis the generated file
Returns:
0 if no error otherwise 1

Definition at line 309 of file class_document.php.

References $doc, $sql, ag_id, db, Document(), and echo.

Referenced by Generate().

    {
        // 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;
    }

Get.

Send the document

Definition at line 416 of file class_document.php.

References $_ENV, $file, $ret, $row, $tmp, db, echo, Database\fetch_array(), and Database\num_row().

    {
        // 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();

    }

Definition at line 1260 of file class_document.php.

References db.

    {
        $this->db->exec_sql('update document set d_description = $1 where d_id=$2',
                array($p_desc,$this->d_id));
    }
Document::Upload ( p_ag_id)

Upload a file into document all the needed data are in $_FILES we don't increment the seq.

Upload

Parameters:
$p_file: array containing by default $_FILES
Returns:

Definition at line 342 of file class_document.php.

References $_ENV, $name, $sql, and db.

    {
        // 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();

    }

Field Documentation

Document::$ag_id

$ag_id action_gestion.ag_id (pk)

Definition at line 36 of file class_document.php.

Referenced by get_all().

Document::$d_description

Description of the file

Definition at line 40 of file class_document.php.

Document::$d_filename

$d_filename

Definition at line 38 of file class_document.php.

Document::$d_id

$d_id Document id

Definition at line 35 of file class_document.php.

Document::$d_lob

$d_lob the oid of the lob

Definition at line 39 of file class_document.php.

Referenced by remove().

Document::$d_mimetype

$d_mimetype

Definition at line 37 of file class_document.php.

Document::$d_number

$d_number number of the document

Definition at line 41 of file class_document.php.

Document::$db

$db Database connexion

Definition at line 34 of file class_document.php.

Document::$md_id

$md_id document's template

Definition at line 42 of file class_document.php.


The documentation for this class was generated from the following file:
 All Data Structures Namespaces Files Functions Variables Enumerations