id = $id; } /** * Get the identifier for the group * * @return string */ public function getId() { return $this->id; } /** * Return entries count * * @return bool */ public function hasEntries(): bool { return count( $this->entries ) > 0; } /** * Get all entries represented as plain old PHP arrays. * * @return array */ public function getEntries(): array { $entryPresenter = static function ( IMenuEntry $entry ) { $result = [ 'name' => $entry->getName(), 'components' => $entry->getComponents(), ]; $classes = $entry->getCSSClasses(); if ( $classes ) { $result[ 'class' ] = implode( ' ', $classes ); } return $result; }; return array_map( $entryPresenter, $this->entries ); } /** * Helper method to verify that the $name of entry is unique (do not exists * in current Group ) * @param string $name * @throws DomainException When the entry already exists */ private function throwIfNotUnique( string $name ): void { try { $this->search( $name ); } catch ( DomainException $exception ) { return; } throw new DomainException( "The \"{$name}\" entry already exists." ); } /** * Prepend new menu entry * @param IMenuEntry $entry * @throws DomainException When the entry already exists */ public function prependEntry( IMenuEntry $entry ): void { $this->throwIfNotUnique( $entry->getName() ); array_unshift( $this->entries, $entry ); } /** * Insert new menu entry * @param IMenuEntry $entry * @throws DomainException When the entry already exists */ public function insertEntry( IMenuEntry $entry ) { $this->throwIfNotUnique( $entry->getName() ); $this->entries[] = $entry; } /** * Searches for a menu entry by name. * * @param string $name * @return int If the menu entry exists, then the 0-based index of the entry; otherwise, -1 * @throws DomainException */ private function search( string $name ): int { $count = count( $this->entries ); for ( $i = 0; $i < $count; ++$i ) { if ( $this->entries[$i]->getName() === $name ) { return $i; } } throw new DomainException( "The \"{$name}\" entry doesn't exist." ); } /** * @param string $targetName * @return IMenuEntry * @throws DomainException */ public function getEntryByName( string $targetName ): IMenuEntry { $index = $this->search( $targetName ); return $this->entries[$index]; } /** * Serialize the group for use in a template * @return array{entries:array,id:string} */ public function serialize(): array { return [ 'entries' => $this->getEntries(), 'id' => $this->getId(), ]; } }