forked from extern/egroupware
search etemplates first under /etemplates in vfs and then in real filesystem, allows to overwrite templates on a per instance base, stylite.merge stream-wrapper can be used to mount templates editable into vfs
This commit is contained in:
parent
928c562797
commit
2479d85c77
@ -162,7 +162,7 @@ class etemplate_new extends etemplate_widget_template
|
|||||||
$dom_id = str_replace('.','-',$this->dom_id);
|
$dom_id = str_replace('.','-',$this->dom_id);
|
||||||
$load_array = array(
|
$load_array = array(
|
||||||
'name' => $this->name,
|
'name' => $this->name,
|
||||||
'url' => $GLOBALS['egw_info']['server']['webserver_url'].$this->rel_path.'?'.filemtime(EGW_SERVER_ROOT.$this->rel_path),
|
'url' => etemplate_widget_template::rel2url($this->rel_path),
|
||||||
'data' => $data,
|
'data' => $data,
|
||||||
'DOMNodeID' => $dom_id,
|
'DOMNodeID' => $dom_id,
|
||||||
);
|
);
|
||||||
|
@ -88,7 +88,7 @@ class etemplate_widget_template extends etemplate_widget
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
$reader = new XMLReader();
|
$reader = new XMLReader();
|
||||||
if (!$reader->open(EGW_SERVER_ROOT.$path)) return false;
|
if (!$reader->open(self::rel2path($path))) return false;
|
||||||
|
|
||||||
while($reader->read())
|
while($reader->read())
|
||||||
{
|
{
|
||||||
@ -112,13 +112,15 @@ class etemplate_widget_template extends etemplate_widget
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const VFS_TEMPLATE_PATH = '/etemplates';
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get path/URL relative to EGroupware install of a template
|
* Get path/URL relative to EGroupware install of a template of full vfs url
|
||||||
*
|
*
|
||||||
* @param string $name
|
* @param string $name
|
||||||
* @param string $template_set=null default try template-set from user and if not found "default"
|
* @param string $template_set=null default try template-set from user and if not found "default"
|
||||||
* @param string $version=''
|
* @param string $version=''
|
||||||
* @return string|boolean path of template xml file or false if not found
|
* @return string path of template xml file or null if not found
|
||||||
*/
|
*/
|
||||||
public static function relPath($name, $template_set=null, $version='')
|
public static function relPath($name, $template_set=null, $version='')
|
||||||
{
|
{
|
||||||
@ -128,18 +130,70 @@ class etemplate_widget_template extends etemplate_widget
|
|||||||
{
|
{
|
||||||
$template_set = $GLOBALS['egw_info']['user']['preferences']['common']['template_set'];
|
$template_set = $GLOBALS['egw_info']['user']['preferences']['common']['template_set'];
|
||||||
}
|
}
|
||||||
$path = '/'.$app.'/templates/'.$template_set.'/'.$rest.'.xet';
|
$template_path = '/'.$app.'/templates/'.$template_set.'/'.$rest.'.xet';
|
||||||
|
$default_path = '/'.$app.'/templates/default/'.$rest.'.xet';
|
||||||
|
|
||||||
if (!file_exists(EGW_SERVER_ROOT.$path)) // try default
|
foreach(array(egw_vfs::PREFIX.self::VFS_TEMPLATE_PATH, EGW_SERVER_ROOT) as $prefix)
|
||||||
{
|
{
|
||||||
$path = '/'.$app.'/templates/default/'.$rest.'.xet';
|
if (file_exists($prefix.$template_path))
|
||||||
|
{
|
||||||
if (!file_exists(EGW_SERVER_ROOT.$path)) $path = false;
|
$path = $template_path;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (file_exists($prefix.$default_path))
|
||||||
|
{
|
||||||
|
$path = $default_path;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// for a vfs template path we keep the prefix, to be able to distinquish between real filesystem and vfs
|
||||||
|
if (isset($path) && $prefix !== EGW_SERVER_ROOT)
|
||||||
|
{
|
||||||
|
$path = $prefix.$path;
|
||||||
}
|
}
|
||||||
//error_log(__METHOD__."('$name', '$template_set') returning ".array2string($path));
|
//error_log(__METHOD__."('$name', '$template_set') returning ".array2string($path));
|
||||||
return $path;
|
return $path;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert relative template path from relPath to an absolute path
|
||||||
|
*
|
||||||
|
* @param string $path
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public static function rel2path($path)
|
||||||
|
{
|
||||||
|
if ($path[0] === '/')
|
||||||
|
{
|
||||||
|
$path = EGW_SERVER_ROOT.$path;
|
||||||
|
}
|
||||||
|
return $path;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Convert relative template path from relPath to an url incl. cache-buster modification time postfix
|
||||||
|
*
|
||||||
|
* @param string $path
|
||||||
|
* @return string url
|
||||||
|
*/
|
||||||
|
public static function rel2url($path)
|
||||||
|
{
|
||||||
|
if ($path)
|
||||||
|
{
|
||||||
|
if ($path[0] === '/')
|
||||||
|
{
|
||||||
|
$url = $GLOBALS['egw_info']['server']['webserver_url'].$path.'?'.filemtime(self::rel2path($path));
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// no mtime postfix, as our WebDAV treats ? literal and not ignore them like Apache for static files!
|
||||||
|
$url = egw::link(egw_vfs::download_url($path));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
//error_log(__METHOD__."('$path') returning $url");
|
||||||
|
return $url;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Run method on all children
|
* Run method on all children
|
||||||
*
|
*
|
||||||
@ -175,6 +229,7 @@ class etemplate_widget_template extends etemplate_widget
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
if ($GLOBALS['egw_info']['flags']['debug'] == 'etemplate_widget_template')
|
if ($GLOBALS['egw_info']['flags']['debug'] == 'etemplate_widget_template')
|
||||||
{
|
{
|
||||||
$name = isset($_GET['name']) ? $_GET['name'] : 'timesheet.edit';
|
$name = isset($_GET['name']) ? $_GET['name'] : 'timesheet.edit';
|
||||||
@ -187,3 +242,4 @@ if ($GLOBALS['egw_info']['flags']['debug'] == 'etemplate_widget_template')
|
|||||||
header('Content-Type: text/xml');
|
header('Content-Type: text/xml');
|
||||||
echo $template->toXml();
|
echo $template->toXml();
|
||||||
}
|
}
|
||||||
|
*/
|
Loading…
Reference in New Issue
Block a user