aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRoeland Jago Douma <roeland@famdouma.nl>2016-11-30 22:09:36 +0100
committerRoeland Jago Douma <roeland@famdouma.nl>2017-01-06 09:42:14 +0100
commit7bd9087f9e2dbf3cc5ae7d728a9583caa3f96e80 (patch)
treea96a6c331522b902a5e1ca183284411c11afe0d2
parentd64d661ef5097bd5b5065f0f7df02f19a7442420 (diff)
downloadnextcloud-server-7bd9087f9e2dbf3cc5ae7d728a9583caa3f96e80.tar.gz
nextcloud-server-7bd9087f9e2dbf3cc5ae7d728a9583caa3f96e80.zip
Inject SCSSCacher
Signed-off-by: Roeland Jago Douma <roeland@famdouma.nl>
-rwxr-xr-xlib/private/Template/CSSResourceLocator.php40
-rw-r--r--lib/private/TemplateLayout.php12
2 files changed, 19 insertions, 33 deletions
diff --git a/lib/private/Template/CSSResourceLocator.php b/lib/private/Template/CSSResourceLocator.php
index 757c0232ca7..34b4d08929a 100755
--- a/lib/private/Template/CSSResourceLocator.php
+++ b/lib/private/Template/CSSResourceLocator.php
@@ -25,33 +25,22 @@
namespace OC\Template;
-use OC\SystemConfig;
-use OCP\Files\IAppData;
use OCP\ILogger;
-use OCP\IURLGenerator;
class CSSResourceLocator extends ResourceLocator {
- /** @var IAppData */
- protected $appData;
- /** @var IURLGenerator */
- protected $urlGenerator;
- /** @var SystemConfig */
- protected $systemConfig;
+ /** @var SCSSCacher */
+ protected $scssCacher;
/**
* @param ILogger $logger
* @param string $theme
* @param array $core_map
* @param array $party_map
- * @param IAppData $appData
- * @param IURLGenerator $urlGenerator
- * @param SystemConfig $systemConfig
+ * @param SCSSCacher $scssCcacher
*/
- public function __construct(ILogger $logger, $theme, $core_map, $party_map, IAppData $appData, IURLGenerator $urlGenerator, SystemConfig $systemConfig) {
- $this->appData = $appData;
- $this->urlGenerator = $urlGenerator;
- $this->systemConfig = $systemConfig;
+ public function __construct(ILogger $logger, $theme, $core_map, $party_map, SCSSCacher $scssCacher) {
+ $this->scssCacher = $scssCacher;
parent::__construct($logger, $theme, $core_map, $party_map);
}
@@ -62,8 +51,8 @@ class CSSResourceLocator extends ResourceLocator {
public function doFind($style) {
if (strpos($style, '3rdparty') === 0
&& $this->appendIfExist($this->thirdpartyroot, $style.'.css')
- || $this->cacheAndAppendScssIfExist($this->serverroot, $style.'.scss', $this->appData, $this->urlGenerator, $this->systemConfig)
- || $this->cacheAndAppendScssIfExist($this->serverroot, 'core/'.$style.'.scss', $this->appData, $this->urlGenerator, $this->systemConfig)
+ || $this->cacheAndAppendScssIfExist($this->serverroot, $style.'.scss')
+ || $this->cacheAndAppendScssIfExist($this->serverroot, 'core/'.$style.'.scss')
|| $this->appendIfExist($this->serverroot, $style.'.css')
|| $this->appendIfExist($this->serverroot, 'core/'.$style.'.css')
) {
@@ -91,22 +80,13 @@ class CSSResourceLocator extends ResourceLocator {
*
* @param string $root path to check
* @param string $file the filename
- * @param IAppData $appData
- * @param IURLGenerator $urlGenerator
- * @param SystemConfig $systemConfig
* @param string|null $webRoot base for path, default map $root to $webRoot
* @return bool True if the resource was found and cached, false otherwise
*/
- protected function cacheAndAppendScssIfExist($root, $file, IAppData $appData, IURLGenerator $urlGenerator, SystemConfig $systemConfig, $webRoot = null) {
+ protected function cacheAndAppendScssIfExist($root, $file, $webRoot = null) {
if (is_file($root.'/'.$file)) {
- $scssCache = new SCSSCacher(
- $this->logger,
- $appData,
- $urlGenerator,
- $systemConfig);
-
- if($scssCache->process($root, $file)) {
- $this->append($root, $scssCache->getCachedSCSS('core', $file), $webRoot, false);
+ if($this->scssCacher->process($root, $file)) {
+ $this->append($root, $this->scssCacher->getCachedSCSS('core', $file), $webRoot, false);
return true;
} else {
$this->logger->error('Failed to compile and/or save '.$root.'/'.$file, ['app' => 'core']);
diff --git a/lib/private/TemplateLayout.php b/lib/private/TemplateLayout.php
index 8ba5bc561f0..67ba831dfaf 100644
--- a/lib/private/TemplateLayout.php
+++ b/lib/private/TemplateLayout.php
@@ -36,6 +36,7 @@
namespace OC;
use OC\Template\JSConfigHelper;
+use OC\Template\SCSSCacher;
class TemplateLayout extends \OC_Template {
@@ -193,14 +194,19 @@ class TemplateLayout extends \OC_Template {
// Read the selected theme from the config file
$theme = \OC_Util::getTheme();
+ $SCSSCacher = new SCSSCacher(
+ \OC::$server->getLogger(),
+ \OC::$server->getAppDataDir('css'),
+ \OC::$server->getURLGenerator(),
+ \OC::$server->getSystemConfig()
+ );
+
$locator = new \OC\Template\CSSResourceLocator(
\OC::$server->getLogger(),
$theme,
array( \OC::$SERVERROOT => \OC::$WEBROOT ),
array( \OC::$SERVERROOT => \OC::$WEBROOT ),
- \OC::$server->getAppDataDir('css'),
- \OC::$server->getURLGenerator(),
- \OC::$server->getSystemConfig());
+ $SCSSCacher);
$locator->find($styles);
return $locator->getResources();
}