6 Commits

Author SHA1 Message Date
6fd19a11be Merge branch 'develop' 2020-08-03 23:38:41 -04:00
a1466143b5 FIX: Type hint 2020-08-03 23:38:30 -04:00
7c727d93e9 Merge branch 'develop' 2020-08-03 23:27:45 -04:00
a8d548c0c4 Si existe duplicado avisa 2020-08-03 23:27:34 -04:00
e02b8c4063 Merge branch 'develop' 2020-08-03 23:17:38 -04:00
f03df583d7 FIX: Retorno de Factory::create 2020-08-03 23:17:29 -04:00

View File

@ -22,7 +22,17 @@ class Model {
}
return $this;
}
public function create(string $model_class, array $data = null): Model {
public function create(string $model_class, array $data = null): ModelInterface {
if ($data !== null) {
$model = $this->find($model_class);
foreach ($data as $f => $v) {
$model = $model->where([[$f, $v]]);
}
$model = $model->one();
if ($model !== false) {
return $model;
}
}
return BaseModel::factory($model_class)->create($data);
}
protected $class;
@ -332,20 +342,29 @@ class Model {
return $orm->offset($this->offset);
}
public function one($id = null): ModelInterface {
public function one($id = null): ?ModelInterface {
$result = $this->build()->findOne($id);
if (!$result) {
return false;
}
$result->setFactory($this);
return $result;
}
public function many(): array {
public function many(): ?array {
$results = $this->build()->findMany();
if (!$results) {
return false;
}
foreach ($results as &$r) {
$r->setFactory($this);
}
return $results;
}
public function array(): array {
public function array(): ?array {
$results = $this->build()->findArray();
if (!$results) {
return false;
}
return $results;
}