-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathColumnModel.php
More file actions
124 lines (101 loc) · 2.76 KB
/
ColumnModel.php
File metadata and controls
124 lines (101 loc) · 2.76 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
<?php
namespace SyncEngine\Model;
use SyncEngine\Column\Type\ColumnTypeInterface;
use SyncEngine\Exception\InvalidException;
use SyncEngine\Form\Fields\InputFieldType;
use SyncEngine\Form\Fields\Interface\FieldConfigInterface;
use SyncEngine\Model\Abstract\ServiceModel;
use SyncEngine\Model\Interface\Configurable;
use SyncEngine\Model\Trait\Config;
use SyncEngine\Service\Interface\FormatInterface;
use SyncEngine\Service\Locator\Columns;
abstract class ColumnModel extends ServiceModel implements Configurable
{
use Config;
const SERVICE = Columns::class;
/**
* The type of task, can be used for categorizing.
*
* @var string|ColumnTypeInterface
*/
public string|ColumnTypeInterface $type = '';
/**
* Human-readable name used in the interface.
*
* @var string
*/
public string $name = '';
/**
* Human-readable description used in the interface.
*
* @var string
*/
public string $description = '';
private FormatInterface $formatter;
public function getType(): string
{
return $this->type instanceof ColumnTypeInterface ? $this->type->getType() : $this->type;
}
public function getName(): string
{
return $this->name;
}
public function getDescription(): string
{
return $this->description;
}
abstract public function initFormatter( array $config = [] ): FormatInterface;
public function setFormatter( array $config = [] ): static
{
$this->formatter = $this->initFormatter( $config );
return $this;
}
public function getFormatter( ?array $config = null ): ?FormatInterface
{
if ( is_array( $config ) ) {
return $this->initFormatter( $config );
}
if ( ! isset( $this->formatter ) && $this->getConfig() ) {
$this->setFormatter( $this->getConfig() );
}
return $this->formatter; // Maybe: throw new \ErrorException( 'Formatter is not initialized.' );
}
/**
* @param $value
* @param array|null $config
* @param ColumnModel|null $source
*
* @throws InvalidException
* @return mixed
*/
public function format( $value, ?array $config = null, ?ColumnModel $source = null )
{
return $this->getFormatter( $config )->convert( $value, $source?->getFormatter() );
}
public function getFields(): array
{
return [];
}
public function getInput( array $config = [] ): ?FieldConfigInterface
{
$field = [
'type' => 'text',
];
return new InputFieldType( $field );
}
public function normalize(): array
{
$props = [
'_class' => $this->getClassLocator(),
'type' => $this->getType(),
'name' => $this->getName(),
'description' => $this->getDescription(),
'fields' => $this->getFields(),
'input' => $this->getInput(),
];
if ( $this->isFromModule() ) {
$props['module'] = $this->getModule()->getName();
}
return $props;
}
}