New router needs JavaScript and Stylesheet handlers fitting it's needs

This commit is contained in:
Thomas Gelf 2014-03-27 07:32:02 +00:00
parent b677a631f0
commit 5c89512e05
2 changed files with 46 additions and 13 deletions

View File

@ -25,15 +25,11 @@ class JavaScript
);
protected static $vendorFiles = array(
'js/vendor/jquery-2.1.0.min.js',
'js/vendor/jquery.sparkline.min.js'
// 'js/vendor/jquery-1.11.0',
'js/vendor/jquery-2.1.0',
'js/vendor/jquery.sparkline'
);
public static function listFiles()
{
return array_merge(self::$vendorFiles, self::$jsFiles, self::listModuleFiles());
}
public static function listModuleFiles()
{
$list = array();
@ -46,18 +42,29 @@ class JavaScript
}
public static function sendMinified()
{
return self::send(true);
}
public static function send($minified = false)
{
header('Content-Type: application/javascript');
$basedir = Icinga::app()->getBootstrapDirecory();
$js = $out = '';
$min = $minified ? '.min' : '';
// TODO: Cache header
header('Content-Type: text/css');
header('Content-Type: application/javascript');
$cacheFile = '/tmp/cache_icinga' . $min . '.js';
if (file_exists($cacheFile)) {
readfile($cacheFile);
exit;
}
// We do not minify vendor files
foreach (self::$vendorFiles as $file) {
$out .= file_get_contents($basedir . '/' . $file);
$out .= file_get_contents($basedir . '/' . $file . $min . '.js');
}
foreach (self::$jsFiles as $file) {
@ -69,8 +76,13 @@ class JavaScript
$js .= file_get_contents($module->getJsFilename());
}
}
$out .= Minifier::minify($js, array('flaggedComments' => false));
if ($minified) {
$out .= Minifier::minify($js, array('flaggedComments' => false));
} else {
$out .= $js;
}
// Not yet, this is for tests only. Waiting for Icinga\Web\Cache
// file_put_contents($cacheFile, $out);
echo $out;
}
}

View File

@ -34,14 +34,35 @@ class StyleSheet
return $less->compile();
}
public static function send()
public static function sendMinified()
{
self::send(true);
}
public static function send($minified = false)
{
header('Content-Type: text/css');
$min = $minified ? '.min' : '';
$cacheFile = '/tmp/cache_icinga' . $min . '.css';
if (file_exists($cacheFile)) {
readfile($cacheFile);
exit;
}
$less = new LessCompiler();
$basedir = Icinga::app()->getBootstrapDirecory();
foreach (self::$lessFiles as $file) {
$less->addFile($basedir . '/' . $file);
}
echo $less->addLoadedModules()->compile();
$less->addLoadedModules();
if ($minified) {
$less->compress();
}
$out = $less->compile();
// Not yet, this is for tests only. Waiting for Icinga\Web\Cache
// file_put_contents($cacheFile, $out);
echo $out;
}
}