true,
'tel_v2' => true,
'tel_intl' => true,
'tel_intl_v2' => true,
'checkbox' => true,
'radio' => true,
'select' => true,
'kr_zip' => true,
];
/**
* Constructor for compatibility with legacy ExtraItem class.
*
* @param int $module_srl
* @param int $idx
* @param string $name
* @param string $type
* @param mixed $default
* @param string $desc
* @param string $is_required (Y, N)
* @param string $search (Y, N)
* @param string $value
* @param string $eid
*/
function __construct(int $module_srl, int $idx, string $name, string $type = 'text', $default = null, $desc = '', $is_required = 'N', $search = 'N', $value = null, string $eid = '')
{
if (!$idx)
{
return;
}
$this->module_srl = $module_srl;
$this->idx = $idx;
$this->eid = $eid;
$this->type = $type;
$this->value = $value;
$this->name = $name;
$this->desc = $desc;
$this->default = $default;
$this->is_required = $is_required;
$this->search = $search;
}
/**
* Set the raw value.
*
* @param mixed $value
* @return void
*/
public function setValue($value): void
{
$this->value = $value;
}
/**
* Get the raw value.
*
* @return string|array|null
*/
public function getValue()
{
return self::_getTypeValue($this->type, $this->value);
}
/**
* Get the value formatted as HTML.
*
* @return string
*/
public function getValueHTML(): string
{
return self::_getTypeValueHTML($this->type, $this->value);
}
/**
* Get the HTML form for an extra input field.
*
* @return string
*/
public function getFormHTML(): string
{
$template = new Template(self::_getSkinPath(), 'form.blade.php');
$template->setVars([
'definition' => $this,
'parent_type' => $this->parent_type,
'type' => $this->type,
'value' => self::_getTypeValue($this->type, $this->value),
'default' => self::_getTypeValue($this->type, $this->default),
'input_name' => $this->parent_type === 'document' ? ('extra_vars' . $this->idx) : ($this->input_name ?: $this->eid),
'input_id' => $this->input_id ?: '',
]);
return $template->compile();
}
/**
* Get the next temporary ID.
*
* @return string
*/
public static function getNextTempID(): string
{
return sprintf('rx_tempid_%d', self::$_temp_id++);
}
/**
* Get the normalized value.
*
* This method is public for compatibility with legacy ExtraItem class.
* It should not be called from outside of this class.
*
* @param string $type
* @param string|array $value
* @return string|array|null
*/
public static function _getTypeValue(string $type, $value)
{
// Return if the value is empty.
if (is_array($value))
{
if (!count($value))
{
return;
}
}
else
{
$value = trim(strval($value ?? ''));
if ($value === '')
{
return;
}
}
// Process array types.
if (isset(self::ARRAY_TYPES[$type]))
{
if (is_array($value))
{
$values = $value;
}
elseif (str_contains($value, '|@|'))
{
$values = explode('|@|', $value);
}
elseif (str_contains($value, ',') && $type !== 'kr_zip')
{
$values = explode(',', $value);
}
else
{
$values = [$value];
}
return array_map(function($str) {
return trim(escape($str, false));
}, array_values($values));
}
// Process the URL type.
if ($type === 'homepage' || $type === 'url')
{
if ($value && !preg_match('!^[a-z]+://!i', $value))
{
$value = 'http://' . $value;
}
return escape($value, false);
}
// Escape and return all other types.
return escape($value, false);
}
/**
* Get the normalized value in HTML format.
*
* @param string $type
* @param string|array $value
* @return string
*/
protected static function _getTypeValueHTML(string $type, $value): string
{
// Return if the value is empty.
$value = self::_getTypeValue($type, $value);
if ($value === null || $value === '' || (is_array($value) && !count($value)))
{
return '';
}
// Apply formatting appropriate for each type.
switch ($type)
{
case 'textarea':
return nl2br($value);
case 'select':
case 'radio':
case 'checkbox':
return is_array($value) ? implode(',', $value) : $value;
case 'tel':
case 'tel_v2':
return is_array($value) ? implode('-', $value) : $value;
case 'tel_intl':
case 'tel_intl_v2':
$country_code = $value[0] ?? '';
$phone_number = implode('-', array_slice((array)$value, 1));
return $value ? "(+{$country_code}) {$phone_number}": '';
case 'homepage':
case 'url':
$display = mb_strlen($value, 'UTF-8') > 60 ? mb_substr($value, 0, 40, 'UTF-8') . '...' . mb_substr($value, -10, 10, 'UTF-8') : $value;
return sprintf('%s', $value, $display);
case 'email_address':
case 'email':
return sprintf('%s', $value, $value);
case 'kr_zip':
return is_array($value) ? implode(' ', $value) : $value;
case 'country':
$country = i18n::listCountries()[$value];
$lang_type = \Context::getLangType();
return $lang_type === 'ko' ? $country->name_korean : $country->name_english;
case 'language':
return Lang::getSupportedList()[$value]['name'] ?? '';
case 'date':
return sprintf('%s-%s-%s', substr($value, 0, 4), substr($value, 4, 2), substr($value, 6, 2));
case 'timezone':
return DateTime::getTimezoneList()[$value] ?? '';
default:
return $value;
}
}
/**
* Get the currently configured skin path.
*
* @return string
*/
protected static function _getSkinPath(): string
{
if (self::$_skin_path !== null)
{
return self::$_skin_path;
}
$config = ModuleModel::getModuleConfig('extravar') ?: new \stdClass;
$skin = $config->skin ?? 'default';
if (Storage::isDirectory(\RX_BASEDIR . 'modules/extravar/skins/' . $skin))
{
self::$_skin_path = \RX_BASEDIR . 'modules/extravar/skins/' . $skin;
}
else
{
self::$_skin_path = \RX_BASEDIR . 'modules/extravar/skins/default';
}
return self::$_skin_path;
}
}