silverstripe-webpack/app/src/Templates/DeferedRequirements.php

169 lines
5.7 KiB
PHP
Raw Normal View History

2018-02-22 14:39:58 +01:00
<?php
2018-04-21 06:29:32 +02:00
namespace Site\Templates;
use SilverStripe\Control\Controller;
2018-03-24 11:45:31 +01:00
use SilverStripe\View\TemplateGlobalProvider;
use SilverStripe\View\Requirements;
use SilverStripe\Core\Config\Config;
use SilverStripe\Control\Director;
use SilverStripe\Core\Path;
use SilverStripe\Core\Manifest\ManifestFileFinder;
2018-04-21 05:36:06 +02:00
class DeferedRequirements implements TemplateGlobalProvider
{
2018-02-22 14:39:58 +01:00
private static $css = [];
private static $js = [];
private static $defered = false;
private static $static_domain;
private static $version;
2018-07-25 11:03:50 +02:00
private static $nojquery = false;
private static $nofontawesome = false;
2018-08-26 12:46:03 +02:00
private static $custom_requirements = [];
2018-02-22 14:39:58 +01:00
/**
* @return array
*/
public static function get_template_global_variables()
{
return [
'AutoRequirements' => 'Auto',
'DeferedCSS' => 'loadCSS',
'DeferedJS' => 'loadJS',
];
}
public static function Auto($class = false)
{
2018-07-25 11:03:50 +02:00
$config = Config::inst()->get(self::class);
2019-04-11 00:15:29 +02:00
$themeName = WebpackTemplateProvider::themeName();
2018-07-25 11:03:50 +02:00
2018-02-22 14:39:58 +01:00
// Initialization
Requirements::block(THIRDPARTY_DIR.'/jquery/jquery.js');
/*if (defined('FONT_AWESOME_DIR')) {
2018-02-22 14:39:58 +01:00
Requirements::block(FONT_AWESOME_DIR.'/css/lib/font-awesome.min.css');
}*/
2018-02-22 14:39:58 +01:00
Requirements::set_force_js_to_bottom(true);
// Main libs
2018-07-25 11:03:50 +02:00
if (!$config['nojquery']) {
DeferedRequirements::loadJS('//ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js');
}
2018-02-22 14:39:58 +01:00
// App libs
2018-07-25 11:03:50 +02:00
if (!$config['nofontawesome']) {
2019-04-11 00:15:29 +02:00
DeferedRequirements::loadCSS('//use.fontawesome.com/releases/v5.4.0/css/all.css');
2018-07-25 11:03:50 +02:00
}
2019-04-11 00:15:29 +02:00
DeferedRequirements::loadCSS($themeName.'.css');
DeferedRequirements::loadJS($themeName.'.js');
2018-02-22 14:39:58 +01:00
// Class libs
2018-08-26 12:46:03 +02:00
$class = get_class(Controller::curr());
2018-09-19 07:20:43 +02:00
if (isset($config['custom_requirements'][$class])) {
2018-08-26 12:46:03 +02:00
foreach ($config['custom_requirements'][$class] as $file) {
2018-09-19 07:20:43 +02:00
if (strpos($file, '.css')) {
2018-08-26 12:46:03 +02:00
DeferedRequirements::loadCSS($file);
}
2018-09-19 07:20:43 +02:00
if (strpos($file, '.js')) {
2018-08-26 12:46:03 +02:00
DeferedRequirements::loadJS($file);
}
}
}
$class = str_replace('\\', '.', $class);
$dir = Path::join(
Director::publicFolder(),
ManifestFileFinder::RESOURCES_DIR,
2019-04-11 00:15:29 +02:00
$themeName,
'client',
'dist'
);
2019-04-11 00:15:29 +02:00
if (file_exists(Path::join($dir, 'css', $themeName.'_'.$class . '.css'))) {
DeferedRequirements::loadCSS($themeName.'_'.$class . '.css');
}
2018-06-23 12:27:06 +02:00
2019-04-11 00:15:29 +02:00
if (file_exists(Path::join($dir, 'js', $themeName.'_'.$class . '.js'))) {
DeferedRequirements::loadJS($themeName.'_'.$class . '.js');
2018-02-22 14:39:58 +01:00
}
return self::forTemplate();
}
public static function loadCSS($css)
{
2019-04-11 00:15:29 +02:00
$external = (mb_substr($css, 0, 2) === '//' || mb_substr($css, 0, 4) === 'http');
if ($external || (self::$defered && !self::_webpackActive())) {
2018-02-22 14:39:58 +01:00
self::$css[] = $css;
} else {
WebpackTemplateProvider::loadCSS($css);
}
}
public static function loadJS($js)
{
2019-04-11 00:15:29 +02:00
/*$external = (mb_substr($js, 0, 2) === '//' || mb_substr($js, 0, 4) === 'http');
if ($external || (self::$defered && !self::_webpackActive())) {*/
// webpack supposed to load external JS
2018-02-22 14:39:58 +01:00
if (self::$defered && !self::_webpackActive()) {
self::$js[] = $js;
} else {
WebpackTemplateProvider::loadJS($js);
}
}
protected static function _webpackActive()
{
return class_exists('WebpackTemplateProvider') && WebpackTemplateProvider::isActive();
}
public static function setDefered($bool)
{
self::$defered = $bool;
}
public static function forTemplate()
{
$result = '';
foreach (self::$css as $css) {
$result .= '<i class="defer-cs" data-load="' . self::get_url($css) . '"></i>';
}
foreach (self::$js as $js) {
$result .= '<i class="defer-sc" data-load="' . self::get_url($js) . '"></i>';
}
$result .=
'<script type="text/javascript">function lsc(a,b){var c=document.createElement("script");c.type="text/javascript",c.readyState'
.'?c.onreadystatechange=function(){"loaded"!=c.readyState&&"complete"!=c.readyState||(c.onreadystatechange=null,b())}'
.':c.onload=function(){b()},c.src=a,document.getElementsByTagName("body")[0].appendChild(c)}'
.'function lscd(a){a<s.length-1&&(a++,lsc(s.item(a).getAttribute("data-load"),function(){lscd(a)}))}'
.'for(var s=document.getElementsByClassName("defer-cs"),i=0;i<s.length;i++){var b=document.createElement("link");b.rel="stylesheet",'
.'b.type="text/css",b.href=s.item(i).getAttribute("data-load"),b.media="all";var c=document.getElementsByTagName("body")[0];'
2019-04-11 00:15:29 +02:00
.'c.appendChild(b)}var s=document.getElementsByClassName("defer-sc"),i=0;if(s.item(i)!==null)lsc(s.item(i).getAttribute("data-load"),function(){lscd(i)});'
2018-02-22 14:39:58 +01:00
.'</script>';
return $result;
}
private static function get_url($url)
{
2018-07-25 11:03:50 +02:00
$config = Config::inst()->get(self::class);
2018-02-22 14:39:58 +01:00
// external URL
if (strpos($url, '//') !== false) {
return $url;
}
2018-07-25 11:03:50 +02:00
$version = $config['version'];
2018-02-22 14:39:58 +01:00
$version = $version
? strpos($url, '?') // inner URL
? '&'.$version // add param
: '?'.$version // new param
: ''; // no version defined
2018-07-25 11:03:50 +02:00
$static_domain = $config['static_domain'];
2018-02-22 14:39:58 +01:00
$static_domain = $static_domain ? $static_domain : '';
return $url.$version;
}
}