oms-Help/Controller/BackendController.php

230 lines
6.9 KiB
PHP

<?php
/**
* Orange Management
*
* PHP Version 7.2
*
* @package Modules\Help
* @copyright Dennis Eichhorn
* @license OMS License 1.0
* @version 1.0.0
* @link http://website.orange-management.de
*/
declare(strict_types=1);
namespace Modules\Help\Controller;
use Modules\Navigation\Models\Navigation;
use Modules\Navigation\Views\NavigationView;
use phpOMS\Contract\RenderableInterface;
use phpOMS\Message\RequestAbstract;
use phpOMS\Message\ResponseAbstract;
use phpOMS\Utils\Parser\Markdown\Markdown;
use phpOMS\Module\ModuleAbstract;
use phpOMS\Module\WebInterface;
use phpOMS\Views\View;
use phpOMS\Message\Http\RequestStatusCode;
/**
* Help class.
*
* @package Modules\Help
* @license OMS License 1.0
* @link http://website.orange-management.de
* @since 1.0.0
*/
class BackendController extends Controller
{
/**
* @param RequestAbstract $request Request
* @param ResponseAbstract $response Response
* @param mixed $data Generic data
*
* @return \Serializable
*
* @since 1.0.0
* @codeCoverageIgnore
*/
public function viewHelp(RequestAbstract $request, ResponseAbstract $response, $data = null) : \Serializable
{
$view = new View($this->app, $request, $response);
$view->setTemplate('/Modules/Help/Theme/Backend/help');
return $view;
}
/**
* @param RequestAbstract $request Request
* @param ResponseAbstract $response Response
* @param mixed $data Generic data
*
* @return \Serializable
*
* @since 1.0.0
* @codeCoverageIgnore
*/
public function viewHelpGeneral(RequestAbstract $request, ResponseAbstract $response, $data = null) : \Serializable
{
$view = new View($this->app, $request, $response);
$path = $this->getHelpGeneralPath($request);
$content = Markdown::parse(\file_get_contents($path));
$navigation = Markdown::parse(\file_get_contents(__DIR__ . '/../../../Documentation/SUMMARY.md'));
$view->setTemplate('/Modules/Help/Theme/Backend/help-general');
$view->setData('content', $content);
$view->setData('navigation', $navigation);
return $view;
}
/**
* Create markdown parsing path
*
* @param RequestAbstract $request Request
*
* @return string
*
* @since 1.0.0
* @codeCoverageIgnore
*/
private function getHelpGeneralPath(RequestAbstract $request) : string
{
if ($request->getData('page') === 'README' || $request->getData('page') === null) {
$path = \realpath(__DIR__ . '/../../../Documentation/README.md');
} else {
$path = \realpath(__DIR__ . '/../../../Documentation/' . $request->getData('page') . '.md');
}
if ($path === false) {
$path = \realpath(__DIR__ . '/../../../Documentation/README.md');
}
return $path;
}
/**
* @param RequestAbstract $request Request
* @param ResponseAbstract $response Response
* @param mixed $data Generic data
*
* @return \Serializable
*
* @since 1.0.0
* @codeCoverageIgnore
*/
public function viewHelpModuleList(RequestAbstract $request, ResponseAbstract $response, $data = null) : \Serializable
{
$view = new View($this->app, $request, $response);
$view->setTemplate('/Modules/Help/Theme/Backend/help-module-list');
return $view;
}
/**
* @param RequestAbstract $request Request
* @param ResponseAbstract $response Response
* @param mixed $data Generic data
*
* @return \Serializable
*
* @since 1.0.0
* @codeCoverageIgnore
*/
public function viewHelpModule(RequestAbstract $request, ResponseAbstract $response, $data = null) : \Serializable
{
$active = $this->app->moduleManager->getActiveModules();
if ($request->getData('id') === null || !isset($active[$request->getData('id')])) {
return $this->viewHelpModuleList();
}
$view = new View($this->app, $request, $response);
$path = $this->getHelpModulePath($request);
$content = Markdown::parse(\file_get_contents($path));
$navigation = Markdown::parse(\file_get_contents(\realpath(__DIR__ . '/../../' . $request->getData('id') . '/Docs/Help/en/SUMMARY.md')));
$view->setTemplate('/Modules/Help/Theme/Backend/help-module');
$view->setData('content', $content);
$view->setData('navigation', $navigation);
return $view;
}
/**
* Create markdown parsing path
*
* @param RequestAbstract $request Request
*
* @return string
*
* @since 1.0.0
* @codeCoverageIgnore
*/
private function getHelpModulePath(RequestAbstract $request) : string
{
if ($request->getData('page') === 'table-of-contencts' || $request->getData('page') === null) {
$path = \realpath(__DIR__ . '/../../' . $request->getData('id') . '/Docs/introduction.md');
} else {
$path = \realpath(__DIR__ . '/../../' . $request->getData('id') . '/Docs/Help/en/' . $request->getData('page') . '.md');
}
if ($path === false) {
$path = \realpath(__DIR__ . '/../../' . $request->getData('id') . '/Docs/introduction.md');
}
return $path;
}
/**
* @param RequestAbstract $request Request
* @param ResponseAbstract $response Response
* @param mixed $data Generic data
*
* @return \Serializable
*
* @since 1.0.0
* @codeCoverageIgnore
*/
public function viewHelpDeveloper(RequestAbstract $request, ResponseAbstract $response, $data = null) : \Serializable
{
$view = new View($this->app, $request, $response);
$path = $this->getHelpDeveloperPath($request);
$content = Markdown::parse(\file_get_contents($path));
$navigation = Markdown::parse(\file_get_contents(__DIR__ . '/../../../Developer-Guide/SUMMARY.md'));
$view->setTemplate('/Modules/Help/Theme/Backend/help-developer');
$view->setData('content', $content);
$view->setData('navigation', $navigation);
return $view;
}
/**
* Create markdown parsing path
*
* @param RequestAbstract $request Request
*
* @return string
*
* @since 1.0.0
* @codeCoverageIgnore
*/
private function getHelpDeveloperPath(RequestAbstract $request) : string
{
if ($request->getData('page') === 'README' || $request->getData('page') === null) {
$path = \realpath(__DIR__ . '/../../../Developer-Guide/README.md');
} else {
$path = \realpath(__DIR__ . '/../../../Developer-Guide/' . $request->getData('page') . '.md');
}
if ($path === false) {
$path = \realpath(__DIR__ . '/../../../Developer-Guide/README.md');
}
return $path;
}
}