nighty commit
This commit is contained in:
parent
f26182f567
commit
02d189bec8
@ -4,26 +4,40 @@ namespace Rails\ActionController\Response;
|
|||||||
use Rails\ActionView;
|
use Rails\ActionView;
|
||||||
|
|
||||||
# TODO
|
# TODO
|
||||||
class ActionController_Response_Partial extends Base
|
class Partial extends Base
|
||||||
{
|
{
|
||||||
|
private $_template;
|
||||||
|
|
||||||
public function _render_view()
|
public function _render_view()
|
||||||
{
|
{
|
||||||
$params = [$this->_params['partial']];
|
|
||||||
if (isset($this->_params['locals']))
|
|
||||||
$params = array_merge($params, [$this->_params['locals']]);
|
|
||||||
|
|
||||||
# Include helpers.
|
# Include helpers.
|
||||||
ActionView\ViewHelpers::load();
|
ActionView\ViewHelpers::load();
|
||||||
|
$layout = !empty($this->_params['layout']) ? $this->_params['layout'] : false;
|
||||||
|
$partial = $this->_params['partial'];
|
||||||
|
$locals = (array)\Rails::application()->controller()->locals();
|
||||||
|
$this->_template = new ActionView\Template(['lambda' => function() use ($partial, $locals) {
|
||||||
|
echo $this->partial($partial, $locals);
|
||||||
|
}], ['layout' => $layout]);
|
||||||
|
|
||||||
|
// $this->_template->setLocals();
|
||||||
|
|
||||||
|
$this->_template->renderContent();
|
||||||
|
// $params = [$this->_params['partial']];
|
||||||
|
// if (isset($this->_params['locals']))
|
||||||
|
// $params = array_merge($params, [$this->_params['locals']]);
|
||||||
|
|
||||||
|
# Include helpers.
|
||||||
|
// ActionView\ViewHelpers::load();
|
||||||
# Create a template so we can call render_partial.
|
# Create a template so we can call render_partial.
|
||||||
# This shouldn't be done this way.
|
# This shouldn't be done this way.
|
||||||
|
|
||||||
$template = new ActionView\Template([]);
|
// $template = new ActionView\Template([]);
|
||||||
|
// vpe($this);
|
||||||
$this->_body = call_user_func_array([$template, 'render_partial'], $params);
|
// $this->_body = call_user_func_array([$template, 'renderContent'], $params);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function _print_view()
|
public function _print_view()
|
||||||
{
|
{
|
||||||
return $this->_body;
|
return $this->_template->content();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,6 +0,0 @@
|
|||||||
<?php
|
|
||||||
namespace Rails\Http\Exception;
|
|
||||||
|
|
||||||
interface ExceptionInterface
|
|
||||||
{
|
|
||||||
}
|
|
@ -1,6 +0,0 @@
|
|||||||
<?php
|
|
||||||
namespace Rails\Http\Exception;
|
|
||||||
|
|
||||||
class InvalidArgumentException extends \Rails\Exception\InvalidArgumentException implements ExceptionInterface
|
|
||||||
{
|
|
||||||
}
|
|
@ -1,6 +0,0 @@
|
|||||||
<?php
|
|
||||||
namespace Rails\Http\Exception;
|
|
||||||
|
|
||||||
class LogicException extends \Rails\Exception\LogicException implements ExceptionInterface
|
|
||||||
{
|
|
||||||
}
|
|
@ -2,6 +2,7 @@
|
|||||||
namespace Rails\ActionDispatch\Http;
|
namespace Rails\ActionDispatch\Http;
|
||||||
|
|
||||||
use Rails;
|
use Rails;
|
||||||
|
use Rails\ActionDispatch\Exception;
|
||||||
|
|
||||||
class Headers
|
class Headers
|
||||||
{
|
{
|
||||||
|
@ -20,7 +20,10 @@ class Table/* extends AbstractTable*/
|
|||||||
$table_data = $table_indexes = $pri = $uni = [];
|
$table_data = $table_indexes = $pri = $uni = [];
|
||||||
|
|
||||||
foreach ($rows as $row) {
|
foreach ($rows as $row) {
|
||||||
$data = ['type' => $row['Type']];
|
$data = [
|
||||||
|
'type' => $row['Type'],
|
||||||
|
'default' => $row['Default']
|
||||||
|
];
|
||||||
|
|
||||||
if (strpos($row['Type'], 'enum') === 0) {
|
if (strpos($row['Type'], 'enum') === 0) {
|
||||||
$enum_values = [];
|
$enum_values = [];
|
||||||
@ -52,4 +55,4 @@ class Table/* extends AbstractTable*/
|
|||||||
|
|
||||||
return [$table_data, $table_indexes];
|
return [$table_data, $table_indexes];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -24,7 +24,10 @@ class Table/* extends AbstractTable*/
|
|||||||
];
|
];
|
||||||
|
|
||||||
foreach ($rows as $row) {
|
foreach ($rows as $row) {
|
||||||
$data = ['type' => $row['type']];
|
$data = [
|
||||||
|
'type' => $row['type'],
|
||||||
|
'default' => $row['default']
|
||||||
|
];
|
||||||
$table_data[$row['name']] = $data;
|
$table_data[$row['name']] = $data;
|
||||||
|
|
||||||
if ($row['pk'])
|
if ($row['pk'])
|
||||||
@ -33,4 +36,4 @@ class Table/* extends AbstractTable*/
|
|||||||
|
|
||||||
return [$table_data, $table_indexes];
|
return [$table_data, $table_indexes];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,6 +30,11 @@ abstract class Base
|
|||||||
*/
|
*/
|
||||||
static private $preventInit = false;
|
static private $preventInit = false;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Flag to prevent setting default attributes.
|
||||||
|
*/
|
||||||
|
static private $skipDefaultAttributes = false;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ActiveModel\Errors instance.
|
* ActiveModel\Errors instance.
|
||||||
*/
|
*/
|
||||||
@ -205,6 +210,7 @@ abstract class Base
|
|||||||
static private function _create_model(array $data)
|
static private function _create_model(array $data)
|
||||||
{
|
{
|
||||||
self::$preventInit = true;
|
self::$preventInit = true;
|
||||||
|
self::$skipDefaultAttributes = true;
|
||||||
$model = new static();
|
$model = new static();
|
||||||
$model->attributes = $data;
|
$model->attributes = $data;
|
||||||
|
|
||||||
@ -243,6 +249,12 @@ abstract class Base
|
|||||||
|
|
||||||
public function __construct(array $attrs = [])
|
public function __construct(array $attrs = [])
|
||||||
{
|
{
|
||||||
|
if (!self::$skipDefaultAttributes) {
|
||||||
|
$this->setDefaultAttributes();
|
||||||
|
} else {
|
||||||
|
self::$skipDefaultAttributes = true;
|
||||||
|
}
|
||||||
|
|
||||||
$this->assignAttributes($attrs);
|
$this->assignAttributes($attrs);
|
||||||
if (!self::$preventInit) {
|
if (!self::$preventInit) {
|
||||||
$this->init();
|
$this->init();
|
||||||
|
@ -282,4 +282,9 @@ trait AttributeMethods
|
|||||||
$attributes = array_diff_key($attributes, array_fill_keys($attrs, true));
|
$attributes = array_diff_key($attributes, array_fill_keys($attrs, true));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
private function setDefaultAttributes()
|
||||||
|
{
|
||||||
|
$this->attributes = self::table()->columnDefaults();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -17,6 +17,8 @@ class ModelSchema
|
|||||||
|
|
||||||
protected $primaryKey;
|
protected $primaryKey;
|
||||||
|
|
||||||
|
protected $columnDefaults;
|
||||||
|
|
||||||
public function __construct($name, Connection $connection)
|
public function __construct($name, Connection $connection)
|
||||||
{
|
{
|
||||||
$this->name = $name;
|
$this->name = $name;
|
||||||
@ -104,6 +106,19 @@ class ModelSchema
|
|||||||
return !empty($this->columns[$column_name]);
|
return !empty($this->columns[$column_name]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function columnDefaults()
|
||||||
|
{
|
||||||
|
if ($this->columnDefaults === null) {
|
||||||
|
$this->columnDefaults = [];
|
||||||
|
foreach ($this->columns as $name => $data) {
|
||||||
|
if ($data['default'] !== null) {
|
||||||
|
$this->columnDefaults[$name] = $data['default'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return $this->columnDefaults;
|
||||||
|
}
|
||||||
|
|
||||||
public function enumValues($column_name)
|
public function enumValues($column_name)
|
||||||
{
|
{
|
||||||
if (!isset($this->columns[$column_name])) {
|
if (!isset($this->columns[$column_name])) {
|
||||||
|
@ -4,4 +4,4 @@ namespace Rails\Exception;
|
|||||||
class LogicException extends \LogicException implements ExceptionInterface
|
class LogicException extends \LogicException implements ExceptionInterface
|
||||||
{
|
{
|
||||||
use ExceptionTrait;
|
use ExceptionTrait;
|
||||||
}
|
}
|
||||||
|
@ -74,6 +74,14 @@ class I18n
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* When adding new translations with the same name, since the arrays are
|
||||||
|
* recursively merged, the result will not be a string, but an array.
|
||||||
|
* If this is the case, the latter value will be used.
|
||||||
|
*/
|
||||||
|
if (is_array($tr))
|
||||||
|
$tr = array_pop($tr);
|
||||||
|
|
||||||
if (is_int(strpos($tr, '%{'))) {
|
if (is_int(strpos($tr, '%{'))) {
|
||||||
foreach ($params as $k => $param) {
|
foreach ($params as $k => $param) {
|
||||||
$tr = str_replace('%{'.$k.'}', $param, $tr);
|
$tr = str_replace('%{'.$k.'}', $param, $tr);
|
||||||
|
@ -50,4 +50,4 @@ class DbTools
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user