NelmioApiDocBundle/Formatter/HtmlFormatter.php
2013-01-08 16:38:52 -08:00

168 lines
3.5 KiB
PHP
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<?php
/*
* This file is part of the NelmioApiDocBundle.
*
* (c) Nelmio <hello@nelm.io>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Nelmio\ApiDocBundle\Formatter;
use Symfony\Component\Templating\EngineInterface;
class HtmlFormatter extends AbstractFormatter
{
/**
* @var string
*/
protected $apiName;
/**
* @var string
*/
protected $endpoint;
/**
* @var string
*/
protected $defaultRequestFormat;
/**
* @var EngineInterface
*/
protected $engine;
/**
* @var boolean
*/
private $enableSandbox;
/**
* @var string
*/
private $requestFormatMethod;
/**
* @var string
*/
private $acceptType;
/**
* @var array
*/
private $authentication;
/**
* @param array $authentication
*/
public function setAuthentication(array $authentication = null)
{
$this->authentication = $authentication;
}
/**
* @param string $apiName
*/
public function setApiName($apiName)
{
$this->apiName = $apiName;
}
/**
* @param string $endpoint
*/
public function setEndpoint($endpoint)
{
$this->endpoint = $endpoint;
}
/**
* @param boolean $enableSandbox
*/
public function setEnableSandbox($enableSandbox)
{
$this->enableSandbox = $enableSandbox;
}
/**
* @param EngineInterface $engine
*/
public function setTemplatingEngine(EngineInterface $engine)
{
$this->engine = $engine;
}
/**
* @param string $acceptType
*/
public function setAcceptType($acceptType)
{
$this->acceptType = $acceptType;
}
/**
* @param string $method
*/
public function setRequestFormatMethod($method)
{
$this->requestFormatMethod = $method;
}
/**
* @param string $format
*/
public function setDefaultRequestFormat($format)
{
$this->defaultRequestFormat = $format;
}
/**
* {@inheritdoc}
*/
protected function renderOne(array $data)
{
return $this->engine->render('NelmioApiDocBundle::resource.html.twig', array_merge(
array(
'data' => $data,
'displayContent' => true,
),
$this->getGlobalVars()
));
}
/**
* {@inheritdoc}
*/
protected function render(array $collection)
{
return $this->engine->render('NelmioApiDocBundle::resources.html.twig', array_merge(
array(
'resources' => $collection,
),
$this->getGlobalVars()
));
}
/**
* @return array
*/
private function getGlobalVars()
{
return array(
'apiName' => $this->apiName,
'authentication' => $this->authentication,
'endpoint' => $this->endpoint,
'enableSandbox' => $this->enableSandbox,
'requestFormatMethod' => $this->requestFormatMethod,
'acceptType' => $this->acceptType,
'defaultRequestFormat' => $this->defaultRequestFormat,
'date' => date(DATE_RFC822),
'css' => file_get_contents(__DIR__ . '/../Resources/public/css/screen.css'),
'js' => file_get_contents(__DIR__ . '/../Resources/public/js/all.js'),
);
}
}