mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-04-15 00:12:43 +09:00
Support order_default attribute to <index> tag in XML query
This commit is contained in:
parent
2a3f5d3c51
commit
4cc730e489
4 changed files with 12 additions and 10 deletions
|
|
@ -11,17 +11,17 @@ abstract class BaseParser
|
|||
* Get all attributes of an element as an associative array.
|
||||
*
|
||||
* @param SimpleXMLElement $element
|
||||
* @param bool $remove_symbols
|
||||
* @param bool $normalize
|
||||
* @return array
|
||||
*/
|
||||
protected static function _getAttributes(\SimpleXMLElement $element, $remove_symbols = true): array
|
||||
protected static function _getAttributes(\SimpleXMLElement $element, $normalize = true): array
|
||||
{
|
||||
$result = array();
|
||||
foreach ($element->attributes() as $key => $val)
|
||||
{
|
||||
if ($remove_symbols)
|
||||
if ($normalize)
|
||||
{
|
||||
$key = preg_replace('/[^a-z]/', '', $key);
|
||||
$key = strtolower(preg_replace('/[^a-zA-Z]/', '', $key));
|
||||
}
|
||||
$result[trim($key)] = trim($val);
|
||||
}
|
||||
|
|
|
|||
|
|
@ -190,10 +190,12 @@ class DBQueryParser extends BaseParser
|
|||
$query->navigation = new DBQuery\Navigation;
|
||||
foreach ($xml->navigation->index ?: [] as $tag)
|
||||
{
|
||||
$attribs = self::_getAttributes($tag, true);
|
||||
$orderby = new DBQuery\OrderBy;
|
||||
$orderby->var = trim($tag['var']) ?: null;
|
||||
$orderby->default = trim($tag['default']) ?: null;
|
||||
$orderby->order_var = trim($tag['order']) ?: null;
|
||||
$orderby->var = ($attribs['var'] ?? null) ?: null;
|
||||
$orderby->default = ($attribs['default'] ?? null) ?: null;
|
||||
$orderby->order_var = ($attribs['order'] ?? null) ?: null;
|
||||
$orderby->order_default = strtoupper($attribs['orderdefault'] ?? '') === 'DESC' ? 'DESC' : 'ASC';
|
||||
$query->navigation->orderby[] = $orderby;
|
||||
}
|
||||
foreach (['list_count', 'page_count', 'page', 'offset'] as $key)
|
||||
|
|
|
|||
|
|
@ -13,7 +13,7 @@
|
|||
</group>
|
||||
</conditions>
|
||||
<navigation>
|
||||
<index var="sort_index" default="list_order" order="order_type" />
|
||||
<index var="sort_index" default="list_order" order="order_type" order_default="desc" />
|
||||
<list_count var="list_count" default="20" />
|
||||
<page_count var="page_count" default="10" />
|
||||
<page var="page" default="1" />
|
||||
|
|
|
|||
|
|
@ -37,7 +37,7 @@ class DBQueryParserTest extends \Codeception\TestCase\Test
|
|||
$this->assertEquals('sort_index', $query->navigation->orderby[0]->var);
|
||||
$this->assertEquals('list_order', $query->navigation->orderby[0]->default);
|
||||
$this->assertEquals('order_type', $query->navigation->orderby[0]->order_var);
|
||||
$this->assertEquals('ASC', $query->navigation->orderby[0]->order_default);
|
||||
$this->assertEquals('DESC', $query->navigation->orderby[0]->order_default);
|
||||
$this->assertTrue($query->navigation->list_count instanceof Rhymix\Framework\Parsers\DBQuery\VariableBase);
|
||||
$this->assertEquals('list_count', $query->navigation->list_count->var);
|
||||
$this->assertEquals('20', $query->navigation->list_count->default);
|
||||
|
|
@ -49,7 +49,7 @@ class DBQueryParserTest extends \Codeception\TestCase\Test
|
|||
public function testSimpleSelect()
|
||||
{
|
||||
$query = Rhymix\Framework\Parsers\DBQueryParser::loadXML(\RX_BASEDIR . 'tests/_data/dbquery/selectTest1.xml');
|
||||
$args = array('member_srl' => 1234, 'regdate_more' => '20200707120000', 'page' => 3);
|
||||
$args = array('member_srl' => 1234, 'regdate_more' => '20200707120000', 'page' => 3, 'order_type' => 'asc');
|
||||
$sql = $query->getQueryString('rx_', $args);
|
||||
$params = $query->getQueryParams();
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue