HummingBirdAnimeClient/src/MenuGenerator.php

116 lines
2.5 KiB
PHP
Raw Normal View History

2016-10-20 22:09:36 -04:00
<?php declare(strict_types=1);
2015-11-16 11:40:01 -05:00
/**
* Hummingbird Anime List Client
2015-11-16 11:40:01 -05:00
*
* An API client for Kitsu and MyAnimeList to manage anime and manga watch lists
2015-11-16 11:40:01 -05:00
*
2016-10-20 22:09:36 -04:00
* PHP version 7
2016-08-30 10:01:18 -04:00
*
2015-11-16 11:40:01 -05:00
* @package HummingbirdAnimeClient
2016-08-30 10:01:18 -04:00
* @author Timothy J. Warren <tim@timshomepage.net>
* @copyright 2015 - 2017 Timothy J. Warren
2016-08-30 10:01:18 -04:00
* @license http://www.opensource.org/licenses/mit-license.html MIT License
* @version 4.0
* @link https://git.timshomepage.net/timw4mail/HummingBirdAnimeClient
2015-11-16 11:40:01 -05:00
*/
namespace Aviat\AnimeClient;
2017-03-30 16:16:40 -04:00
use Aviat\Ion\{ArrayWrapper, StringWrapper};
use Aviat\Ion\Di\ContainerInterface;
/**
* Helper object to manage menu creation and selection
*/
2015-10-09 14:34:55 -04:00
class MenuGenerator extends UrlGenerator {
2016-10-20 22:09:36 -04:00
use ArrayWrapper;
use StringWrapper;
/**
* Html generation helper
*
2017-02-22 14:46:35 -05:00
* @var \Aura\Html\HelperLocator
*/
protected $helper;
2015-10-09 14:34:55 -04:00
/**
* Request object
*
2017-02-22 15:08:29 -05:00
* @var \Psr\Http\Message\RequestInterface
2015-10-09 14:34:55 -04:00
*/
protected $request;
/**
* Create menu generator
*
* @param ContainerInterface $container
*/
public function __construct(ContainerInterface $container)
{
parent::__construct($container);
$this->helper = $container->get('html-helper');
2015-10-09 14:34:55 -04:00
$this->request = $container->get('request');
}
/**
* Generate the full menu structure from the config files
*
2015-11-16 15:57:37 -05:00
* @param array $menus
* @return array
*/
2017-02-16 14:30:06 -05:00
protected function parseConfig(array $menus)
{
$parsed = [];
2015-10-15 09:25:30 -04:00
foreach ($menus as $name => $menu)
{
$parsed[$name] = [];
foreach ($menu['items'] as $path_name => $partial_path)
{
$title = (string)$this->string($path_name)->humanize()->titleize();
$parsed[$name][$title] = (string)$this->string($menu['route_prefix'])->append($partial_path);
}
}
return $parsed;
}
/**
* Generate the html structure of the menu selected
*
* @param string $menu
* @return string
*/
public function generate($menu)
{
2015-10-15 09:25:30 -04:00
$menus = $this->config->get('menus');
2017-02-16 14:30:06 -05:00
$parsedConfig = $this->parseConfig($menus);
2015-10-09 14:34:55 -04:00
// Bail out early on invalid menu
2017-02-16 14:30:06 -05:00
if ( ! $this->arr($parsedConfig)->hasKey($menu))
2015-10-09 14:34:55 -04:00
{
return '';
}
2017-02-16 14:30:06 -05:00
$menuConfig = $parsedConfig[$menu];
2017-02-16 14:30:06 -05:00
foreach ($menuConfig as $title => $path)
2015-10-09 14:34:55 -04:00
{
$has = $this->string($this->path())->contains($path);
2017-04-17 16:13:36 -04:00
$selected = ($has && mb_strlen($this->path()) >= mb_strlen($path));
2015-10-09 14:34:55 -04:00
$link = $this->helper->a($this->url($path), $title);
2015-10-09 14:34:55 -04:00
$attrs = ($selected)
? ['class' => 'selected']
: [];
2015-10-09 14:34:55 -04:00
$this->helper->ul()->rawItem($link, $attrs);
}
2015-10-09 14:34:55 -04:00
// Create the menu html
return $this->helper->ul();
}
}
// End of MenuGenerator.php