summaryrefslogtreecommitdiff
path: root/framework/Data/ActiveRecord/Scaffold/InputBuilder/TScaffoldInputBase.php
blob: 14244b4c249dbeb60faaba93ef10a156d9e8fa50 (plain)
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
<?php
/**
 * TScaffoldInputBase class file.
 *
 * @link http://www.pradosoft.com/
 * @copyright Copyright &copy; 2005-2014 PradoSoft
 * @license http://www.pradosoft.com/license/
 * @package System.Data.ActiveRecord.Scaffold.InputBuilder
 */
class TScaffoldInputBase
{
	const DEFAULT_ID = 'scaffold_input';
	private $_parent;

	protected function getParent()
	{
		return $this->_parent;
	}

	public static function createInputBuilder($record)
	{
		$record->getDbConnection()->setActive(true); //must be connected before retrieving driver name!
		$driver = $record->getDbConnection()->getDriverName();
		switch(strtolower($driver))
		{
			case 'sqlite': //sqlite 3
			case 'sqlite2': //sqlite 2
				require_once(dirname(__FILE__).'/TSqliteScaffoldInput.php');
				return new TSqliteScaffoldInput($conn);
			case 'mysqli':
			case 'mysql':
				require_once(dirname(__FILE__).'/TMysqlScaffoldInput.php');
				return new TMysqlScaffoldInput($conn);
			case 'pgsql':
				require_once(dirname(__FILE__).'/TPgsqlScaffoldInput.php');
				return new TPgsqlScaffoldInput($conn);
			case 'mssql':
				require_once(dirname(__FILE__).'/TMssqlScaffoldInput.php');
				return new TMssqlScaffoldInput($conn);
			case 'ibm':
				require_once(dirname(__FILE__).'/TIbmScaffoldInput.php');
				return new TIbmScaffoldInput($conn);
			default:
				throw new TConfigurationException(
					'scaffold_invalid_database_driver',$driver);
		}
	}

	public function createScaffoldInput($parent, $item, $column, $record)
	{
		$this->_parent=$parent;
		$item->setCustomData($column->getColumnId());
		$this->createControl($item->_input, $column, $record);
		if($item->_input->findControl(self::DEFAULT_ID))
			$this->createControlLabel($item->_label, $column, $record);
	}

	protected function createControlLabel($label, $column, $record)
	{
		$fieldname = ucwords(str_replace('_', ' ', $column->getColumnId())).':';
		$label->setText($fieldname);
		$label->setForControl(self::DEFAULT_ID);
	}

	public function loadScaffoldInput($parent, $item, $column, $record)
	{
		$this->_parent=$parent;
		if($this->getIsEnabled($column, $record))
		{
			$prop = $column->getColumnId();
			$record->setColumnValue($prop, $this->getControlValue($item->_input, $column, $record));
		}
	}

	protected function getIsEnabled($column, $record)
	{
		return !($this->getParent()->getRecordPk() !== null
				&& $column->getIsPrimaryKey() || $column->hasSequence());
	}

	protected function getRecordPropertyValue($column, $record)
	{
		$value = $record->getColumnValue($column->getColumnId());
		if($column->getDefaultValue()!==TDbTableColumn::UNDEFINED_VALUE && $value===null)
			return $column->getDefaultValue();
		else
			return $value;
	}

	protected function setRecordPropertyValue($item, $record, $input)
	{
		$record->setColumnValue($item->getCustomData(), $input->getText());
	}

	protected function createControl($container, $column, $record)
	{
	}

	protected function getControlValue($container, $column, $record)
	{
	}
}