entries ) > 0; } /** * Get all entries represented as plain old PHP arrays. * * @return array */ public function getEntries() { $entryPresenter = 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( $name ) { try { $this->search( $name ); } catch ( DomainException $exception ) { return; } throw new DomainException( "The \"${name}\" entry already exists." ); } /** * 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; } /** * Insert an entry into the menu. * * @param string $name A unique name identifying the menu entry * @param bool $isJSOnly Whether the menu entry works without JS * @throws DomainException When the entry already exists * @return MenuEntry */ public function insert( $name, $isJSOnly = false ) { $this->throwIfNotUnique( $name ); $this->entries[] = $entry = new MenuEntry( $name, $isJSOnly ); return $entry; } /** * Searches for a menu entry by name. * * @param string $name * @return integer If the menu entry exists, then the 0-based index of the entry; otherwise, -1 * @throws DomainException */ private function search( $name ) { $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." ); } /** * Insert an entry after an existing one. * * @param string $targetName The name of the existing entry to insert * the new entry after * @param string $name The name of the new entry * @param bool $isJSOnly Whether the entry works without JS * @throws DomainException When the existing entry doesn't exist * @return MenuEntry */ public function insertAfter( $targetName, $name, $isJSOnly = false ) { $this->throwIfNotUnique( $name ); $index = $this->search( $targetName ); $entry = new MenuEntry( $name, $isJSOnly ); array_splice( $this->entries, $index + 1, 0, [ $entry ] ); return $entry; } /** * @param string $targetName * @return IMenuEntry * @throws DomainException */ public function getEntryByName( $targetName ): IMenuEntry { $index = $this->search( $targetName ); return $this->entries[$index]; } } /** * make sure BlueSpiceMultiUpload and GrowthExperiments use the new class * @TODO remove after updating all extensions that still depend upon MenuBuilder */ class_alias( 'MediaWiki\Minerva\Menu\Group', 'MediaWiki\Minerva\MenuBuilder' );