mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-04-02 01:52:10 +09:00
Implement default extravar skin to replace hardcoded HTML in ExtraItem class
This commit is contained in:
parent
dd06193a1d
commit
31fa498b19
14 changed files with 604 additions and 590 deletions
301
modules/extravar/models/Value.php
Normal file
301
modules/extravar/models/Value.php
Normal file
|
|
@ -0,0 +1,301 @@
|
|||
<?php
|
||||
|
||||
namespace Rhymix\Modules\Extravar\Models;
|
||||
|
||||
use ModuleModel;
|
||||
use Rhymix\Framework\DateTime;
|
||||
use Rhymix\Framework\i18n;
|
||||
use Rhymix\Framework\Lang;
|
||||
use Rhymix\Framework\Template;
|
||||
use Rhymix\Framework\Storage;
|
||||
|
||||
class Value
|
||||
{
|
||||
/**
|
||||
* Public properties for compatibility with legacy ExtraItem class.
|
||||
*/
|
||||
public $module_srl = 0;
|
||||
public $idx = 0;
|
||||
public $eid = '';
|
||||
public $input_id = '';
|
||||
public $input_name = '';
|
||||
public $parent_type = 'document';
|
||||
public $type = 'text';
|
||||
public $value = null;
|
||||
public $name = '';
|
||||
public $desc = '';
|
||||
public $default = null;
|
||||
public $is_required = 'N';
|
||||
public $is_disabled = 'N';
|
||||
public $is_readonly = 'N';
|
||||
public $search = 'N';
|
||||
|
||||
/**
|
||||
* Skin path cache.
|
||||
*/
|
||||
protected static $_skin_path = null;
|
||||
|
||||
/**
|
||||
* Temporary ID cache.
|
||||
*/
|
||||
protected static $_temp_id = 1;
|
||||
|
||||
/**
|
||||
* List of types where the value should be interpreted as an array.
|
||||
*/
|
||||
public const ARRAY_TYPES = [
|
||||
'tel' => 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('<a href="%s" target="_blank">%s</a>', $value, $display);
|
||||
case 'email_address':
|
||||
case 'email':
|
||||
return sprintf('<a href="mailto:%s">%s</a>', $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;
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue