2011-04-19 17:03:23 +10:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* An interface that a class can implement to be treated as a list container.
|
|
|
|
*
|
|
|
|
* @package sapphire
|
|
|
|
* @subpackage model
|
|
|
|
*/
|
|
|
|
interface SS_List extends ArrayAccess, Countable, IteratorAggregate {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns all the items in the list in an array.
|
|
|
|
*
|
|
|
|
* @return arary
|
|
|
|
*/
|
|
|
|
public function toArray();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the contents of the list as an array of maps.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function toNestedArray();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a subset of the items within the list.
|
|
|
|
*
|
|
|
|
* @param int $offset
|
|
|
|
* @param int $length
|
|
|
|
* @return SS_List
|
|
|
|
*/
|
|
|
|
public function getRange($offset, $length);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds an item to the list, making no guarantees about where it will
|
|
|
|
* appear.
|
|
|
|
*
|
|
|
|
* @param mixed $item
|
|
|
|
*/
|
|
|
|
public function add($item);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes an item from the list.
|
|
|
|
*
|
|
|
|
* @param mixed $item
|
|
|
|
*/
|
|
|
|
public function remove($item);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the first item in the list.
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function first();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the last item in the list.
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function last();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns a map of a key field to a value field of all the items in the
|
|
|
|
* list.
|
|
|
|
*
|
|
|
|
* @param string $keyfield
|
|
|
|
* @param string $titlefield
|
|
|
|
* @return array
|
|
|
|
*/
|
2011-10-22 15:42:46 +02:00
|
|
|
public function map($keyfield = 'ID', $titlefield = 'Title');
|
2011-04-19 17:03:23 +10:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the first item in the list where the key field is equal to the
|
|
|
|
* value.
|
|
|
|
*
|
|
|
|
* @param string $key
|
|
|
|
* @param mixed $value
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function find($key, $value);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns an array of a single field value for all items in the list.
|
|
|
|
*
|
2011-12-07 14:35:30 +13:00
|
|
|
* @param string $colName
|
2011-04-19 17:03:23 +10:00
|
|
|
* @return array
|
|
|
|
*/
|
2011-10-22 15:42:46 +02:00
|
|
|
public function column($colName = "ID");
|
2011-04-19 17:03:23 +10:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns TRUE if the list can be sorted by a field.
|
|
|
|
*
|
|
|
|
* @param string $by
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function canSortBy($by);
|
|
|
|
|
|
|
|
/**
|
2011-12-09 10:08:46 +13:00
|
|
|
* Sorts this list by one or more fields. You can either pass in a single
|
|
|
|
* field name and direction, or a map of field names to sort directions.
|
2011-04-19 17:03:23 +10:00
|
|
|
*
|
2011-12-09 10:08:46 +13:00
|
|
|
* @example $list->sort('Name'); // default ASC sorting
|
|
|
|
* @example $list->sort('Name DESC'); // DESC sorting
|
|
|
|
* @example $list->sort('Name', 'ASC');
|
|
|
|
* @example $list->sort(array('Name'=>'ASC,'Age'=>'DESC'));
|
2011-04-19 17:03:23 +10:00
|
|
|
*/
|
2011-12-09 10:08:46 +13:00
|
|
|
public function sort();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Filter the list to include items with these charactaristics
|
|
|
|
*
|
|
|
|
* @example $list->filter('Name', 'bob'); // only bob in the list
|
|
|
|
* @example $list->filter('Name', array('aziz', 'bob'); // aziz and bob in list
|
|
|
|
* @example $list->filter(array('Name'=>'bob, 'Age'=>21)); // bob with the age 21
|
|
|
|
* @example $list->filter(array('Name'=>'bob, 'Age'=>array(21, 43))); // bob with the Age 21 or 43
|
|
|
|
* @example $list->filter(array('Name'=>array('aziz','bob'), 'Age'=>array(21, 43))); // aziz with the age 21 or 43 and bob with the Age 21 or 43
|
|
|
|
*/
|
|
|
|
public function filter();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Exclude the list to not contain items with these charactaristics
|
|
|
|
*
|
|
|
|
* @example $list->exclude('Name', 'bob'); // exclude bob from list
|
|
|
|
* @example $list->exclude('Name', array('aziz', 'bob'); // exclude aziz and bob from list
|
|
|
|
* @example $list->exclude(array('Name'=>'bob, 'Age'=>21)); // exclude bob that has Age 21
|
|
|
|
* @example $list->exclude(array('Name'=>'bob, 'Age'=>array(21, 43))); // exclude bob with Age 21 or 43
|
|
|
|
* @example $list->exclude(array('Name'=>array('bob','phil'), 'Age'=>array(21, 43))); // bob age 21 or 43, phil age 21 or 43 would be excluded
|
|
|
|
*/
|
|
|
|
public function exclude();
|
2011-04-19 17:03:23 +10:00
|
|
|
|
|
|
|
}
|