Skip to content

Commit

Permalink
Update array syntax style, broken doc blocks and namespace imports
Browse files Browse the repository at this point in the history
  • Loading branch information
robbieaverill committed Nov 15, 2018
1 parent 3ce41f6 commit 204ef6d
Show file tree
Hide file tree
Showing 2 changed files with 47 additions and 53 deletions.
55 changes: 26 additions & 29 deletions src/StringTagField.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,15 @@

namespace SilverStripe\TagField;

use Iterator;
use SilverStripe\Control\Controller;
use SilverStripe\Control\HTTPRequest;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\Core\Convert;
use SilverStripe\Forms\DropdownField;
use SilverStripe\Forms\Validator;
use SilverStripe\ORM\ArrayList;
use SilverStripe\ORM\DataList;
use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\DataObjectInterface;
use SilverStripe\ORM\SS_List;
Expand All @@ -29,7 +32,7 @@ class StringTagField extends DropdownField
* @var array
*/
private static $allowed_actions = [
'suggest'
'suggest',
];

/**
Expand Down Expand Up @@ -67,8 +70,7 @@ public function getShouldLazyLoad()

/**
* @param bool $shouldLazyLoad
*
* @return static
* @return $this
*/
public function setShouldLazyLoad($shouldLazyLoad)
{
Expand All @@ -87,8 +89,7 @@ public function getLazyLoadItemLimit()

/**
* @param int $lazyLoadItemLimit
*
* @return static
* @return $this
*/
public function setLazyLoadItemLimit($lazyLoadItemLimit)
{
Expand All @@ -107,8 +108,7 @@ public function getIsMultiple()

/**
* @param bool $isMultiple
*
* @return static
* @return $this
*/
public function setIsMultiple($isMultiple)
{
Expand All @@ -135,7 +135,6 @@ public function getRecord()

/**
* @param DataObject $record
*
* @return $this
*/
public function setRecord(DataObject $record)
Expand All @@ -148,7 +147,7 @@ public function setRecord(DataObject $record)
/**
* {@inheritdoc}
*/
public function Field($properties = array())
public function Field($properties = [])
{
Requirements::css('silverstripe/tagfield:css/select2.min.css');
Requirements::css('silverstripe/tagfield:css/TagField.css');
Expand All @@ -165,9 +164,9 @@ public function Field($properties = array())
if ($this->getShouldLazyLoad()) {
$this->setAttribute('data-ss-tag-field-suggest-url', $this->getSuggestURL());
} else {
$properties = array_merge($properties, array(
$properties = array_merge($properties, [
'Options' => $this->getOptions()
));
]);
}

$this->setAttribute('data-can-create', (int) $this->getCanCreate());
Expand Down Expand Up @@ -202,11 +201,11 @@ protected function getOptions()

foreach ($source as $value) {
$options->push(
ArrayData::create(array(
ArrayData::create([
'Title' => $value,
'Value' => $value,
'Selected' => in_array($value, $values),
))
])
);
}

Expand All @@ -231,8 +230,8 @@ public function setValue($value, $source = null)
$value = $source->column('ID');
}

if (is_null($value)) {
$value = array();
if ($value === null) {
$value = [];
}

return parent::setValue(array_filter($value));
Expand All @@ -245,7 +244,7 @@ public function getAttributes()
{
return array_merge(
parent::getAttributes(),
array('name' => $this->getName() . '[]')
['name' => $this->getName() . '[]']
);
}

Expand All @@ -258,7 +257,7 @@ public function saveInto(DataObjectInterface $record)

$name = $this->getName();

$record->$name = join(',', $this->Value());
$record->$name = implode(',', $this->Value());
$record->write();
}

Expand All @@ -271,22 +270,22 @@ public function saveInto(DataObjectInterface $record)
public function suggest(HTTPRequest $request)
{
$responseBody = json_encode(
array('items' => array())
['items' => []]
);

$response = new HTTPResponse;
$response = HTTPResponse::create();
$response->addHeader('Content-Type', 'application/json');

if ($record = $this->getRecord()) {
$tags = array();
$tags = [];
$term = $request->getVar('term');

if ($record->hasField($this->getName())) {
$tags = $this->getTags($term);
}

$responseBody = json_encode(
array('items' => $tags)
['items' => $tags]
);
}

Expand All @@ -299,23 +298,22 @@ public function suggest(HTTPRequest $request)
* Returns array of arrays representing tags.
*
* @param string $term
*
* @return array
*/
protected function getTags($term)
{
$record = $this->getRecord();

if (!$record) {
return array();
return [];
}

$fieldName = $this->getName();
$className = $record->getClassName();

$term = Convert::raw2sql($term);

$query = $className::get()
$query = DataList::create($className)
->filter($fieldName . ':PartialMatch:nocase', $term)
->limit($this->getLazyLoadItemLimit());

Expand All @@ -326,10 +324,10 @@ protected function getTags($term)

foreach ($tags as $i => $tag) {
if (stripos($tag, $term) !== false && !in_array($tag, $items)) {
$items[] = array(
$items[] = [
'id' => $tag,
'text' => $tag
);
'text' => $tag,
];
}
}
}
Expand Down Expand Up @@ -359,8 +357,7 @@ public function getCanCreate()

/**
* @param bool $canCreate
*
* @return static
* @return $this
*/
public function setCanCreate($canCreate)
{
Expand Down
45 changes: 21 additions & 24 deletions src/TagField.php
Original file line number Diff line number Diff line change
Expand Up @@ -5,9 +5,9 @@
use SilverStripe\Control\Controller;
use SilverStripe\Control\HTTPRequest;
use SilverStripe\Control\HTTPResponse;
use SilverStripe\Core\Convert;
use SilverStripe\Core\Injector\Injector;
use SilverStripe\Forms\DropdownField;
use SilverStripe\Forms\Validator;
use SilverStripe\ORM\ArrayList;
use SilverStripe\ORM\DataList;
use SilverStripe\ORM\DataObject;
Expand All @@ -27,9 +27,9 @@ class TagField extends DropdownField
/**
* @var array
*/
private static $allowed_actions = array(
'suggest'
);
private static $allowed_actions = [
'suggest',
];

/**
* @var bool
Expand Down Expand Up @@ -198,7 +198,7 @@ public function setSourceList($sourceList)
/**
* {@inheritdoc}
*/
public function Field($properties = array())
public function Field($properties = [])
{
Requirements::css('silverstripe/tagfield:client/dist/styles/bundle.css');
Requirements::javascript('silverstripe/tagfield:client/dist/js/bundle.js');
Expand All @@ -219,6 +219,7 @@ public function Field($properties = array())
}
$schema['optionUrl'] = $this->getSuggestURL();
}

$this->setAttribute('data-schema', json_encode($schema));

$this->addExtraClass('ss-tag-field');
Expand Down Expand Up @@ -275,10 +276,10 @@ protected function formatOptions(DataList $source)

foreach ($source as $object) {
$options->push(
ArrayData::create(array(
ArrayData::create([
'Title' => $object->$titleField,
'Value' => $object->Title,
))
])
);
}

Expand Down Expand Up @@ -316,13 +317,12 @@ public function saveInto(DataObjectInterface $record)

$name = $this->getName();
$titleField = $this->getTitleField();
$source = $this->getSource();
$values = $this->Value();
$relation = $record->$name();
$ids = array();
$ids = [];

if (!$values) {
$values = array();
$values = [];
}
if (empty($record) || empty($titleField)) {
return;
Expand Down Expand Up @@ -350,12 +350,11 @@ public function saveInto(DataObjectInterface $record)
* Get or create tag with the given value
*
* @param string $term
* @return DataObject
* @return DataObject|bool
*/
protected function getOrCreateTag($term)
{
// Check if existing record can be found
/** @var DataList $source */
$source = $this->getSourceList();
$titleField = $this->getTitleField();
$record = $source
Expand All @@ -372,9 +371,9 @@ protected function getOrCreateTag($term)
$record->{$titleField} = $term;
$record->write();
return $record;
} else {
return false;
}

return false;
}

/**
Expand All @@ -387,9 +386,9 @@ public function suggest(HTTPRequest $request)
{
$tags = $this->getTags($request->getVar('term'));

$response = new HTTPResponse();
$response = HTTPResponse::create();
$response->addHeader('Content-Type', 'application/json');
$response->setBody(json_encode(array('items' => $tags)));
$response->setBody(json_encode(['items' => $tags]));

return $response;
}
Expand All @@ -402,9 +401,6 @@ public function suggest(HTTPRequest $request)
*/
protected function getTags($term)
{
/**
* @var array $source
*/
$source = $this->getSourceList();

$titleField = $this->getTitleField();
Expand All @@ -415,13 +411,13 @@ protected function getTags($term)
->limit($this->getLazyLoadItemLimit());

// Map into a distinct list
$items = array();
$items = [];
$titleField = $this->getTitleField();
foreach ($query->map('ID', $titleField) as $id => $title) {
$items[$title] = array(
$items[$title] = [
'id' => $title,
'text' => $title
);
'text' => $title,
];
}

return array_values($items);
Expand All @@ -442,10 +438,11 @@ public function validate($validator)
/**
* Converts the field to a readonly variant.
*
* @return TagField_Readonly
* @return ReadonlyTagField
*/
public function performReadonlyTransformation()
{
/** @var ReadonlyTagField $copy */
$copy = $this->castedCopy(ReadonlyTagField::class);
$copy->setSourceList($this->getSourceList());
return $copy;
Expand Down

0 comments on commit 204ef6d

Please sign in to comment.