2012-04-15 00:48:50 +02:00
|
|
|
<?php
|
2016-06-15 06:03:16 +02:00
|
|
|
|
2016-08-19 00:51:35 +02:00
|
|
|
namespace SilverStripe\View;
|
|
|
|
|
2017-06-27 04:30:48 +02:00
|
|
|
use SilverStripe\Core\Manifest\ModuleLoader;
|
2017-06-22 12:50:45 +02:00
|
|
|
use SilverStripe\ORM\DataList;
|
2016-08-19 00:51:35 +02:00
|
|
|
|
2016-11-29 00:31:16 +01:00
|
|
|
class GenericTemplateGlobalProvider implements TemplateGlobalProvider
|
|
|
|
{
|
2012-04-15 00:48:50 +02:00
|
|
|
|
2016-11-29 00:31:16 +01:00
|
|
|
public static function get_template_global_variables()
|
|
|
|
{
|
2020-04-20 19:58:09 +02:00
|
|
|
return [
|
2016-11-29 00:31:16 +01:00
|
|
|
'ModulePath',
|
|
|
|
'List' => 'getDataList'
|
2020-04-20 19:58:09 +02:00
|
|
|
];
|
2016-11-29 00:31:16 +01:00
|
|
|
}
|
2012-04-15 00:48:50 +02:00
|
|
|
|
2016-11-29 00:31:16 +01:00
|
|
|
/**
|
|
|
|
* Given some pre-defined modules, return the filesystem path of the module.
|
|
|
|
* @param string $name Name of module to find path of
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function ModulePath($name)
|
|
|
|
{
|
2021-12-13 09:05:33 +01:00
|
|
|
// BC for a couple of the key modules in the old syntax. Reduces merge brittleness but can
|
2017-06-27 04:30:48 +02:00
|
|
|
// be removed before 4.0 stable
|
|
|
|
$legacyMapping = [
|
|
|
|
'framework' => 'silverstripe/framework',
|
|
|
|
'frameworkadmin' => 'silverstripe/admin',
|
|
|
|
];
|
|
|
|
if (isset($legacyMapping[$name])) {
|
|
|
|
$name = $legacyMapping[$name];
|
2016-11-29 00:31:16 +01:00
|
|
|
}
|
2017-06-27 04:30:48 +02:00
|
|
|
|
|
|
|
return ModuleLoader::getModule($name)->getRelativePath();
|
2016-11-29 00:31:16 +01:00
|
|
|
}
|
2012-05-19 02:55:49 +02:00
|
|
|
|
2016-11-29 00:31:16 +01:00
|
|
|
/**
|
|
|
|
* This allows templates to create a new `DataList` from a known
|
|
|
|
* DataObject class name, and call methods such as aggregates.
|
|
|
|
*
|
|
|
|
* The common use case is for partial caching:
|
|
|
|
* <code>
|
|
|
|
* <% cached List(Member).max(LastEdited) %>
|
|
|
|
* loop members here
|
|
|
|
* <% end_cached %>
|
|
|
|
* </code>
|
|
|
|
*
|
2024-01-17 05:08:26 +01:00
|
|
|
* @template T of DataObject
|
|
|
|
* @param class-string<T> $className
|
|
|
|
* @return DataList<T>
|
2016-11-29 00:31:16 +01:00
|
|
|
*/
|
|
|
|
public static function getDataList($className)
|
|
|
|
{
|
2017-06-22 12:50:45 +02:00
|
|
|
return DataList::create($className);
|
2016-11-29 00:31:16 +01:00
|
|
|
}
|
2012-04-15 00:48:50 +02:00
|
|
|
}
|