interface Sortable implements SS_List

Additional interface for {@link SS_List} classes that are sortable.

All methods in this interface are immutable - they should return new instances with the sort applied, rather than applying the sort in place

Methods

array
toArray()

Returns all the items in the list in an array.

from SS_List
array
toNestedArray()

Returns the contents of the list as an array of maps.

from SS_List
add(mixed $item)

Adds an item to the list, making no guarantees about where it will appear.

from SS_List
remove(mixed $item)

Removes an item from the list.

from SS_List
mixed
first()

Returns the first item in the list.

from SS_List
mixed
last()

Returns the last item in the list.

from SS_List
Map
map(string $keyfield = 'ID', string $titlefield = 'Title')

Returns a map of a key field to a value field of all the items in the list.

from SS_List
mixed
find(string $key, mixed $value)

Returns the first item in the list where the key field is equal to the value.

from SS_List
array
column(string $colName = "ID")

Returns an array of a single field value for all items in the list.

from SS_List
$this
each(callable $callback)

Walks the list using the specified callback

from SS_List
bool
canSortBy(string $by)

Returns TRUE if the list can be sorted by a field.

sort()

Return a new instance of this list that is sorted 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.

reverse()

Return a new instance of this list based on reversing the current sort.

Details

in SS_List at line 20
array toArray()

Returns all the items in the list in an array.

Return Value

array

in SS_List at line 27
array toNestedArray()

Returns the contents of the list as an array of maps.

Return Value

array

in SS_List at line 35
add(mixed $item)

Adds an item to the list, making no guarantees about where it will appear.

Parameters

mixed $item

in SS_List at line 42
remove(mixed $item)

Removes an item from the list.

Parameters

mixed $item

in SS_List at line 49
mixed first()

Returns the first item in the list.

Return Value

mixed

in SS_List at line 56
mixed last()

Returns the last item in the list.

Return Value

mixed

in SS_List at line 66
Map map(string $keyfield = 'ID', string $titlefield = 'Title')

Returns a map of a key field to a value field of all the items in the list.

Parameters

string $keyfield
string $titlefield

Return Value

Map

in SS_List at line 76
mixed find(string $key, mixed $value)

Returns the first item in the list where the key field is equal to the value.

Parameters

string $key
mixed $value

Return Value

mixed

in SS_List at line 84
array column(string $colName = "ID")

Returns an array of a single field value for all items in the list.

Parameters

string $colName

Return Value

array

in SS_List at line 92
$this each(callable $callback)

Walks the list using the specified callback

Parameters

callable $callback

Return Value

$this

at line 22
bool canSortBy(string $by)

Returns TRUE if the list can be sorted by a field.

Parameters

string $by

Return Value

bool

at line 34
Sortable sort()

Return a new instance of this list that is sorted 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.

Return Value

Sortable

at line 43
Sortable reverse()

Return a new instance of this list based on reversing the current sort.

Return Value

Sortable