mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
themedScript Added
A function to call javascript files just by its name as it occurs with themedCSS
This commit is contained in:
parent
f6dca68be1
commit
d75de1369f
@ -175,6 +175,23 @@ class Requirements implements Flushable {
|
|||||||
return self::backend()->themedCSS($name, $module, $media);
|
return self::backend()->themedCSS($name, $module, $media);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers the given themeable javascript as required.
|
||||||
|
*
|
||||||
|
* A javascript file in the current theme path name 'themename/javascript/$name.js' is first searched for,
|
||||||
|
* and it that doesn't exist and the module parameter is set then a javascript file with that name in
|
||||||
|
* the module is used.
|
||||||
|
*
|
||||||
|
* @param string $name The name of the file - eg '/javascript/File.js' would have the name 'File'
|
||||||
|
* @param string $module The module to fall back to if the javascript file does not exist in the
|
||||||
|
* current theme.
|
||||||
|
* @param string $type Comma-separated list of types to use in the script tag
|
||||||
|
* (e.g. 'text/javascript,text/ecmascript')
|
||||||
|
*/
|
||||||
|
public static function themedScript($name, $module = null, $type = null) {
|
||||||
|
return self::backend()->themedScript($name, $module, $type);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Clear either a single or all requirements
|
* Clear either a single or all requirements
|
||||||
*
|
*
|
||||||
@ -1331,6 +1348,38 @@ class Requirements_Backend {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Registers the given themeable javascript as required.
|
||||||
|
*
|
||||||
|
* A javascript file in the current theme path name 'themename/javascript/$name.js' is first searched for,
|
||||||
|
* and it that doesn't exist and the module parameter is set then a javascript file with that name in
|
||||||
|
* the module is used.
|
||||||
|
*
|
||||||
|
* @param string $name The name of the file - eg '/js/File.js' would have the name 'File'
|
||||||
|
* @param string $module The module to fall back to if the javascript file does not exist in the
|
||||||
|
* current theme.
|
||||||
|
* @param string $type Comma-separated list of types to use in the script tag
|
||||||
|
* (e.g. 'text/javascript,text/ecmascript')
|
||||||
|
*/
|
||||||
|
public function themedScript($name, $module = null, $type = null) {
|
||||||
|
$theme = SSViewer::get_theme_folder();
|
||||||
|
$project = project();
|
||||||
|
$absbase = BASE_PATH . DIRECTORY_SEPARATOR;
|
||||||
|
$abstheme = $absbase . $theme;
|
||||||
|
$absproject = $absbase . $project;
|
||||||
|
$js = "/javascript/$name.js";
|
||||||
|
|
||||||
|
if(file_exists($absproject . $js)) {
|
||||||
|
$this->javascript($project . $js);
|
||||||
|
} elseif($module && file_exists($abstheme . '_' . $module.$js)) {
|
||||||
|
$this->javascript($theme . '_' . $module . $js);
|
||||||
|
} elseif(file_exists($abstheme . $js)) {
|
||||||
|
$this->javascript($theme . $js);
|
||||||
|
} elseif($module) {
|
||||||
|
$this->javascript($module . $js);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Output debugging information.
|
* Output debugging information.
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user