14 Commits
0.1.1 ... 0.1.9

Author SHA1 Message Date
89d1db7a7e Merge branch 'develop' 2020-08-03 23:10:57 -04:00
17453427a2 Id en busqueda de 1 y creacion de nuevo modelo 2020-08-03 23:10:47 -04:00
8dc0a27fd9 Merge branch 'develop' 2020-08-03 22:07:24 -04:00
5b1a61cd3b FIX: not reseting 2020-08-03 22:07:12 -04:00
ae172b902c Merge branch 'develop' 2020-08-03 16:25:19 -04:00
d3cb68c5ca Form alias para Define 2020-08-03 16:25:05 -04:00
7f81b987c9 Merge branch 'develop' 2020-07-24 12:06:16 -04:00
0a46604e0c FIX: uso de nombre de variable equivocada en fabrica 2020-07-24 12:06:06 -04:00
af801e769f Merge branch 'develop' 2020-07-24 11:58:16 -04:00
e9bee7fa48 FIX: nombres de variables 2020-07-24 11:58:09 -04:00
c40baaad3f Merge branch 'develop' 2020-07-24 11:47:39 -04:00
ac019aac3f FIX: bad return value 2020-07-24 11:47:25 -04:00
a82fdce64b Merge branch 'develop' 2020-07-22 23:08:52 -04:00
86ffb0b84c FIX 2020-07-22 23:08:34 -04:00
3 changed files with 21 additions and 10 deletions

View File

@ -3,6 +3,7 @@ namespace ProVM\Common\Define;
use \Model as BaseModel; use \Model as BaseModel;
use ProVM\Common\Alias\Model as ModelInterface; use ProVM\Common\Alias\Model as ModelInterface;
use ProVM\Common\Factory\Model as ModelFactory;
abstract class Model extends BaseModel implements ModelInterface { abstract class Model extends BaseModel implements ModelInterface {
const SELF_KEY = 'self_key'; const SELF_KEY = 'self_key';
@ -60,10 +61,10 @@ abstract class Model extends BaseModel implements ModelInterface {
], [ ], [
Model::PARENT_KEY => 'id' Model::PARENT_KEY => 'id'
]); ]);
$parent_table = (new $parent_class())->getTable(); $parent_table = (new $parent_model_class())->getTable();
return $this->factory return $this->factory
->find($parent_model_class) ->find($parent_model_class)
->wherer([ ->where([
[ [
$relation_definitions[Model::PARENT_KEY], $relation_definitions[Model::PARENT_KEY],
$this->{$relation_definitions[Model::SELF_KEY]} $this->{$relation_definitions[Model::SELF_KEY]}
@ -81,7 +82,7 @@ abstract class Model extends BaseModel implements ModelInterface {
Model::SELF_KEY => 'id', Model::SELF_KEY => 'id',
Model::SIBLING_KEY => 'id' Model::SIBLING_KEY => 'id'
]); ]);
$sibling_table = (new $sibling_class())->getTable(); $sibling_table = (new $sibling_model_class())->getTable();
return $this->find($sibling_model_class) return $this->find($sibling_model_class)
->select([ ->select([
[ [

View File

@ -22,11 +22,15 @@ class Model {
} }
return $this; return $this;
} }
public function create(string $model_class, array $data = null): Model {
return BaseModel::factory($model_class)->create($data);
}
protected $class; protected $class;
public function find(string $model_class): Model { public function find(string $model_class): Model {
if (!class_exists($model_class)) { if (!class_exists($model_class)) {
throw new \InvalidArgumentException('El modelo ' . $model_class . ' no existe.'); throw new \InvalidArgumentException('El modelo ' . $model_class . ' no existe.');
} }
$this->reset();
$this->class = $model_class; $this->class = $model_class;
return $this; return $this;
} }
@ -79,14 +83,14 @@ class Model {
} }
foreach ($conditions as $c) { foreach ($conditions as $c) {
$cond = (object) [ $cond = (object) [
'column' => $j['column'] ?? $j[0], 'column' => $c['column'] ?? $c[0],
'value' => $j['value'] ?? $j[1], 'value' => $c['value'] ?? $c[1],
'sym' => strtolower($j['sym'] ?? ($j[2] ?? '=')), 'sym' => strtolower($c['sym'] ?? ($c[2] ?? '=')),
'type' => strtolower($j['type']) ?? '' 'type' => strtolower($c['type']) ?? ''
]; ];
$this->conditions []= $cond; $this->conditions []= $cond;
} }
return $this->conditions; return $this;
} }
protected $grouping; protected $grouping;
public function group($groups): Model { public function group($groups): Model {
@ -328,8 +332,8 @@ class Model {
return $orm->offset($this->offset); return $orm->offset($this->offset);
} }
public function one(): ModelInterface { public function one($id = null): ModelInterface {
$result = $this->build()->findOne(); $result = $this->build()->findOne($id);
$result->setFactory($this); $result->setFactory($this);
return $result; return $result;
} }

6
common/Form/Model.php Normal file
View File

@ -0,0 +1,6 @@
<?php
namespace ProVM\Common\Form;
use ProVM\Common\Define\Model as BaseModel;
abstract class Model extends BaseModel {}