2018-02-22 20:39:58 +07:00
|
|
|
<?php
|
|
|
|
|
2018-04-21 11:29:32 +07:00
|
|
|
namespace Site\Templates;
|
|
|
|
|
2018-07-19 19:10:55 +07:00
|
|
|
use SilverStripe\Control\Controller;
|
2018-03-24 17:45:31 +07: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 10:36:06 +07:00
|
|
|
class DeferedRequirements implements TemplateGlobalProvider
|
|
|
|
{
|
2018-02-22 20:39:58 +07:00
|
|
|
private static $css = [];
|
|
|
|
private static $js = [];
|
|
|
|
private static $defered = false;
|
|
|
|
private static $static_domain;
|
|
|
|
private static $version;
|
2018-07-25 16:03:50 +07:00
|
|
|
private static $nojquery = false;
|
|
|
|
private static $nofontawesome = false;
|
2018-02-22 20:39:58 +07: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 16:03:50 +07:00
|
|
|
$config = Config::inst()->get(self::class);
|
|
|
|
|
2018-02-22 20:39:58 +07:00
|
|
|
// Initialization
|
|
|
|
Requirements::block(THIRDPARTY_DIR.'/jquery/jquery.js');
|
2018-07-19 19:10:55 +07:00
|
|
|
/*if (defined('FONT_AWESOME_DIR')) {
|
2018-02-22 20:39:58 +07:00
|
|
|
Requirements::block(FONT_AWESOME_DIR.'/css/lib/font-awesome.min.css');
|
2018-07-19 19:10:55 +07:00
|
|
|
}*/
|
2018-02-22 20:39:58 +07:00
|
|
|
Requirements::set_force_js_to_bottom(true);
|
|
|
|
|
|
|
|
// Main libs
|
2018-07-25 16:03:50 +07:00
|
|
|
if (!$config['nojquery']) {
|
|
|
|
DeferedRequirements::loadJS('//ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js');
|
|
|
|
}
|
2018-02-22 20:39:58 +07:00
|
|
|
// App libs
|
2018-07-25 16:03:50 +07:00
|
|
|
if (!$config['nofontawesome']) {
|
|
|
|
DeferedRequirements::loadCSS('//use.fontawesome.com/releases/v5.0.13/css/all.css');
|
|
|
|
}
|
2018-03-24 17:45:31 +07:00
|
|
|
DeferedRequirements::loadCSS('app.css');
|
|
|
|
DeferedRequirements::loadJS('app.js');
|
2018-02-22 20:39:58 +07:00
|
|
|
|
|
|
|
// Class libs
|
2018-07-19 19:10:55 +07:00
|
|
|
$class = str_replace('\\', '.', get_class(Controller::curr()));
|
|
|
|
$dir = Path::join(
|
|
|
|
Director::publicFolder(),
|
|
|
|
ManifestFileFinder::RESOURCES_DIR,
|
|
|
|
'app',
|
|
|
|
'client',
|
|
|
|
'dist'
|
|
|
|
);
|
|
|
|
|
|
|
|
if (file_exists(Path::join($dir, 'css', '_' . $class . '.css'))) {
|
|
|
|
DeferedRequirements::loadCSS('_' . $class . '.css');
|
|
|
|
}
|
2018-06-23 17:27:06 +07:00
|
|
|
|
2018-07-19 19:10:55 +07:00
|
|
|
if (file_exists(Path::join($dir, 'js', $class . '.js'))) {
|
|
|
|
DeferedRequirements::loadJS($class . '.js');
|
2018-02-22 20:39:58 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
return self::forTemplate();
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function loadCSS($css)
|
|
|
|
{
|
|
|
|
if (self::$defered && !self::_webpackActive()) {
|
|
|
|
self::$css[] = $css;
|
|
|
|
} else {
|
|
|
|
WebpackTemplateProvider::loadCSS($css);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function loadJS($js)
|
|
|
|
{
|
|
|
|
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()
|
|
|
|
{
|
|
|
|
if (!self::$defered || self::_webpackActive()) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
$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];'
|
|
|
|
.'c.appendChild(b)}var s=document.getElementsByClassName("defer-sc"),i=0;lsc(s.item(i).getAttribute("data-load"),function(){lscd(i)});'
|
|
|
|
.'</script>';
|
|
|
|
|
|
|
|
return $result;
|
|
|
|
}
|
|
|
|
|
|
|
|
private static function get_url($url)
|
|
|
|
{
|
2018-07-25 16:03:50 +07:00
|
|
|
$config = Config::inst()->get(self::class);
|
|
|
|
|
2018-02-22 20:39:58 +07:00
|
|
|
// external URL
|
|
|
|
if (strpos($url, '//') !== false) {
|
|
|
|
return $url;
|
|
|
|
}
|
|
|
|
|
2018-07-25 16:03:50 +07:00
|
|
|
$version = $config['version'];
|
2018-02-22 20:39:58 +07:00
|
|
|
$version = $version
|
|
|
|
? strpos($url, '?') // inner URL
|
|
|
|
? '&'.$version // add param
|
|
|
|
: '?'.$version // new param
|
|
|
|
: ''; // no version defined
|
|
|
|
|
2018-07-25 16:03:50 +07:00
|
|
|
$static_domain = $config['static_domain'];
|
2018-02-22 20:39:58 +07:00
|
|
|
$static_domain = $static_domain ? $static_domain : '';
|
|
|
|
|
|
|
|
return $url.$version;
|
|
|
|
}
|
|
|
|
}
|