<?php
// This file defines a set of functions and an associative array.
// The key of the array corresponds to a header in the source
// import file and the value of the array item will be used in
// the creation of the output file.
//
// An exported Outlook file looks like this:
//
// Title<tab>First Name<tab>Middle Name<tab>Last Name<tab>...
// <tab>Patrick<tab><tab>Walsh<tab>...
//
// Where the first line explains each optional field.  This is what
// will be looked up in the key.
//
// The array need not be in any order and any fields not defined will
// not be transferred.  If the val='+', the value will be appended to
// the previous field and any text after the '+' will be appended
// before the value.  For example, the following would add a comma and
// a space between LastName and FirstName and store it in FullName:
//
//	array('LastName' => 'FullName','FirstName' => '+, ');
//
// Also start with a '#' symbol and a comma separated list will be
// turned into a number of the same entries.

  /* $Id: Import_from_Outlook_-_French,v 1.2 2004/04/27 02:57:03 milosch Exp $ */

	class import_conv
	{
		var $currentrecord = array(); //used for buffering to allow uid lines to go first
		var $id;
		var $type = 'csv';

		/* Thanks to ledruide for the Outlook fields */
		var $import = array(
			'Fonction' => 'title',
			'Prnom' => 'n_given',
			'Deuxime prnom' => 'n_middle',
			'Nom' => 'n_family',
			'Suffixe' => 'n_suffix',
			'Socit' => 'org_name',
			'Service' => 'org_unit',
			'Rue (bureau)' => 'adr_one_street',
			'Rue (bureau) 2' => 'address2',
			'Rue (bureau) 3' => 'address3',
			'Ville (bureau)' => 'adr_one_locality',
			'tat/Prov (bureau)' => 'adr_one_region',
			'Code postal (bureau)' => 'adr_one_postalcode',
			'Pays (bureau)' => 'adr_one_countryname',
			'Rue (domicile)' => 'adr_two_street',
			'Rue (domicile) 3' => '',
			'Rue (domicile) 3' => '',
			'Ville (domicile)' => 'adr_two_locality',
			'tat/Prov (domicile)' => 'adr_two_region',
			'Code postal (domicile)' => 'adr_two_postalcode',
			'Pays (domicile)' => 'adr_two_countryname',
			'Rue (autre)' => '',
			'Rue (autre) 2' => '',
			'Rue (autre) 3' => '',
			'Ville (autre)' => '',
			'tat/Prov (autre)' => '',
			'Code postal (autre)' => '',
			'Pays (autre)' => '',
			"Tlphone de l'assistant(e)" => 'tel_msg',
			'Tlcopie (bureau)' => 'tel_fax',
			'Tlphone (bureau)' => 'tel_work',
			'Tlphone 2 (bureau)' => 'ophone',
			'Rappel' => '',
			'Tlphone (voiture)' => 'tel_car',
			'Tlphone socit' => '',
			'Tlcopie (domicile)' => '',
			'Tlphone (domicile)' => 'tel_home',
			'Tlphone 2 (domicile)' => '',
			'RNIS' => 'tel_isdn',
			'Tl. mobile' => 'tel_cell',
			'Tlcopie (autre)' => '',
			'Tlphone (autre)' => '',
			'Rcepteur de radiomessagerie' => 'tel_pager',
			'Tlphone principal' => '',
			'Radio tlphone' => '',
			'Tlphone TDD/TTY' => '',
			'Tlex' => '',
			'Compte' => '',
			'Anniversaire de mariage ou fte' => '',
			"Nom de l'assistant(e)" => '',
			'Informations facturation' => '',
			'Anniversaire' => 'bday',
			'Catgories' => '',
			'Enfants' => '',
			'Adresse e-mail' => 'email',
			"Nom complet de l'adresse e-mail" => '',
			'Adresse e-mail 2' => 'email_home',
			"Nom complet de l'adresse e-mail 2" => '',
			'Adresse e-mail 3' => '',
			"Nom complet de l'adresse e-mail 3" => '',
			'Sexe' => '',
			'Code gouvernement' => '',
			'Passe-temps' => '',
			'Initiales' => '',
			'Mots cls' => '',
			'Langue' => '',
			'Lieu' => '',
			'Kilomtrage' => '',
			'Notes' => 'note',
			'Bureau' => '',
			"Numro d'identification de l'organisation" => '',
			'B.P.' => '',
			'Priv' => '',
			'Profession' => '',
			'Recommand par' => '',
			'Conjoint(e)' => '',
			'Utilisateur 1' => '',
			'Utilisateur 2' => '',
			'Utilisateur 3' => '',
			'Utilisateur 4' => '',
			'Page Web' => 'url'
		);

		function import_start_file($buffer)
		{
			return $buffer;
		}

		function import_start_record($buffer)
		{
			$top = array();
			++$this->id;
			$this->currentrecord = $top;
			return $buffer;
		}

		function import_new_attrib($buffer,$name,$value)
		{
			$value = trim($value);
			$value = str_replace('\n','<BR>',$value);
			$value = str_replace('\r','',$value);
			$this->currentrecord += array($name => $value);

			return $buffer;
		}

		function import_end_record($buffer)
		{
			$buffer[$this->id] = '';
			while(list($name, $value) = each($this->currentrecord))
			{
				$buffer[$this->id][$name] = $value;
				//echo '<br>'.$name.' => '.$value;
			}
			return $buffer;
		}

		function import_end_file($buffer,$access='private',$cat_id=0)
		{
			$contacts = CreateObject('phpgwapi.contacts');
			//echo '<br>';
			for($i=1;$i<=count($buffer);$i++)
			{
				while(list($name,$value) = @each($buffer[$i]))
				{
					//echo '<br>'.$i.': '.$name.' => '.$value;
					$entry[$i][$name] = $value;
				}
				$entry[$i]['email_type']      = 'INTERNET';
				$entry[$i]['email_home_type'] = 'INTERNET';
				$entry[$i]['adr_one_type']    = 'intl';
				$entry[$i]['adr_two_type']    = 'intl';
				$entry[$i]['fn'] = $entry[$i]['n_given'] . ' ' . $entry[$i]['n_family'];
				//echo '<br>';
				$contacts->add($GLOBALS['phpgw_info']['user']['account_id'],$entry[$i],$access,$cat_id);
			}
			$num = $i - 1;
			return lang('Successfully imported %1 records into your addressbook.',$num);
		}
	}
?>
