silverstripe-cms/code/Model/SiteTreeFileExtension.php

126 lines
3.2 KiB
PHP
Raw Normal View History

<?php
2016-07-22 11:32:32 +12:00
namespace SilverStripe\CMS\Model;
use SilverStripe\Assets\File;
use SilverStripe\Core\Convert;
use SilverStripe\Forms\FieldList;
use SilverStripe\Forms\ReadonlyField;
use SilverStripe\ORM\DataExtension;
use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\ManyManyList;
use SilverStripe\ORM\Versioning\Versioned;
2016-09-13 10:47:02 +12:00
use SilverStripe\View\SSViewer;
2016-07-22 11:32:32 +12:00
use Subsite;
/**
* Extension applied to {@see File} object to track links to {@see SiteTree} records.
*
* {@see SiteTreeLinkTracking} for the extension applied to {@see SiteTree}
*
* Note that since both SiteTree and File are versioned, LinkTracking and ImageTracking will
* only be enabled for the Stage record.
*
* @property File $owner
*/
class SiteTreeFileExtension extends DataExtension {
private static $belongs_many_many = array(
2016-08-10 16:08:39 +12:00
'BackLinkTracking' => 'SilverStripe\\CMS\\Model\\SiteTree.ImageTracking' // {@see SiteTreeLinkTracking}
);
2016-02-22 11:44:24 +13:00
/**
* Images tracked by pages are owned by those pages
*
* @config
* @var array
*/
private static $owned_by = array(
'BackLinkTracking'
);
2016-09-20 12:08:20 +12:00
private static $casting = array(
'BackLinkHTMLList' => 'HTMLFragment'
);
public function updateCMSFields(FieldList $fields) {
$fields->insertAfter(
2016-08-10 16:08:39 +12:00
'LastEdited',
ReadonlyField::create(
2016-02-22 11:44:24 +13:00
'BackLinkCount',
_t('AssetTableField.BACKLINKCOUNT', 'Used on:'),
2016-08-10 16:08:39 +12:00
$this->BackLinkTracking()->count() . ' ' . _t('AssetTableField.PAGES', 'page(s)')
)
->addExtraClass('cms-description-toggle')
2016-08-10 16:08:39 +12:00
->setDescription($this->BackLinkHTMLList())
);
}
/**
* Generate an HTML list which provides links to where a file is used.
*
* @return string
*/
public function BackLinkHTMLList() {
$viewer = new SSViewer(["type" => "Includes", self::class . "_description"]);
2016-09-20 12:08:20 +12:00
return $viewer->process($this->owner);
}
/**
* Extend through {@link updateBackLinkTracking()} in your own {@link Extension}.
2014-02-10 15:35:13 -05:00
*
* @return ManyManyList
*/
public function BackLinkTracking() {
if(class_exists("Subsite")){
$rememberSubsiteFilter = Subsite::$disable_subsite_filter;
Subsite::disable_subsite_filter(true);
}
$links = $this->owner->getManyManyComponents('BackLinkTracking');
$this->owner->extend('updateBackLinkTracking', $links);
2016-02-22 11:44:24 +13:00
if(class_exists("Subsite")){
Subsite::disable_subsite_filter($rememberSubsiteFilter);
}
2016-02-22 11:44:24 +13:00
return $links;
}
2016-02-22 11:44:24 +13:00
/**
* @todo Unnecessary shortcut for AssetTableField, coupled with cms module.
2016-02-22 11:44:24 +13:00
*
2016-08-10 16:08:39 +12:00
* @return int
*/
public function BackLinkTrackingCount() {
$pages = $this->owner->BackLinkTracking();
if($pages) {
2016-08-10 16:08:39 +12:00
return $pages->count();
} else {
return 0;
}
}
2016-02-22 11:44:24 +13:00
/**
* Updates link tracking in the current stage.
*/
public function onAfterDelete() {
// Skip live stage
if(Versioned::get_stage() === Versioned::LIVE) {
return;
}
// We query the explicit ID list, because BackLinkTracking will get modified after the stage
// site does its thing
$brokenPageIDs = $this->owner->BackLinkTracking()->column("ID");
if($brokenPageIDs) {
// This will syncLinkTracking on the same stage as this file
2016-07-22 11:32:32 +12:00
$brokenPages = DataObject::get('SilverStripe\\CMS\\Model\\SiteTree')->byIDs($brokenPageIDs);
foreach($brokenPages as $brokenPage) {
$brokenPage->write();
}
}
}
}