mirror of
https://github.com/wilr/silverstripe-googlesitemaps.git
synced 2024-10-22 09:05:48 +00:00
The change frequency is now configurable via GoogleSitemap::register_dataobject()
This commit is contained in:
parent
54929f3e50
commit
c841987427
@ -55,7 +55,14 @@ class GoogleSitemap extends Controller {
|
|||||||
*/
|
*/
|
||||||
public static $google_sitemap_dataobjects_changefreq = array();
|
public static $google_sitemap_dataobjects_changefreq = array();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* List of DataObjects priority
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
public static $google_sitemap_dataobjects_priority = array();
|
||||||
|
|
||||||
|
/**
|
||||||
* Decorates the given DataObject with {@link GoogleSitemapDecorator}
|
* Decorates the given DataObject with {@link GoogleSitemapDecorator}
|
||||||
* and pushes the class name to the registered DataObjects.
|
* and pushes the class name to the registered DataObjects.
|
||||||
* Note that all registered DataObjects need the method AbsoluteLink().
|
* Note that all registered DataObjects need the method AbsoluteLink().
|
||||||
@ -65,11 +72,16 @@ class GoogleSitemap extends Controller {
|
|||||||
*
|
*
|
||||||
* @return void
|
* @return void
|
||||||
*/
|
*/
|
||||||
public static function register_dataobject($className, $changeFreq = 'monthly') {
|
public static function register_dataobject($className, $changeFreq = 'monthly', $priority = 0.6) {
|
||||||
if (!self::is_registered($className)) {
|
if (!self::is_registered($className)) {
|
||||||
Object::add_extension($className, 'GoogleSitemapDecorator');
|
Object::add_extension($className, 'GoogleSitemapDecorator');
|
||||||
self::$google_sitemap_dataobjects[] = $className;
|
self::$google_sitemap_dataobjects[] = $className;
|
||||||
self::$google_sitemap_dataobjects_changefreq[] = $changeFreq;
|
if ($changeFreq === null) {
|
||||||
|
self::$google_sitemap_dataobjects_changefreq[] = "monthly";
|
||||||
|
} else {
|
||||||
|
self::$google_sitemap_dataobjects_changefreq[] = $changeFreq;
|
||||||
|
}
|
||||||
|
self::$google_sitemap_dataobjects_priority[] = $priority;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -100,11 +112,11 @@ class GoogleSitemap extends Controller {
|
|||||||
|
|
||||||
if($dataObjectSet) {
|
if($dataObjectSet) {
|
||||||
foreach($dataObjectSet as $dataObject) {
|
foreach($dataObjectSet as $dataObject) {
|
||||||
if($dataObject->canView() && (!isset($dataObject->Priority) || $dataObject->Priority > 0)) {
|
if($dataObject->canView()) {
|
||||||
$dataObject->ChangeFreq = self::$google_sitemap_dataobjects_changefreq[$index];
|
$dataObject->ChangeFreq = self::$google_sitemap_dataobjects_changefreq[$index];
|
||||||
|
|
||||||
if(!isset($dataObject->Priority)) {
|
if(!isset($dataObject->Priority)) {
|
||||||
$dataObject->Priority = 1.0;
|
$dataObject->Priority = self::$google_sitemap_dataobjects_priority[$index];
|
||||||
}
|
}
|
||||||
|
|
||||||
$output->push($dataObject);
|
$output->push($dataObject);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user