forked from extern/egroupware
- improved caching of extensions (previously a reload was made if delete/show/list was called)
- call the writeLangFile function of the apps ui-layer if it exists
This commit is contained in:
parent
c74cecd2a3
commit
510dbb355e
@ -30,7 +30,7 @@
|
|||||||
'not_writeable' => "Error: webserver is not allowed to write into '%s' !!!",
|
'not_writeable' => "Error: webserver is not allowed to write into '%s' !!!",
|
||||||
'exported' => "eTemplate '%s' written to '%s'",
|
'exported' => "eTemplate '%s' written to '%s'",
|
||||||
'newer_version' => "newer version '%s' exists !!!",
|
'newer_version' => "newer version '%s' exists !!!",
|
||||||
'need_name' => 'Application name needed to write a langfile !!!'
|
'need_name' => 'Application name needed to write a langfile or dump the eTemplates !!!'
|
||||||
);
|
);
|
||||||
var $aligns = array(
|
var $aligns = array(
|
||||||
'' => 'Left',
|
'' => 'Left',
|
||||||
@ -86,7 +86,7 @@
|
|||||||
{
|
{
|
||||||
$msg .= $this->messages['not_found'];
|
$msg .= $this->messages['not_found'];
|
||||||
}
|
}
|
||||||
if ($this->extensions == '')
|
if (!is_array($this->extensions))
|
||||||
{
|
{
|
||||||
$this->extensions = $this->scan_for_extensions();
|
$this->extensions = $this->scan_for_extensions();
|
||||||
if (count($this->extensions))
|
if (count($this->extensions))
|
||||||
@ -424,7 +424,15 @@
|
|||||||
}
|
}
|
||||||
elseif ($content['dump'])
|
elseif ($content['dump'])
|
||||||
{
|
{
|
||||||
$msg = $this->etemplate->dump2setup($content['name']);
|
list($name) = explode('.',$content['name']);
|
||||||
|
if (empty($name) || !@is_dir(PHPGW_SERVER_ROOT.'/'.$name))
|
||||||
|
{
|
||||||
|
$msg = $this->messages['need_name'];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$msg = $this->etemplate->dump2setup($content['name']);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
elseif ($content['save'])
|
elseif ($content['save'])
|
||||||
{
|
{
|
||||||
@ -455,7 +463,27 @@
|
|||||||
$m = new editor(False);
|
$m = new editor(False);
|
||||||
$additional = $m->messages + $this->etemplate->types + $this->extensions + $this->aligns;
|
$additional = $m->messages + $this->etemplate->types + $this->extensions + $this->aligns;
|
||||||
}
|
}
|
||||||
$msg = $this->etemplate->writeLangFile($name,'en',$additional);
|
else // try to call the writeLangFile function of the app's ui-layer
|
||||||
|
{
|
||||||
|
$ui = @CreateObject($name.'.'.($class = 'ui'.$name));
|
||||||
|
if (!is_object($ui))
|
||||||
|
{
|
||||||
|
$ui = @CreateObject($name.'.'.($class = 'ui'));
|
||||||
|
}
|
||||||
|
if (!is_object($ui))
|
||||||
|
{
|
||||||
|
$ui = @CreateObject($name.'.'.($class = $name));
|
||||||
|
}
|
||||||
|
if (is_object($ui) && @$ui->public_functions['writeLangFile'])
|
||||||
|
{
|
||||||
|
$msg = "$class::writeLangFile: ".$ui->writeLangFile();
|
||||||
|
}
|
||||||
|
unset($ui);
|
||||||
|
}
|
||||||
|
if (empty($msg))
|
||||||
|
{
|
||||||
|
$msg = $this->etemplate->writeLangFile($name,'en',$additional);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
elseif ($content['export_xml'])
|
elseif ($content['export_xml'])
|
||||||
@ -553,21 +581,25 @@
|
|||||||
return $imported;
|
return $imported;
|
||||||
}
|
}
|
||||||
|
|
||||||
function delete($post_vars='',$back = 'edit')
|
function delete($content='',$back = 'edit')
|
||||||
{
|
{
|
||||||
if ($this->debug)
|
if ($this->debug)
|
||||||
{
|
{
|
||||||
echo "delete(back='$back') cont = "; _debug_array($post_vars);
|
echo "delete(back='$back') content = "; _debug_array($content);
|
||||||
}
|
}
|
||||||
if (!$post_vars)
|
if (!is_array($content))
|
||||||
{
|
{
|
||||||
$post_vars = array();
|
$content = array();
|
||||||
}
|
}
|
||||||
if (isset($post_vars['name']))
|
if (!is_array($this->extensions) && isset($content['**extensions**']))
|
||||||
{
|
{
|
||||||
$read_ok = $this->etemplate->read($post_vars);
|
$this->extensions = $content['**extensions**']; unset($content['**extensions**']);
|
||||||
}
|
}
|
||||||
if (isset($post_vars['yes'])) // Delete
|
if (isset($content['name']))
|
||||||
|
{
|
||||||
|
$read_ok = $this->etemplate->read($content);
|
||||||
|
}
|
||||||
|
if (isset($content['yes'])) // Delete
|
||||||
{
|
{
|
||||||
if ($read_ok)
|
if ($read_ok)
|
||||||
{
|
{
|
||||||
@ -575,9 +607,9 @@
|
|||||||
}
|
}
|
||||||
$msg = $this->messages[$read_ok ? 'deleted' : 'not_found'];
|
$msg = $this->messages[$read_ok ? 'deleted' : 'not_found'];
|
||||||
|
|
||||||
if ($post_vars['back'] == 'list_result')
|
if ($content['back'] == 'list_result')
|
||||||
{
|
{
|
||||||
$this->list_result($post_vars['preserv'],$msg);
|
$this->list_result($content['preserv'],$msg);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@ -585,12 +617,12 @@
|
|||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if (isset($post_vars['no'])) // Back to ...
|
if (isset($content['no'])) // Back to ...
|
||||||
{
|
{
|
||||||
switch ($back = $post_vars['back'])
|
switch ($back = $content['back'])
|
||||||
{
|
{
|
||||||
case 'list_result':
|
case 'list_result':
|
||||||
$this->$back($post_vars['preserv']);
|
$this->$back($content['preserv']);
|
||||||
return;
|
return;
|
||||||
case 'show':
|
case 'show':
|
||||||
break;
|
break;
|
||||||
@ -605,13 +637,17 @@
|
|||||||
$this->edit($this->messages['not_found']);
|
$this->edit($this->messages['not_found']);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
$preserv = array(
|
||||||
|
'preserv' => $content['preserv'],
|
||||||
|
'back' => $back
|
||||||
|
);
|
||||||
$content = $this->etemplate->as_array();
|
$content = $this->etemplate->as_array();
|
||||||
|
|
||||||
$delete = new etemplate('etemplate.editor.delete');
|
$delete = new etemplate('etemplate.editor.delete');
|
||||||
$delete->exec('etemplate.editor.delete',$content,array(),array(),$content+ array(
|
$delete->exec('etemplate.editor.delete',$content,array(),array(),
|
||||||
'back' => $back,
|
$content+$preserv+array(
|
||||||
'preserv' => $post_vars['preserv']
|
'**extensions**' => $this->extensions
|
||||||
),'');
|
),'');
|
||||||
}
|
}
|
||||||
|
|
||||||
function list_result($cont='',$msg='')
|
function list_result($cont='',$msg='')
|
||||||
@ -620,6 +656,10 @@
|
|||||||
{
|
{
|
||||||
echo "<p>etemplate.editor.list_result: cont="; _debug_array($cont);
|
echo "<p>etemplate.editor.list_result: cont="; _debug_array($cont);
|
||||||
}
|
}
|
||||||
|
if (!is_array($this->extensions) && is_array($cont) && isset($cont['**extensions**']))
|
||||||
|
{
|
||||||
|
$this->extensions = $cont['**extensions**']; unset($cont['**extensions**']);
|
||||||
|
}
|
||||||
if (!$cont || !is_array($cont))
|
if (!$cont || !is_array($cont))
|
||||||
{
|
{
|
||||||
return $this->edit('error');
|
return $this->edit('error');
|
||||||
@ -666,7 +706,10 @@
|
|||||||
}
|
}
|
||||||
$list_result = new etemplate('etemplate.editor.list_result');
|
$list_result = new etemplate('etemplate.editor.list_result');
|
||||||
//$list_result->debug=1;
|
//$list_result->debug=1;
|
||||||
$list_result->exec('etemplate.editor.list_result',$content,'','',array('result' => $result),'');
|
$list_result->exec('etemplate.editor.list_result',$content,'','',array(
|
||||||
|
'result' => $result,
|
||||||
|
'**extensions**' => $this->extensions
|
||||||
|
),'');
|
||||||
}
|
}
|
||||||
|
|
||||||
function show($post_vars='')
|
function show($post_vars='')
|
||||||
@ -675,10 +718,14 @@
|
|||||||
{
|
{
|
||||||
echo "<p>etemplate.editor.show: content="; _debug_array($post_vars);
|
echo "<p>etemplate.editor.show: content="; _debug_array($post_vars);
|
||||||
}
|
}
|
||||||
if (!$post_vars)
|
if (!is_array($post_vars))
|
||||||
{
|
{
|
||||||
$post_vars = array();
|
$post_vars = array();
|
||||||
}
|
}
|
||||||
|
if (!is_array($this->extensions) && isset($post_vars['**extensions**']))
|
||||||
|
{
|
||||||
|
$this->extensions = $post_vars['**extensions**']; unset($post_vars['**extensions**']);
|
||||||
|
}
|
||||||
if (isset($GLOBALS['HTTP_GET_VARS']['name']) && !$this->etemplate->read($GLOBALS['HTTP_GET_VARS']) ||
|
if (isset($GLOBALS['HTTP_GET_VARS']['name']) && !$this->etemplate->read($GLOBALS['HTTP_GET_VARS']) ||
|
||||||
isset($post_vars['name']) && !$this->etemplate->read($post_vars))
|
isset($post_vars['name']) && !$this->etemplate->read($post_vars))
|
||||||
{
|
{
|
||||||
@ -735,7 +782,10 @@
|
|||||||
unserialize(substr($vals["A$r"],0,-5)) : $vals["A$r"];
|
unserialize(substr($vals["A$r"],0,-5)) : $vals["A$r"];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$show->exec('etemplate.editor.show',$content,array(),'',array('olds' => $vals),'');
|
$show->exec('etemplate.editor.show',$content,array(),'',array(
|
||||||
|
'olds' => $vals,
|
||||||
|
'**extensions**' => $this->extensions
|
||||||
|
),'');
|
||||||
}
|
}
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
|
Loading…
Reference in New Issue
Block a user