44 Commits

Author SHA1 Message Date
8c481eb512 Merge branch 'develop' into release 2022-12-22 19:48:34 -03:00
7a88398379 Simplified Model 2022-12-22 19:48:23 -03:00
7848d973a6 Reorder 2022-12-22 19:48:05 -03:00
67fea3b15f Merge branch 'develop' into release 2022-12-22 19:42:29 -03:00
2a06507876 Merge branch 'develop' into release 2022-10-11 12:17:39 -03:00
faf615e79d Merge branch 'develop' into release 2022-10-11 11:41:05 -03:00
b8409182d7 Merge branch 'develop' into release 2022-10-10 22:19:18 -03:00
e576ef5054 Merge branch 'develop' into release 2022-10-10 21:48:01 -03:00
b19654bc70 Merge branch 'develop' into release 2022-10-10 17:32:48 -03:00
0af6be2c8e Merge branch 'develop' into release 2022-10-10 16:46:57 -03:00
ba3c70a70e Merge branch 'develop' into release 2022-10-10 16:37:30 -03:00
bc006f3e01 Merge branch 'develop' into release 2022-09-12 21:49:23 -03:00
4ccc38ffac Merge branch 'develop' into release 2022-09-12 17:39:15 -03:00
8531658899 FIX 2022-09-12 17:34:05 -03:00
02f8bb0b4f FIX 2022-09-12 17:29:32 -03:00
10e87b71a3 Update in Repository 2022-09-12 17:23:55 -03:00
37c5a79d5a Made model jsonserializable and added functionality into repository 2022-09-09 15:57:01 -04:00
d12f3f7897 Implement delete 2022-09-09 13:15:54 -04:00
7fc7de7390 Added Factory implementation 2022-09-09 10:33:19 -04:00
3bc54fb9d1 Second version 2022-09-08 21:42:32 -04:00
123d46d33c Fixed Model joins 2021-12-20 23:34:52 -03:00
65c224c636 Merge branch 'develop' into master 2021-08-01 20:51:44 -04:00
6cd26a88ea Merge branch 'develop' into master 2021-08-01 20:34:04 -04:00
022ba575b7 Merge branch 'develop' into master 2021-06-04 21:15:26 -04:00
c913f65b91 Considera leer el dato y correccion en los nombres de los metodos 2021-03-16 00:22:13 -03:00
c8a7781c88 Merge branch 'develop' 2021-03-15 11:17:11 -03:00
1505539e61 Merge branch 'develop' into master 2021-03-09 00:19:55 -03:00
3087a48c43 Merge branch 'develop' into master 2021-03-09 00:15:12 -03:00
43f545516d Merge branch 'develop' 2020-08-04 01:33:09 -04:00
b757ed19b2 Merge branch 'develop' 2020-08-03 23:54:16 -04:00
9dc71e4d77 Merge branch 'develop' 2020-08-03 23:51:05 -04:00
c6806a1c62 Merge branch 'develop' 2020-08-03 23:42:11 -04:00
6fd19a11be Merge branch 'develop' 2020-08-03 23:38:41 -04:00
7c727d93e9 Merge branch 'develop' 2020-08-03 23:27:45 -04:00
e02b8c4063 Merge branch 'develop' 2020-08-03 23:17:38 -04:00
89d1db7a7e Merge branch 'develop' 2020-08-03 23:10:57 -04:00
8dc0a27fd9 Merge branch 'develop' 2020-08-03 22:07:24 -04:00
ae172b902c Merge branch 'develop' 2020-08-03 16:25:19 -04:00
7f81b987c9 Merge branch 'develop' 2020-07-24 12:06:16 -04:00
af801e769f Merge branch 'develop' 2020-07-24 11:58:16 -04:00
c40baaad3f Merge branch 'develop' 2020-07-24 11:47:39 -04:00
a82fdce64b Merge branch 'develop' 2020-07-22 23:08:52 -04:00
8126b1f67d Merge branch 'develop' 2020-07-22 22:57:48 -04:00
2177cb4652 Merge branch 'develop' 2020-07-22 14:08:09 -04:00
3 changed files with 1 additions and 80 deletions

View File

@ -6,16 +6,6 @@ use ProVM\Concept\Model as ModelInterface;
abstract class Model implements ModelInterface
{
protected Repository $repository;
public function setRepository(Repository $repository): ModelInterface
{
$this->repository = $repository;
return $this;
}
public function getRepository(): Repository
{
return $this->repository;
}
protected int $id;
public function setId(int $id): ModelInterface
{
@ -26,64 +16,4 @@ abstract class Model implements ModelInterface
{
return $this->id;
}
protected bool $new;
public function setNew(): ModelInterface
{
$this->new = true;
return $this;
}
public function isNew(): bool
{
return $this->new ?? false;
}
protected bool $dirty;
public function setDirty(): ModelInterface
{
$this->dirty = true;
return $this;
}
public function isDirty(): bool
{
return $this->dirty ?? $this->isNew();
}
public function save(): void
{
if ($this->isDirty()) {
$this->getRepository()->save($this);
}
}
public function edit(array $data): void
{
foreach ($data as $key => $val) {
$m = 'set' . ucwords($key);
$this->{$m}($val);
}
$this->isDirty();
}
public function delete(): void
{
$this->getRepository()->delete($this);
}
public function jsonSerialize(): mixed
{
$obj = new \ReflectionObject($this);
$methods = $obj->getMethods();
$output = [];
foreach ($methods as $method) {
if (!str_contains($method->getName(), 'get')) {
continue;
}
if ($method->getName() === 'getRepository') {
continue;
}
$p = strtolower(preg_replace('/(?<!^)[A-Z]/', '_$0', str_replace('get', '', $method->getName())));
if (!isset($this->{$p})) {
continue;
}
$output[$p] = $this->{$method->getName()}();
}
return $output;
}
}

View File

@ -6,15 +6,6 @@ use ProVM\Concept\Model\Repository;
interface Model extends JsonSerializable
{
public function setRepository(Repository $factory): Model;
public function getRepository(): Repository;
public function setId(int $id): Model;
public function getId(): int;
public function setNew(): Model;
public function isNew(): bool;
public function setDirty(): Model;
public function isDirty(): bool;
public function save(): void;
public function edit(array $data): void;
public function delete(): void;
}

View File

@ -1,8 +1,8 @@
<?php
namespace ProVM\Implement\Model;
use ProVM\Concept\Model;
use Psr\Container\ContainerInterface;
use ProVM\Concept\Model;
use ProVM\Concept\Model\Factory as FactoryInterface;
use ProVM\Concept\Model\Repository;