diff options
| author | MaZderMind | 2018-05-12 11:26:14 +0200 | 
|---|---|---|
| committer | MaZderMind | 2018-05-12 11:26:14 +0200 | 
| commit | 59f7c88ac3c8454eb0812dcb044e2854d9241001 (patch) | |
| tree | 8688ac2112062252ed77961ed9289065c929041d /model/Room.php | |
| parent | 2cf00ac475500f007bce90cf81d8d582208650c9 (diff) | |
| parent | 622b1f030c5c931704b7e997918dad2dcfd48551 (diff) | |
Merge branch 'feature/talkinfo-in-json'
Diffstat (limited to '')
| -rw-r--r-- | model/Room.php | 20 | 
1 files changed, 20 insertions, 0 deletions
| diff --git a/model/Room.php b/model/Room.php index 7089532..3552f60 100644 --- a/model/Room.php +++ b/model/Room.php @@ -4,6 +4,7 @@ class Room  {  	private $slug;  	private $conference; +	private $talks;  	public function __construct(Conference $conference, $slug)  	{ @@ -16,8 +17,27 @@ class Room  			throw new NotFoundException('Room '.$slug);  		$this->slug = $slug; + +		$schedule = $conference->getSchedule(); +		$talksPerRoom = $schedule->getSchedule(); +		$scheduleName = $this->getScheduleName(); + +		$this->talks = isset($talksPerRoom[$scheduleName]) ? $talksPerRoom[$scheduleName] : [];  	} +	public function getCurrentTalk($now) +	{ +		return array_filter_last($this->talks, function($talk) use ($now) { +			return $talk['start'] < $now && $talk['end'] > $now; +		}); +	} + +	public function getNextTalk($now) +	{ +		return array_filter_first($this->talks, function($talk) use ($now) { +			return !isset($talk['special']) && $talk['start'] > $now; +		}); +	}  	public function getConference() {  		return $this->conference; | 
