2007-07-19 10:40:28 +00:00
|
|
|
<?php
|
2016-08-19 10:51:35 +12:00
|
|
|
|
|
|
|
namespace SilverStripe\View;
|
|
|
|
|
|
|
|
use SilverStripe\ORM\ArrayLib;
|
|
|
|
use InvalidArgumentException;
|
|
|
|
use stdClass;
|
|
|
|
|
2008-02-25 02:10:37 +00:00
|
|
|
/**
|
2011-03-25 17:29:33 +13:00
|
|
|
* Lets you wrap a bunch of array data, or object members, into a {@link ViewableData} object.
|
2007-07-19 10:40:28 +00:00
|
|
|
*
|
2008-02-25 02:10:37 +00:00
|
|
|
* <code>
|
2007-07-19 10:40:28 +00:00
|
|
|
* new ArrayData(array(
|
|
|
|
* "ClassName" => "Page",
|
|
|
|
* "AddAction" => "Add a new Page page",
|
|
|
|
* ));
|
2008-02-25 02:10:37 +00:00
|
|
|
* </code>
|
2007-07-19 10:40:28 +00:00
|
|
|
*/
|
|
|
|
class ArrayData extends ViewableData {
|
2007-10-20 08:36:47 +00:00
|
|
|
|
2010-10-18 22:39:19 +00:00
|
|
|
/**
|
2015-07-27 22:31:18 +12:00
|
|
|
* @var array
|
2010-10-18 22:39:19 +00:00
|
|
|
* @see ArrayData::_construct()
|
|
|
|
*/
|
2007-07-19 10:40:28 +00:00
|
|
|
protected $array;
|
2015-07-27 22:31:18 +12:00
|
|
|
|
2008-02-25 02:10:37 +00:00
|
|
|
/**
|
2011-03-25 17:29:33 +13:00
|
|
|
* @param object|array $value An associative array, or an object with simple properties.
|
|
|
|
* Converts object properties to keys of an associative array.
|
2008-02-25 02:10:37 +00:00
|
|
|
*/
|
2011-03-25 17:29:33 +13:00
|
|
|
public function __construct($value) {
|
|
|
|
if (is_object($value)) {
|
|
|
|
$this->array = get_object_vars($value);
|
|
|
|
} elseif (ArrayLib::is_associative($value)) {
|
|
|
|
$this->array = $value;
|
|
|
|
} elseif (is_array($value) && count($value) === 0) {
|
|
|
|
$this->array = array();
|
2008-02-25 02:10:37 +00:00
|
|
|
} else {
|
2011-03-25 17:29:33 +13:00
|
|
|
$message = 'Parameter to ArrayData constructor needs to be an object or associative array';
|
|
|
|
throw new InvalidArgumentException($message);
|
2008-02-25 02:10:37 +00:00
|
|
|
}
|
2009-03-04 03:44:11 +00:00
|
|
|
parent::__construct();
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
2015-07-27 22:31:18 +12:00
|
|
|
|
2010-10-18 22:39:19 +00:00
|
|
|
/**
|
|
|
|
* Get the source array
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
2011-03-27 21:37:06 +11:00
|
|
|
public function toMap() {
|
2010-10-18 22:39:19 +00:00
|
|
|
return $this->array;
|
|
|
|
}
|
2015-07-27 22:31:18 +12:00
|
|
|
|
2010-10-18 22:39:19 +00:00
|
|
|
/**
|
2011-03-25 17:29:33 +13:00
|
|
|
* Gets a field from this object.
|
2010-10-18 22:39:19 +00:00
|
|
|
*
|
2011-03-25 17:29:33 +13:00
|
|
|
*
|
|
|
|
* If the value is an object but not an instance of
|
|
|
|
* ViewableData, it will be converted recursively to an
|
|
|
|
* ArrayData.
|
|
|
|
*
|
|
|
|
* If the value is an associative array, it will likewise be
|
|
|
|
* converted recursively to an ArrayData.
|
2016-08-19 10:51:35 +12:00
|
|
|
*
|
|
|
|
* @param string $field
|
|
|
|
* @return mixed
|
2010-10-18 22:39:19 +00:00
|
|
|
*/
|
2016-08-19 10:51:35 +12:00
|
|
|
public function getField($field) {
|
|
|
|
$value = $this->array[$field];
|
2011-03-25 17:29:33 +13:00
|
|
|
if (is_object($value) && !$value instanceof ViewableData) {
|
|
|
|
return new ArrayData($value);
|
|
|
|
} elseif (ArrayLib::is_associative($value)) {
|
|
|
|
return new ArrayData($value);
|
2012-12-09 00:20:20 +13:00
|
|
|
} else {
|
2011-03-25 17:29:33 +13:00
|
|
|
return $value;
|
2007-10-20 08:36:47 +00:00
|
|
|
}
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
2010-10-15 03:47:27 +00:00
|
|
|
/**
|
|
|
|
* Add or set a field on this object.
|
|
|
|
*
|
|
|
|
* @param string $field
|
|
|
|
* @param mixed $value
|
2016-06-03 20:51:02 +12:00
|
|
|
* @return $this
|
2010-10-15 03:47:27 +00:00
|
|
|
*/
|
|
|
|
public function setField($field, $value) {
|
|
|
|
$this->array[$field] = $value;
|
2016-06-03 20:51:02 +12:00
|
|
|
return $this;
|
2010-10-15 03:47:27 +00:00
|
|
|
}
|
2015-07-27 22:31:18 +12:00
|
|
|
|
2010-10-18 22:39:19 +00:00
|
|
|
/**
|
|
|
|
* Check array to see if field isset
|
|
|
|
*
|
2016-08-19 10:51:35 +12:00
|
|
|
* @param string $field Field Key
|
2010-10-18 22:39:19 +00:00
|
|
|
* @return bool
|
|
|
|
*/
|
2016-08-19 10:51:35 +12:00
|
|
|
public function hasField($field) {
|
|
|
|
return isset($this->array[$field]);
|
2007-07-19 10:40:28 +00:00
|
|
|
}
|
2015-07-27 22:31:18 +12:00
|
|
|
|
2011-03-23 10:23:57 +13:00
|
|
|
/**
|
|
|
|
* Converts an associative array to a simple object
|
|
|
|
*
|
|
|
|
* @param array
|
2016-02-23 18:09:58 +13:00
|
|
|
* @return stdClass $obj
|
2011-03-23 10:23:57 +13:00
|
|
|
*/
|
|
|
|
public static function array_to_object($arr = null) {
|
|
|
|
$obj = new stdClass();
|
|
|
|
if ($arr) foreach($arr as $name => $value) $obj->$name = $value;
|
|
|
|
return $obj;
|
|
|
|
}
|
2011-03-27 21:37:06 +11:00
|
|
|
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|