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
<?php
namespace Gedcomx\Rs\Client;
use Gedcomx\Gedcomx;
use GuzzleHttp\Psr7\Request;
use GuzzleHttp\Psr7\Response;
/**
* The PlaceGroupState exposes management functions for a place group.
*/
class PlaceGroupState extends GedcomxApplicationState
{
/**
* Clones the current state instance.
*
* @param \GuzzleHttp\Psr7\Request $request
* @param \GuzzleHttp\Psr7\Response $response
*
* @return \Gedcomx\Rs\Client\PlaceGroupState
*/
protected function reconstruct(Request $request, Response $response)
{
return new PlaceGroupState($this->client, $request, $response, $this->accessToken, $this->stateFactory);
}
/**
* Returns the entity from the REST API response.
*
* @return \Gedcomx\Gedcomx
*/
protected function loadEntity()
{
$json = json_decode($this->response->getBody(), true);
return new Gedcomx($json);
}
/**
* Gets the main data element represented by this state instance.
*
* @return \Gedcomx\Source\SourceDescription|null
*/
protected function getScope()
{
return $this->getPlaceGroup();
}
/**
* Gets the rel name for the current state instance.
*
* @return string
*/
public function getSelfRel()
{
return Rel::PLACE_GROUP;
}
/**
* Gets a list of place descriptions represented by the current place group.
*
* @return \Gedcomx\Source\SourceDescription|null
*/
public function getPlaceGroup()
{
if ($this->getEntity() != null) {
return $this->getEntity()->getSourceDescriptions();
}
return null;
}
}