Skip to content
Snippets Groups Projects
accountancyexport.class.php 13.3 KiB
Newer Older
Florian Henry's avatar
Florian Henry committed
<?php
 * Copyright (C) 2007-2012	Laurent Destailleur	<eldy@users.sourceforge.net>
 * Copyright (C) 2014		Juanjo Menent		<jmenent@2byte.es>
 * Copyright (C) 2015		Florian Henry		<florian.henry@open-concept.pro>
 * Copyright (C) 2015		Raphaël Doursenaud	<rdoursenaud@gpcsolutions.fr>
 * Copyright (C) 2016		Pierre-Henry Favre	<phf@atm-consulting.fr>
 * Copyright (C) 2016-2017	Alexandre Spangaro	<aspangaro@zendsi.com>
Florian Henry's avatar
Florian Henry committed
 *
 * 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
Florian Henry's avatar
Florian Henry committed
 * 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/accountancy/class/accountancyexport.class.php
 * \ingroup		Advanced accountancy
 * \brief 		Class accountancy export
Florian Henry's avatar
Florian Henry committed
 */

/**
 * Class AccountancyExport
 *
 * Manage the different format accountancy export
 */
Laurent Destailleur's avatar
Laurent Destailleur committed

Florian Henry's avatar
Florian Henry committed
require_once DOL_DOCUMENT_ROOT . '/core/lib/functions.lib.php';
Laurent Destailleur's avatar
Laurent Destailleur committed

Florian Henry's avatar
Florian Henry committed
class AccountancyExport
{
	/**
Laurent Destailleur's avatar
Laurent Destailleur committed
	 * @var Type of export. Defined by $conf->global->ACCOUNTING_EXPORT_MODELCSV
Florian Henry's avatar
Florian Henry committed
	 */
Laurent Destailleur's avatar
Laurent Destailleur committed
	public static $EXPORT_TYPE_NORMAL = 1;     // Classic CSV
	public static $EXPORT_TYPE_CEGID = 2;
	public static $EXPORT_TYPE_COALA = 3;
	public static $EXPORT_TYPE_BOB50 = 4;
	public static $EXPORT_TYPE_CIEL = 5;
	public static $EXPORT_TYPE_QUADRATUS = 6;
	public static $EXPORT_TYPE_EBP = 7;
florian HENRY's avatar
florian HENRY committed
	public static $EXPORT_TYPE_COGILOG = 8;
	public static $EXPORT_TYPE_AGIRIS = 9;
Florian Henry's avatar
Florian Henry committed

	/**
Florian Henry's avatar
Florian Henry committed
	 * @var string[] Error codes (or messages)
	 */
	public $errors = array ();
Florian Henry's avatar
Florian Henry committed

	/**
Florian Henry's avatar
Florian Henry committed
	 * @var string Separator
	 */
	public $separator = '';

	/**
Florian Henry's avatar
Florian Henry committed
	 * @var string End of line
	 */
	public $end_line = '';

	/**
	 * Constructor
	 *
	 * @param DoliDb $db Database handler
	 */
	public function __construct(DoliDB &$db) {
Florian Henry's avatar
Florian Henry committed
		global $conf;

		$this->db = &$db;
		$this->separator = $conf->global->ACCOUNTING_EXPORT_SEPARATORCSV;
		$this->end_line = "\n";
	}

	/**
Laurent Destailleur's avatar
Laurent Destailleur committed
	 * Array wit all export type available (key + label)
Florian Henry's avatar
Florian Henry committed
	 *
	 * @return array of type
	 */
	public static function getType() {
Florian Henry's avatar
Florian Henry committed
		global $langs;

		return array (
				self::$EXPORT_TYPE_NORMAL => $langs->trans('Modelcsv_normal'),
				self::$EXPORT_TYPE_CEGID => $langs->trans('Modelcsv_CEGID'),
				self::$EXPORT_TYPE_COALA => $langs->trans('Modelcsv_COALA'),
				self::$EXPORT_TYPE_BOB50 => $langs->trans('Modelcsv_bob50'),
				self::$EXPORT_TYPE_CIEL => $langs->trans('Modelcsv_ciel'),
				self::$EXPORT_TYPE_QUADRATUS => $langs->trans('Modelcsv_quadratus'),
				self::$EXPORT_TYPE_EBP => $langs->trans('Modelcsv_ebp'),
florian HENRY's avatar
florian HENRY committed
				self::$EXPORT_TYPE_COGILOG => $langs->trans('Modelcsv_cogilog'),
				self::$EXPORT_TYPE_AGIRIS => $langs->trans('Modelcsv_agiris')
Florian Henry's avatar
Florian Henry committed
		);
	}

	/**
	 * Download the export
	 *
	 * @return void
	 */
	public static function downloadFile() {
Florian Henry's avatar
Florian Henry committed
		global $conf;
		$journal = 'bookkepping';
		include DOL_DOCUMENT_ROOT . '/accountancy/tpl/export_journal.tpl.php';
	}

	/**
	 * Function who chose which export to use with the default config
	 *
Florian Henry's avatar
Florian Henry committed
	 * @param unknown $TData data
Florian Henry's avatar
Florian Henry committed
	 */
	public function export(&$TData) {
Florian Henry's avatar
Florian Henry committed
		global $conf, $langs;

florian HENRY's avatar
florian HENRY committed
		self::downloadFile();

Florian Henry's avatar
Florian Henry committed
		switch ($conf->global->ACCOUNTING_EXPORT_MODELCSV) {
			case self::$EXPORT_TYPE_NORMAL :
Florian Henry's avatar
Florian Henry committed
				$this->exportNormal($TData);
				break;
			case self::$EXPORT_TYPE_CEGID :
Florian Henry's avatar
Florian Henry committed
				$this->exportCegid($TData);
				break;
			case self::$EXPORT_TYPE_COALA :
Florian Henry's avatar
Florian Henry committed
				$this->exportCoala($TData);
				break;
			case self::$EXPORT_TYPE_BOB50 :
Florian Henry's avatar
Florian Henry committed
				$this->exportBob50($TData);
				break;
			case self::$EXPORT_TYPE_CIEL :
Florian Henry's avatar
Florian Henry committed
				$this->exportCiel($TData);
				break;
			case self::$EXPORT_TYPE_QUADRATUS :
Florian Henry's avatar
Florian Henry committed
				$this->exportQuadratus($TData);
				break;
			case self::$EXPORT_TYPE_EBP :
				$this->exportEbp($TData);
				break;
florian HENRY's avatar
florian HENRY committed
			case self::$EXPORT_TYPE_COGILOG :
				$this->exportCogilog($TData);
				break;
			case self::$EXPORT_TYPE_AGIRIS :
				$this->exportAgiris($TData);
				break;
Laurent Destailleur's avatar
Laurent Destailleur committed
			default:
Florian Henry's avatar
Florian Henry committed
				$this->errors[] = $langs->trans('accountancy_error_modelnotfound');
				break;
		}
	}

	/**
	 * Export format : Normal
	 *
florian HENRY's avatar
florian HENRY committed
	 * @param array $objectLines data
Florian Henry's avatar
Florian Henry committed
	 *
Florian Henry's avatar
Florian Henry committed
	 * @return void
	 */
	public function exportNormal($objectLines) {
		global $conf;
		foreach ( $objectLines as $line ) {
			// Std export
			$date = dol_print_date($line->doc_date, $conf->global->ACCOUNTING_EXPORT_DATE);
			print $date . $this->separator;
			print $line->doc_ref . $this->separator;
			print length_accountg($line->numero_compte) . $this->separator;
			print length_accounta($line->subledger_account) . $this->separator;
			print price($line->debit) . $this->separator;
			print price($line->credit) . $this->separator;
			print $line->code_journal . $this->separator;
			print $this->end_line;
		}
Florian Henry's avatar
Florian Henry committed
	}

	/**
	 * Export format : CEGID
	 *
florian HENRY's avatar
florian HENRY committed
	 * @param array $objectLines data
Florian Henry's avatar
Florian Henry committed
	 *
Florian Henry's avatar
Florian Henry committed
	 * @return void
	 */
	public function exportCegid($objectLines) {
		foreach ( $objectLines as $line ) {
			$date = dol_print_date($line->doc_date, '%d%m%Y');
			$separator = ";";

			print $date . $separator;
			print $line->code_journal . $separator;
			print length_accountg($line->numero_compte) . $separator;
			print length_accounta($line->subledger_account) . $separator;
			print $line->sens . $separator;
			print price($line->montant) . $separator;
			print $line->label_operation . $separator;
			print $this->end_line;
		}
Florian Henry's avatar
Florian Henry committed
	}

florian HENRY's avatar
florian HENRY committed
	/**
	 * Export format : COGILOG
	 *
	 * @param array $objectLines data
	 *
	 * @return void
	 */
	public function exportCogilog($objectLines) {
		foreach ( $objectLines as $line ) {
			$date = dol_print_date($line->doc_date, '%d%m%Y');

			print $line->code_journal . $this->separator;
			print $date . $this->separator;
			print $line->piece_num . $this->separator;
			print length_accountg($line->numero_compte) . $this->separator;
			print '' . $this->separator;
			print $line->label_operation . $this->separator;
florian HENRY's avatar
florian HENRY committed
			print $date . $this->separator;
			if ($line->sens=='D') {
				print price($line->montant) . $this->separator;
				print '' . $this->separator;
			}elseif ($line->sens=='C') {
				print '' . $this->separator;
				print price($line->montant) . $this->separator;
			}
			print $line->doc_ref . $this->separator;
			print $line->label_operation . $this->separator;
florian HENRY's avatar
florian HENRY committed
			print $this->end_line;
		}
	}

Florian Henry's avatar
Florian Henry committed
	/**
	 * Export format : COALA
	 *
florian HENRY's avatar
florian HENRY committed
	 * @param array $objectLines data
Florian Henry's avatar
Florian Henry committed
	 *
Florian Henry's avatar
Florian Henry committed
	 * @return void
	 */
	public function exportCoala($objectLines) {
		// Coala export
		foreach ( $objectLines as $line ) {
			$date = dol_print_date($line->doc_date, '%d/%m/%Y');
			print $date . $this->separator;
			print $line->code_journal . $this->separator;
			print length_accountg($line->numero_compte) . $this->separator;
			print $line->piece_num . $this->separator;
			print $line->doc_ref . $this->separator;
			print price($line->debit) . $this->separator;
			print price($line->credit) . $this->separator;
			print 'E' . $this->separator;
			print length_accountg($line->subledger_account) . $this->separator;
			print $this->end_line;
		}
Florian Henry's avatar
Florian Henry committed
	}

	/**
	 * Export format : BOB50
	 *
florian HENRY's avatar
florian HENRY committed
	 * @param array $objectLines data
Florian Henry's avatar
Florian Henry committed
	 *
Florian Henry's avatar
Florian Henry committed
	 * @return void
	 */
	public function exportBob50($objectLines) {

		// Bob50
		foreach ( $objectLines as $line ) {
			print $line->piece_num . $this->separator;
			$date = dol_print_date($line->doc_date, '%d/%m/%Y');
			print $date . $this->separator;

			if (empty($line->subledger_account)) {
				print 'G' . $this->separator;
				print length_accounta($line->numero_compte) . $this->separator;
			} else {
				if (substr($line->numero_compte, 0, 3) == '411') {
					print 'C' . $this->separator;
				}
				if (substr($line->numero_compte, 0, 3) == '401') {
					print 'F' . $this->separator;
				}
				print length_accountg($line->subledger_account) . $this->separator;
			}

			print price($line->debit) . $this->separator;
			print price($line->credit) . $this->separator;
			print dol_trunc($line->label_operation, 32) . $this->separator;
			print $this->end_line;
		}
Florian Henry's avatar
Florian Henry committed
	}

	/**
	 * Export format : CIEL
	 *
florian HENRY's avatar
florian HENRY committed
	 * @param array $TData data
Florian Henry's avatar
Florian Henry committed
	 *
Florian Henry's avatar
Florian Henry committed
	 * @return void
	 */
	public function exportCiel(&$TData) {
Florian Henry's avatar
Florian Henry committed
		global $conf;

florian HENRY's avatar
florian HENRY committed
		$this->end_line ="\r\n";

		$date_ecriture = dol_print_date(dol_now(), $conf->global->ACCOUNTING_EXPORT_DATE); // format must be yyyymmdd
		foreach ( $TData as $data ) {
Florian Henry's avatar
Florian Henry committed
			$code_compta = $data->numero_compte;
			if (! empty($data->subledger_account))
				$code_compta = $data->subledger_account;
Florian Henry's avatar
Florian Henry committed

			$Tab = array ();
Florian Henry's avatar
Florian Henry committed
			$Tab['num_ecriture'] = str_pad($i, 5);
			$Tab['code_journal'] = str_pad($data->code_journal, 2);
			$Tab['date_ecriture'] = $date_ecriture;
			$Tab['date_ope'] = dol_print_date($data->doc_date, $conf->global->ACCOUNTING_EXPORT_DATE);
			$Tab['num_piece'] = str_pad(self::trunc($data->piece_num, 12), 12);
			$Tab['num_compte'] = str_pad(self::trunc($code_compta, 11), 11);
			$Tab['libelle_ecriture'] = str_pad(self::trunc($data->doc_ref . $data->label_operation, 25), 25);
Florian Henry's avatar
Florian Henry committed
			$Tab['montant'] = str_pad(abs($data->montant), 13, ' ', STR_PAD_LEFT);
			$Tab['type_montant'] = str_pad($data->sens, 1);
			$Tab['vide'] = str_repeat(' ', 18);
			$Tab['intitule_compte'] = str_pad(self::trunc($data->label_operation, 34), 34);
Florian Henry's avatar
Florian Henry committed
			$Tab['end'] = 'O2003';

			$Tab['end_line'] = $this->end_line;

			print implode($Tab);
Florian Henry's avatar
Florian Henry committed
		}
	}

	/**
	 * Export format : Quadratus
	 *
florian HENRY's avatar
florian HENRY committed
	 * @param array $TData data
Florian Henry's avatar
Florian Henry committed
	 *
Florian Henry's avatar
Florian Henry committed
	 * @return void
	 */
	public function exportQuadratus(&$TData) {
Florian Henry's avatar
Florian Henry committed
		global $conf;

florian HENRY's avatar
florian HENRY committed
		$this->end_line ="\r\n";

Florian Henry's avatar
Florian Henry committed
		$date_ecriture = dol_print_date(time(), $conf->global->ACCOUNTING_EXPORT_DATE); // format must be ddmmyy
		foreach ( $TData as $data ) {
Florian Henry's avatar
Florian Henry committed
			$code_compta = $data->numero_compte;
			if (! empty($data->subledger_account))
				$code_compta = $data->subledger_account;
Florian Henry's avatar
Florian Henry committed

			$Tab = array ();
Florian Henry's avatar
Florian Henry committed
			$Tab['type_ligne'] = 'M';
			$Tab['num_compte'] = str_pad(self::trunc($code_compta, 8), 8);
			$Tab['code_journal'] = str_pad(self::trunc($data->code_journal, 2), 2);
			$Tab['folio'] = '000';
			$Tab['date_ecriture'] = $date_ecriture;
			$Tab['filler'] = ' ';
			$Tab['libelle_ecriture'] = str_pad(self::trunc($data->doc_ref . ' ' . $data->label_operation, 20), 20);
Florian Henry's avatar
Florian Henry committed
			$Tab['sens'] = $data->sens; // C or D
			$Tab['signe_montant'] = '+';
			$Tab['montant'] = str_pad(abs($data->montant), 12, '0', STR_PAD_LEFT); // TODO manage negative amount
Florian Henry's avatar
Florian Henry committed
			$Tab['contrepartie'] = str_repeat(' ', 8);
			if (! empty($data->date_echeance))
				$Tab['date_echeance'] = dol_print_date($data->date_echeance, $conf->global->ACCOUNTING_EXPORT_DATE);
			else
				$Tab['date_echeance'] = '000000';
Florian Henry's avatar
Florian Henry committed
			$Tab['lettrage'] = str_repeat(' ', 5);
			$Tab['num_piece'] = str_pad(self::trunc($data->piece_num, 5), 5);
			$Tab['filler2'] = str_repeat(' ', 20);
			$Tab['num_piece2'] = str_pad(self::trunc($data->piece_num, 8), 8);
			$Tab['devis'] = str_pad($conf->currency, 3);
			$Tab['code_journal2'] = str_pad(self::trunc($data->code_journal, 3), 3);
			$Tab['filler3'] = str_repeat(' ', 3);
			$Tab['libelle_ecriture2'] = str_pad(self::trunc($data->doc_ref . ' ' . $data->label_operation, 32), 32);
Florian Henry's avatar
Florian Henry committed
			$Tab['num_piece3'] = str_pad(self::trunc($data->piece_num, 10), 10);
			$Tab['filler4'] = str_repeat(' ', 73);

			$Tab['end_line'] = $this->end_line;

			print implode($Tab);
		}
	}

florian HENRY's avatar
florian HENRY committed
	 * @param array $objectLines data
	 *
	 * @return void
	 */
	public function exportEbp($objectLines) {

		$this->separator = ',';

		foreach ( $objectLines as $line ) {

			$date = dol_print_date($line->doc_date, '%d%m%Y');

			print $line->id . $this->separator;
			print $date . $this->separator;
			print $line->code_journal . $this->separator;
			print length_accountg($line->numero_compte) . $this->separator;
			print substr(length_accountg($line->numero_compte),0,2) . $this->separator;
			print '"'.dol_trunc($line->label_operation,40,'right','UTF-8',1).'"' . $this->separator;
Alexandre SPANGARO's avatar
Alexandre SPANGARO committed
			print '"'.dol_trunc($line->piece_num,15,'right','UTF-8',1).'"'.$this->separator;
			print price2num($line->montant).$this->separator;
			print $line->sens.$this->separator;
			print $date . $this->separator;
			print 'EUR';
			print $this->end_line;
		}
	}


	 * Export format : Agiris Isacompta
	 *
	 * @param array $objectLines data
	 *
	 * @return void
	 */
	public function exportAgiris($objectLines) {

		$this->separator = ';';

		foreach ( $objectLines as $line ) {

			$date = dol_print_date($line->doc_date, '%d%m%Y');

			print $line->piece_num . $this->separator;
			print $line->label_operation . $this->separator;
			print $date . $this->separator;
			print $line->label_operation . $this->separator;

			if (empty($line->subledger_account)) {
				print length_accountg($line->numero_compte) . $this->separator;
			} else {
				print length_accounta($line->subledger_account) . $this->separator;
			print $line->doc_ref . $this->separator;
			print price($line->debit) . $this->separator;
			print price($line->credit) . $this->separator;
			print price($line->montant).$this->separator;
			print $line->sens.$this->separator;
			print $line->code_journal;
Florian Henry's avatar
Florian Henry committed
	/**
	 *
Florian Henry's avatar
Florian Henry committed
	 * @param unknown $str data
	 * @param integer $size data
Florian Henry's avatar
Florian Henry committed
	 */
	public static function trunc($str, $size) {
Florian Henry's avatar
Florian Henry committed
		return dol_trunc($str, $size, 'right', 'UTF-8', 1);
	}
}