mirror of
https://github.com/e107inc/e107.git
synced 2025-08-01 04:10:38 +02:00
user_extended_class.php code optimization.
This commit is contained in:
@@ -517,6 +517,36 @@ class e107_user_extended
|
|||||||
{
|
{
|
||||||
return $this->user_extended_get_fieldList($cat, $indexField);
|
return $this->user_extended_get_fieldList($cat, $indexField);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private function getFieldTypeClass($listRoot)
|
||||||
|
{
|
||||||
|
|
||||||
|
$filename = e_CORE . 'sql/extended_' . $listRoot . '.php';
|
||||||
|
|
||||||
|
if(!is_readable($filename))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
require_once($filename);
|
||||||
|
$className = 'extended_' . $listRoot;
|
||||||
|
|
||||||
|
if(!class_exists($className))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @var extended_timezones $temp */
|
||||||
|
$temp = new $className();
|
||||||
|
|
||||||
|
if(!method_exists($className, 'getValue'))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return $temp;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -1005,14 +1035,12 @@ class e107_user_extended
|
|||||||
|
|
||||||
case EUF_PREDEFINED : // predefined list, shown in dropdown
|
case EUF_PREDEFINED : // predefined list, shown in dropdown
|
||||||
$listRoot = trim($struct['user_extended_struct_values']); // Base list name
|
$listRoot = trim($struct['user_extended_struct_values']); // Base list name
|
||||||
$filename = e_CORE.'sql/extended_'.$listRoot.'.php';
|
|
||||||
if (!is_readable($filename)) return 'No file: '.$filename;
|
if(!$temp = $this->getFieldTypeClass($listRoot))
|
||||||
require_once($filename);
|
{
|
||||||
$className = 'extended_'.$listRoot;
|
return "Missing Extended Class";
|
||||||
if (!class_exists($className)) return '?????';
|
}
|
||||||
/** @var extended_timezones $temp */
|
|
||||||
$temp = new $className();
|
|
||||||
if (!method_exists($className, 'getValue')) return '???-???';
|
|
||||||
$temp->pointerReset();
|
$temp->pointerReset();
|
||||||
|
|
||||||
$ret = "<select id='{$fid}' {$include} name='{$fname}' {$required} >\n";
|
$ret = "<select id='{$fid}' {$include} name='{$fname}' {$required} >\n";
|
||||||
@@ -1329,14 +1357,11 @@ class e107_user_extended
|
|||||||
*/
|
*/
|
||||||
function user_extended_display_text($table, $value)
|
function user_extended_display_text($table, $value)
|
||||||
{
|
{
|
||||||
$filename = e_CORE.'sql/extended_'.$table.'.php';
|
if(!$temp = $this->getFieldTypeClass($table))
|
||||||
if (!is_readable($filename)) return 'No file: '.$filename;
|
{
|
||||||
require_once($filename);
|
"Couldn't find extended field class: ".$table;
|
||||||
$className = 'extended_'.$table;
|
}
|
||||||
if (!class_exists($className)) return '?????';
|
|
||||||
/** @var extended_timezones $temp */
|
|
||||||
$temp = new $className();
|
|
||||||
if (!method_exists($className, 'getValue')) return '???-???';
|
|
||||||
return $temp->getValue($value);
|
return $temp->getValue($value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user