2012-04-03 00:46:01 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* eGroupWare
|
|
|
|
*
|
|
|
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
|
|
|
* @package infolog
|
|
|
|
* @subpackage importexport
|
|
|
|
* @link http://www.egroupware.org
|
|
|
|
* @author Nathan Gray
|
|
|
|
* @copyright Nathan Gray
|
|
|
|
* @version $Id$
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* export iCal plugin of infolog
|
|
|
|
*/
|
|
|
|
class infolog_export_ical extends infolog_export_csv {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Exports records as defined in $_definition
|
|
|
|
*
|
|
|
|
* @param egw_record $_definition
|
|
|
|
*/
|
|
|
|
public function export( $_stream, importexport_definition $_definition) {
|
|
|
|
$options = $_definition->plugin_options;
|
|
|
|
$this->bo = new infolog_bo();
|
|
|
|
$boical = new infolog_ical();
|
2012-04-05 17:57:06 +02:00
|
|
|
$horde = new Horde_iCalendar();
|
2012-04-03 00:46:01 +02:00
|
|
|
|
|
|
|
$limit_exception = bo_merge::is_export_limit_excepted();
|
|
|
|
if (!$limit_exception) $export_limit = bo_merge::getExportLimit('infolog');
|
|
|
|
|
|
|
|
$ids = array();
|
|
|
|
$query = array();
|
|
|
|
switch($options['selection'])
|
|
|
|
{
|
|
|
|
case 'search':
|
|
|
|
$query = array_merge($GLOBALS['egw']->session->appsession('session_data','infolog'), $query);
|
|
|
|
// Fall through
|
|
|
|
case 'all':
|
|
|
|
$query['num_rows'] = $export_limit ? $export_limit : -1;
|
|
|
|
$query['start'] = 0;
|
|
|
|
$selection = $this->bo->search($query);
|
|
|
|
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
$ids = $selection = explode(',',$options['selection']);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2012-04-05 17:57:06 +02:00
|
|
|
$horde->clear();
|
2012-04-03 00:46:01 +02:00
|
|
|
foreach($selection as $_selection) {
|
|
|
|
$result = $boical->exportVTODO($_selection,'2.0','PUBLISH',false);
|
2012-04-05 17:57:06 +02:00
|
|
|
|
|
|
|
// infolog_ical doesn't allow a nice call to get just the VTODO
|
2012-04-03 00:46:01 +02:00
|
|
|
if($result)
|
|
|
|
{
|
2012-04-05 17:57:06 +02:00
|
|
|
$horde->parsevCalendar($result, 'VCALENDAR', 'utf-8', false);
|
2012-04-03 00:46:01 +02:00
|
|
|
}
|
|
|
|
}
|
2012-04-05 17:57:06 +02:00
|
|
|
fwrite($_stream, $horde->exportvCalendar());
|
2012-04-03 00:46:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* returns translated name of plugin
|
|
|
|
*
|
|
|
|
* @return string name
|
|
|
|
*/
|
|
|
|
public static function get_name() {
|
2012-04-05 17:57:06 +02:00
|
|
|
return lang('Infolog iCal export');
|
2012-04-03 00:46:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* returns translated (user) description of plugin
|
|
|
|
*
|
|
|
|
* @return string descriprion
|
|
|
|
*/
|
|
|
|
public static function get_description() {
|
|
|
|
return lang("Exports in iCal format.");
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* retruns file suffix for exported file
|
|
|
|
*
|
|
|
|
* @return string suffix
|
|
|
|
*/
|
|
|
|
public static function get_filesuffix() {
|
|
|
|
return 'ics';
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function get_mimetype() {
|
|
|
|
return 'text/infolog';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* return html for options.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function get_options_etpl() {
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* returns selectors of this plugin
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public function get_selectors_etpl() {
|
|
|
|
return array(
|
|
|
|
'name' => 'infolog.export_csv_selectors',
|
|
|
|
'content' => 'search'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|