* Addressbook: ablity to mail (multiple) vCard via context menu

This commit is contained in:
Ralf Becker 2011-11-29 12:07:11 +00:00
parent 9db9804c14
commit 86577fa44e
3 changed files with 71 additions and 4 deletions

View File

@ -587,7 +587,15 @@ class addressbook_ui extends addressbook_bo
$this->prefs['document_dir'], $group, 'Insert in document', 'document_', $this->prefs['document_dir'], $group, 'Insert in document', 'document_',
$this->prefs['default_document'], $this->config['contact_export_limit'] $this->prefs['default_document'], $this->config['contact_export_limit']
); );
if ($GLOBALS['egw_info']['user']['apps']['felamimail'])
{
$actions['mail'] = array(
'caption' => lang('Mail VCard'),
'icon' => 'filemanager/mail_post_to',
'group' => $group,
'onExecute' => 'javaScript:adb_mail_vcard',
);
}
++$group; ++$group;
if (!($tid_filter == 'D' && !$GLOBALS['egw_info']['user']['apps']['admin'] && $this->config['history'] != 'userpurge')) if (!($tid_filter == 'D' && !$GLOBALS['egw_info']['user']['apps']['admin'] && $this->config['history'] != 'userpurge'))
{ {
@ -2194,7 +2202,19 @@ class addressbook_ui extends addressbook_bo
*/ */
function js() function js()
{ {
list($width,$height) = explode('x',egw_link::get_registry('felamimail','add_popup'));
return '<script LANGUAGE="JavaScript"> return '<script LANGUAGE="JavaScript">
function adb_mail_vcard(_action, _elems)
{
var link = "'.egw::link('/index.php',array('menuaction' => 'felamimail.uicompose.compose')).'";
for (var i = 0; i < _elems.length; i++)
{
link += "&preset[file][]="+encodeURIComponent("vfs://default/apps/addressbook/"+_elems[i].id+"/.entry");
}
'."egw_openWindowCentered2(link, '_blank', $width, $height, 'yes');".'
}
function adb_get_selection(form) function adb_get_selection(form)
{ {
var use_all = document.getElementById("exec[use_all]"); var use_all = document.getElementById("exec[use_all]");

View File

@ -114,6 +114,7 @@ class links_stream_wrapper extends links_stream_wrapper_parent
* This method is called in response to stat() calls on the URL paths associated with the wrapper. * This method is called in response to stat() calls on the URL paths associated with the wrapper.
* *
* Reimplemented from sqlfs, as we have to pass the value of check_extends_acl(), due to the lack of late static binding. * Reimplemented from sqlfs, as we have to pass the value of check_extends_acl(), due to the lack of late static binding.
* And to return vcard for url /apps/addressbook/$id/.entry
* *
* @param string $path * @param string $path
* @param int $flags holds additional flags set by the streams API. It can hold one or more of the following values OR'd together: * @param int $flags holds additional flags set by the streams API. It can hold one or more of the following values OR'd together:
@ -128,7 +129,28 @@ class links_stream_wrapper extends links_stream_wrapper_parent
*/ */
static function url_stat ( $url, $flags ) static function url_stat ( $url, $flags )
{ {
$ret = parent::url_stat($url,$flags,$eacl_check=self::check_extended_acl($url,egw_vfs::READABLE)); $eacl_check=self::check_extended_acl($url,egw_vfs::READABLE);
if ($eacl_check && substr($url,-7) == '/.entry' &&
(list($app) = array_slice(explode('/',$url),-3,1)) && $app === 'addressbook')
{
$ret = array(
'ino' => $info['fs_id'],
'name' => '.entry',
'mode' => self::MODE_FILE|egw_vfs::READABLE, // required by the stream wrapper
'size' => 1024, // fmail does NOT attach files with size 0!
'uid' => 0,
'gid' => 0,
'mtime' => time(),
'ctime' => time(),
'nlink' => 1,
// eGW addition to return some extra values
'mime' => $app == 'addressbook' ? 'text/vcard' : 'text/calendar',
);
}
else
{
$ret = parent::url_stat($url,$flags,$eacl_check);
}
if (self::DEBUG) error_log(__METHOD__."('$url', $flags) calling parent::url_stat(,,".array2string($eacl_check).') returning '.array2string($ret)); if (self::DEBUG) error_log(__METHOD__."('$url', $flags) calling parent::url_stat(,,".array2string($eacl_check).') returning '.array2string($ret));
return $ret; return $ret;
} }
@ -206,6 +228,7 @@ class links_stream_wrapper extends links_stream_wrapper_parent
* This method is called immediately after your stream object is created. * This method is called immediately after your stream object is created.
* *
* Reimplemented from sqlfs to ensure self::url_stat is called, to fill sqlfs stat cache with our eacl! * Reimplemented from sqlfs to ensure self::url_stat is called, to fill sqlfs stat cache with our eacl!
* And to return vcard for url /apps/addressbook/$id/.entry
* *
* @param string $url URL that was passed to fopen() and that this object is expected to retrieve * @param string $url URL that was passed to fopen() and that this object is expected to retrieve
* @param string $mode mode used to open the file, as detailed for fopen() * @param string $mode mode used to open the file, as detailed for fopen()
@ -219,8 +242,25 @@ class links_stream_wrapper extends links_stream_wrapper_parent
function stream_open ( $url, $mode, $options, &$opened_path ) function stream_open ( $url, $mode, $options, &$opened_path )
{ {
// the following call is necessary to fill sqlfs_stream_wrapper::$stat_cache, WITH the extendes ACL! // the following call is necessary to fill sqlfs_stream_wrapper::$stat_cache, WITH the extendes ACL!
self::url_stat($url,0); $stat = self::url_stat($url,0);
//error_log(__METHOD__."('$url', '$mode', $options) stat=".array2string($stat));
if ($stat && $mode[0] == 'r' && substr($url,-7) === '/.entry')
{
list($id) = array_slice(explode('/',$url),-2,1);
$name = md5($url);
$ab_vcard = new addressbook_vcal('addressbook','text/vcard');
if (!($GLOBALS[$name] =& $ab_vcard->getVCard($id)))
{
error_log(__METHOD__."('$url', '$mode', $options) addressbook_vcal::getVCard($id) returned false!");
return false;
}
//error_log(__METHOD__."('$url', '$mode', $options) addressbook_vcal::getVCard($id) returned ".$GLOBALS[$name]);
require_once(EGW_API_INC.'/class.global_stream_wrapper.inc.php');
$this->opened_stream = fopen('global://'.$name,'r');
unset($GLOBALS[$name]); // unset it, so it does not use up memory, once the stream is closed
return true;
}
return parent::stream_open($url,$mode,$options,$opened_path); return parent::stream_open($url,$mode,$options,$opened_path);
} }

View File

@ -114,6 +114,7 @@ class mime_magic
public static function mime2ext($type) public static function mime2ext($type)
{ {
$type = strtolower($type); $type = strtolower($type);
if (isset(self::$mime_alias_map[$type])) $type = self::$mime_alias_map[$type];
$key = array_search($type, self::$mime_extension_map); $key = array_search($type, self::$mime_extension_map);
if (empty($type) || $key === false) if (empty($type) || $key === false)
{ {
@ -391,7 +392,7 @@ class mime_magic
'ustar' => 'application/x-ustar', 'ustar' => 'application/x-ustar',
'vbs' => 'text/plain', //added by skwashd - for obvious reasons 'vbs' => 'text/plain', //added by skwashd - for obvious reasons
'vcd' => 'application/x-cdlink', 'vcd' => 'application/x-cdlink',
'vcf' => 'text/x-vcard', 'vcf' => 'text/vcard',
'vcs' => 'text/calendar', 'vcs' => 'text/calendar',
'vfb' => 'text/calendar', 'vfb' => 'text/calendar',
'vrml' => 'model/vrml', 'vrml' => 'model/vrml',
@ -426,6 +427,12 @@ class mime_magic
'z' => 'application/x-compress', 'z' => 'application/x-compress',
'zip' => 'application/zip', 'zip' => 'application/zip',
); );
/**
* Mapping some old formats to the newer form, or any other aliasing for mime-types
*/
static $mime_alias_map = array(
'text/x-vcard' => 'text/vcard',
);
/** /**
* @deprecated use static parameter mime_magic::$mime_extension_map * @deprecated use static parameter mime_magic::$mime_extension_map