16 Commits

7 changed files with 88 additions and 12 deletions

View File

@ -2,7 +2,7 @@
namespace ProVM\Common\Alias; namespace ProVM\Common\Alias;
use \Model as BaseModel; use \Model as BaseModel;
use ProVM\Common\Alias\Model as ModelInterface; use ProVM\Common\Define\Model as ModelInterface;
use ProVM\Common\Factory\Model as ModelFactory; use ProVM\Common\Factory\Model as ModelFactory;
abstract class Model extends BaseModel implements ModelInterface { abstract class Model extends BaseModel implements ModelInterface {
@ -122,4 +122,35 @@ abstract class Model extends BaseModel implements ModelInterface {
public function toArray(): array { public function toArray(): array {
return $this->asArray(); return $this->asArray();
} }
protected static function parseInput($input): array {
return array_intersect_key((array) $input, array_combine(static::$fields, static::$fields));
}
public static function add(ModelFactory $factory, $input): ?ModelInterface {
$data = static::parseInput($input);
$class = get_called_class();
if (method_exists($class, 'find')) {
$obj = static::find($factory, $input);
} else {
$where = $data;
array_walk($where, function(&$item, $key) {
$item = [$key, $item];
});
$where = array_values($where);
$obj = $factory->find($class)->where($where)->one();
}
if ($obj === null) {
$obj = $factory->create($class, $data);
}
return $obj;
}
public function edit($input): bool {
$data = static::parseInput($input);
foreach (static::$fields as $field) {
if ($this->{$field} != $data[$field]) {
$this->{$field} = $data[$field];
}
}
return $this->save();
}
} }

View File

@ -11,4 +11,7 @@ interface Model {
public function siblingOf(string $sibling_model_class, string $connecting_table, array $relation_definitions): ?array; public function siblingOf(string $sibling_model_class, string $connecting_table, array $relation_definitions): ?array;
public function toArray(): array; public function toArray(): array;
public static function add(ModelFactory $factory, $input): ?Model;
public function edit($input): bool;
} }

View File

@ -0,0 +1,13 @@
<?php
namespace ProVM\Common\Define\Model;
use Carbon\Carbon;
trait Date {
public function date(\DateTime $date = null) {
if ($date === null) {
return Carbon::parse($this->date);
}
$this->date = $data->format('Y-m-d');
}
}

View File

@ -0,0 +1,13 @@
<?php
namespace ProVM\Common\Define\Model;
use Carbon\Carbon;
trait DateTime {
public function dateTime(\DateTime $date_time = null) {
if ($date_time === null) {
return Carbon::parse($this->date_time);
}
$this->date_time = $date_time->format('c');
}
}

View File

@ -0,0 +1,13 @@
<?php
namespace ProVM\Common\Define\Model;
use Carbon\Carbon;
trait Time {
public function time(\DateTime $time = null) {
if ($time === null) {
return Carbon::parse($this->time);
}
$this->time = $time->format('H:i:s e');
}
}

View File

@ -3,7 +3,7 @@ namespace ProVM\Common\Factory;
use ORM; use ORM;
use Model as BaseModel; use Model as BaseModel;
use ProVM\Common\Alias\Model as ModelInterface; use ProVM\Common\Define\Model as ModelInterface;
class Model { class Model {
public function reset(): Model { public function reset(): Model {
@ -79,9 +79,9 @@ class Model {
'table' => $j['table'] ?? $j[0], 'table' => $j['table'] ?? $j[0],
'from' => $j['from'] ?? $j[1], 'from' => $j['from'] ?? $j[1],
'to' => $j['to'] ?? $j[2], 'to' => $j['to'] ?? $j[2],
'sym' => $j['sym'] ?? ($j[3] ?? '='), 'symb' => $j['symb'] ?? ($j[3] ?? '='),
'alias' => $j['alias'] ?? '', 'alias' => $j['alias'] ?? '',
'type' => strtolower($j['type']) ?? '', 'type' => strtolower($j['type'] ?? ''),
'params' => $j['params'] ?? '' 'params' => $j['params'] ?? ''
]; ];
$this->joins []= $join; $this->joins []= $join;
@ -97,8 +97,8 @@ class Model {
$cond = (object) [ $cond = (object) [
'column' => $c['column'] ?? $c[0], 'column' => $c['column'] ?? $c[0],
'value' => $c['value'] ?? $c[1], 'value' => $c['value'] ?? $c[1],
'sym' => strtolower($c['sym'] ?? ($c[2] ?? '=')), 'symb' => strtolower($c['symb'] ?? ($c[2] ?? '=')),
'type' => strtolower($c['type']) ?? '' 'type' => strtolower($c['type'] ?? '')
]; ];
$this->conditions []= $cond; $this->conditions []= $cond;
} }
@ -154,7 +154,7 @@ class Model {
return $orm; return $orm;
} }
foreach ($this->columns as $col) { foreach ($this->columns as $col) {
$orm = $orm->select(trim(implode('.', $col), '.')); $orm = $orm->select(trim(implode('.', (array) $col), '.'));
} }
return $orm; return $orm;
} }
@ -192,7 +192,7 @@ class Model {
} }
if ($join->type == 'raw') { if ($join->type == 'raw') {
$orm = $orm->{$method}($join->table, [$join->from, $join->symb, $join->to], $join->alias, $join->params); $orm = $orm->{$method}($join->table, [$join->from, $join->symb, $join->to], $join->alias, $join->params);
} elseif ($join->alias === '') { } elseif ($join->alias !== '') {
$orm = $orm->{$method}($join->table, [$join->from, $join->symb, $join->to], $join->alias); $orm = $orm->{$method}($join->table, [$join->from, $join->symb, $join->to], $join->alias);
} else { } else {
$orm = $orm->{$method}($join->table, [$join->from, $join->symb, $join->to]); $orm = $orm->{$method}($join->table, [$join->from, $join->symb, $join->to]);
@ -206,7 +206,7 @@ class Model {
} }
foreach ($this->conditions as $cond) { foreach ($this->conditions as $cond) {
$method = 'where'; $method = 'where';
switch ($cond->sym) { switch ($cond->symb) {
case '<': case '<':
$method = 'whereLt'; $method = 'whereLt';
break; break;
@ -363,10 +363,13 @@ class Model {
return $results; return $results;
} }
public function array(): ?array { public function array(): ?array {
$results = $this->build()->findArray(); $results = $this->many();
if (!$results) { if (!$results or $results === null) {
return null; return null;
} }
array_walk($results, function(&$item) {
$item = $item->toArray();
});
return $results; return $results;
} }

View File

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