2007-07-19 10:40:28 +00:00
< ? php
2008-02-25 02:10:37 +00:00
/**
2010-10-12 23:02:10 +00:00
* Represents a folder in the assets / directory .
2010-10-15 03:12:39 +00:00
* The folder path is stored in the " Filename " property .
*
* Updating the " Name " or " Filename " properties on
* a folder object also updates all associated children
* ( both { @ link File } and { @ link Folder } records ) .
*
2010-10-15 03:20:47 +00:00
* Deleting a folder will also remove the folder from the filesystem ,
* including any subfolders and contained files . Use { @ link deleteDatabaseOnly ()}
* to avoid touching the filesystem .
*
2010-10-15 03:12:39 +00:00
* See { @ link File } documentation for more details about the
* relationship between the database and filesystem in the sapphire file APIs .
2010-10-12 23:02:10 +00:00
*
2008-02-25 02:10:37 +00:00
* @ package sapphire
* @ subpackage filesystem
*/
2007-07-19 10:40:28 +00:00
class Folder extends File {
2009-11-21 02:32:40 +00:00
static $singular_name = " Folder " ;
static $plural_name = " Folders " ;
2010-10-13 01:01:12 +00:00
2010-10-13 03:33:16 +00:00
static $default_sort = " \" Sort \" " ;
2007-07-19 10:40:28 +00:00
2011-03-15 22:30:31 +13:00
function populateDefaults () {
parent :: populateDefaults ();
if ( ! $this -> Name ) $this -> Name = _t ( 'AssetAdmin.NEWFOLDER' , " NewFolder " );
}
2010-10-15 03:12:39 +00:00
/**
* Find the given folder or create it both as { @ link Folder } database records
* and on the filesystem . If necessary , creates parent folders as well .
2008-03-17 22:51:25 +00:00
*
2010-10-15 03:21:41 +00:00
* @ param $folderPath string Absolute or relative path to the file .
* If path is relative , its interpreted relative to the " assets/ " directory .
2010-10-15 03:12:39 +00:00
* @ return Folder
2007-07-19 10:40:28 +00:00
*/
2008-03-17 22:51:25 +00:00
static function findOrMake ( $folderPath ) {
2010-04-14 04:42:59 +00:00
// Create assets directory, if it is missing
2010-10-15 03:21:23 +00:00
if ( ! file_exists ( ASSETS_PATH )) Filesystem :: makeFolder ( ASSETS_PATH );
2010-04-14 04:42:59 +00:00
2008-03-17 22:51:25 +00:00
$folderPath = trim ( Director :: makeRelative ( $folderPath ));
// replace leading and trailing slashes
$folderPath = preg_replace ( '/^\/?(.*)\/?$/' , '$1' , $folderPath );
$parts = explode ( " / " , $folderPath );
2010-10-12 23:02:10 +00:00
2007-07-19 10:40:28 +00:00
$parentID = 0 ;
2010-10-15 03:21:41 +00:00
$item = null ;
2007-07-19 10:40:28 +00:00
foreach ( $parts as $part ) {
2010-10-12 23:02:10 +00:00
if ( ! $part ) continue ; // happens for paths with a trailing slash
2011-03-21 16:12:37 +13:00
$item = DataObject :: get_one (
" Folder " ,
sprintf (
" \" Name \" = '%s' AND \" ParentID \" = %d " ,
Convert :: raw2sql ( $part ),
( int ) $parentID
)
);
2007-07-19 10:40:28 +00:00
if ( ! $item ) {
$item = new Folder ();
$item -> ParentID = $parentID ;
$item -> Name = $part ;
2008-11-10 03:51:35 +00:00
$item -> Title = $part ;
2007-07-19 10:40:28 +00:00
$item -> write ();
2010-04-12 23:45:53 +00:00
}
if ( ! file_exists ( $item -> getFullPath ())) {
2010-10-15 03:21:23 +00:00
Filesystem :: makeFolder ( $item -> getFullPath ());
2007-07-19 10:40:28 +00:00
}
$parentID = $item -> ID ;
}
2010-10-15 03:21:41 +00:00
2007-07-19 10:40:28 +00:00
return $item ;
}
/**
* Syncronise the file database with the actual content of the assets folder
*/
function syncChildren () {
$parentID = ( int ) $this -> ID ; // parentID = 0 on the singleton, used as the 'root node';
$added = 0 ;
$deleted = 0 ;
// First, merge any children that are duplicates
2008-11-24 09:31:14 +00:00
$duplicateChildrenNames = DB :: query ( " SELECT \" Name \" FROM \" File \" WHERE \" ParentID \" = $parentID GROUP BY \" Name \" HAVING count(*) > 1 " ) -> column ();
2007-07-19 10:40:28 +00:00
if ( $duplicateChildrenNames ) foreach ( $duplicateChildrenNames as $childName ) {
2009-04-05 23:24:56 +00:00
$childName = DB :: getConn () -> addslashes ( $childName );
2007-07-19 10:40:28 +00:00
// Note, we do this in the database rather than object-model; otherwise we get all sorts of problems about deleting files
2008-11-24 09:31:14 +00:00
$children = DB :: query ( " SELECT \" ID \" FROM \" File \" WHERE \" Name \" = ' $childName ' AND \" ParentID \" = $parentID " ) -> column ();
2008-08-14 22:20:14 +00:00
if ( $children ) {
$keptChild = array_shift ( $children );
foreach ( $children as $removedChild ) {
2008-11-24 09:31:14 +00:00
DB :: query ( " UPDATE \" File \" SET \" ParentID \" = $keptChild WHERE \" ParentID \" = $removedChild " );
2008-11-23 23:28:16 +00:00
DB :: query ( " DELETE FROM \" File \" WHERE \" ID \" = $removedChild " );
2008-08-14 22:20:14 +00:00
}
} else {
2008-11-23 00:31:06 +00:00
user_error ( " Inconsistent database issue: SELECT ID FROM \" File \" WHERE Name = ' $childName ' AND ParentID = $parentID should have returned data " , E_USER_WARNING );
2007-07-19 10:40:28 +00:00
}
}
// Get index of database content
2008-02-25 02:10:37 +00:00
// We don't use DataObject so that things like subsites doesn't muck with this.
2008-11-24 09:31:14 +00:00
$dbChildren = DB :: query ( " SELECT * FROM \" File \" WHERE \" ParentID \" = $parentID " );
2008-02-25 02:10:37 +00:00
$hasDbChild = array ();
if ( $dbChildren ) {
2007-07-19 10:40:28 +00:00
foreach ( $dbChildren as $dbChild ) {
2008-02-25 02:10:37 +00:00
$className = $dbChild [ 'ClassName' ];
2009-08-24 07:21:08 +00:00
if ( ! $className ) $className = " File " ;
2008-02-25 02:10:37 +00:00
$hasDbChild [ $dbChild [ 'Name' ]] = new $className ( $dbChild );
2007-07-19 10:40:28 +00:00
}
}
2008-02-25 02:10:37 +00:00
$unwantedDbChildren = $hasDbChild ;
2007-07-19 10:40:28 +00:00
// Iterate through the actual children, correcting the database as necessary
$baseDir = $this -> FullPath ;
if ( ! $this -> Filename ) die ( $this -> ID . " - " . $this -> FullPath );
if ( file_exists ( $baseDir )) {
$actualChildren = scandir ( $baseDir );
foreach ( $actualChildren as $actualChild ) {
2010-12-05 00:05:05 +00:00
if ( $actualChild [ 0 ] == '.' || $actualChild [ 0 ] == '_' || substr ( $actualChild , 0 , 6 ) == 'Thumbs' || $actualChild == 'web.config' ) {
2010-01-21 22:59:19 +00:00
continue ;
}
2007-07-19 10:40:28 +00:00
// A record with a bad class type doesn't deserve to exist. It must be purged!
if ( isset ( $hasDbChild [ $actualChild ])) {
$child = $hasDbChild [ $actualChild ];
2009-03-10 22:08:52 +00:00
if (( ! ( $child instanceof Folder ) && is_dir ( $baseDir . $actualChild ) )
|| (( $child instanceof Folder ) && ! is_dir ( $baseDir . $actualChild )) ) {
2008-11-23 23:28:16 +00:00
DB :: query ( " DELETE FROM \" File \" WHERE \" ID \" = $child->ID " );
2007-07-19 10:40:28 +00:00
unset ( $hasDbChild [ $actualChild ]);
}
}
if ( isset ( $hasDbChild [ $actualChild ])) {
$child = $hasDbChild [ $actualChild ];
unset ( $unwantedDbChildren [ $actualChild ]);
} else {
$added ++ ;
$childID = $this -> constructChild ( $actualChild );
$child = DataObject :: get_by_id ( " File " , $childID );
}
if ( $child && is_dir ( $baseDir . $actualChild )) {
$childResult = $child -> syncChildren ();
$added += $childResult [ 'added' ];
$deleted += $childResult [ 'deleted' ];
}
2009-10-21 02:30:48 +00:00
// Clean up the child record from memory after use. Important!
$child -> destroy ();
2009-10-21 02:32:11 +00:00
$child = null ;
2007-07-19 10:40:28 +00:00
}
// Iterate through the unwanted children, removing them all
if ( isset ( $unwantedDbChildren )) foreach ( $unwantedDbChildren as $unwantedDbChild ) {
2008-11-23 23:28:16 +00:00
DB :: query ( " DELETE FROM \" File \" WHERE \" ID \" = $unwantedDbChild->ID " );
2007-07-19 10:40:28 +00:00
$deleted ++ ;
}
} else {
2008-11-23 23:28:16 +00:00
DB :: query ( " DELETE FROM \" File \" WHERE \" ID \" = $this->ID " );
2007-07-19 10:40:28 +00:00
}
return array ( 'added' => $added , 'deleted' => $deleted );
}
/**
* Construct a child of this Folder with the given name .
* It does this without actually using the object model , as this starts messing
* with all the data . Rather , it does a direct database insert .
*/
function constructChild ( $name ) {
// Determine the class name - File, Folder or Image
$baseDir = $this -> FullPath ;
if ( is_dir ( $baseDir . $name )) {
$className = " Folder " ;
} else {
// Could use getimagesize to get the type of the image
$ext = strtolower ( substr ( $name , strrpos ( $name , '.' ) + 1 ));
switch ( $ext ) {
case " gif " : case " jpg " : case " jpeg " : case " png " : $className = " Image " ; break ;
default : $className = " File " ;
}
}
if ( Member :: currentUser ()) $ownerID = Member :: currentUser () -> ID ;
2007-10-02 04:56:43 +00:00
else $ownerID = 0 ;
2007-07-19 10:40:28 +00:00
2009-04-05 23:24:56 +00:00
$filename = DB :: getConn () -> addslashes ( $this -> Filename . $name );
2007-07-19 10:40:28 +00:00
if ( $className == 'Folder' ) $filename .= '/' ;
2009-04-05 23:24:56 +00:00
$name = DB :: getConn () -> addslashes ( $name );
2007-07-19 10:40:28 +00:00
2008-11-24 09:31:14 +00:00
DB :: query ( " INSERT INTO \" File \"
( \ " ClassName \" , \" ParentID \" , \" OwnerID \" , \" Name \" , \" Filename \" , \" Created \" , \" LastEdited \" , \" Title \" )
2009-03-11 21:50:03 +00:00
VALUES ( '$className' , $this -> ID , $ownerID , '$name' , '$filename' , " . DB::getConn()->now() . ',' . DB::getConn()->now() . " , '$name' ) " );
2007-07-19 10:40:28 +00:00
2007-09-14 01:36:32 +00:00
return DB :: getGeneratedID ( " File " );
2007-07-19 10:40:28 +00:00
}
/**
* Take a file uploaded via a POST form , and save it inside this folder .
*/
function addUploadToFolder ( $tmpFile ) {
if ( ! is_array ( $tmpFile )) {
2008-04-06 04:10:51 +00:00
user_error ( " Folder::addUploadToFolder() Not passed an array. Most likely, the form hasn't got the right enctype " , E_USER_ERROR );
2007-07-19 10:40:28 +00:00
}
2010-05-25 03:04:55 +00:00
if ( ! isset ( $tmpFile [ 'size' ])) {
2007-07-19 10:40:28 +00:00
return ;
}
ENHANCEMENT Introduced constants for system paths like /sapphire in preparation for a more flexible directory reorganisation. Instead of hardcoding your path, please use the following constants: BASE_PATH, BASE_URL, SAPPHIRE_DIR, SAPPHIRE_PATH, CMS_DIR, CMS_PATH, THIRDPARTY_DIR, THIRDPARTY_PATH, ASSETS_DIR, ASSETS_PATH, THEMES_DIR, THEMES_PATH
git-svn-id: svn://svn.silverstripe.com/silverstripe/open/modules/sapphire/trunk@63154 467b73ca-7a2a-4603-9d3b-597d59a354a9
2008-09-27 16:02:38 +00:00
$base = BASE_PATH ;
2007-07-19 10:40:28 +00:00
// $parentFolder = Folder::findOrMake("Uploads");
// Generate default filename
$file = str_replace ( ' ' , '-' , $tmpFile [ 'name' ]);
$file = ereg_replace ( '[^A-Za-z0-9+.-]+' , '' , $file );
$file = ereg_replace ( '-+' , '-' , $file );
2010-01-21 22:59:19 +00:00
while ( $file [ 0 ] == '_' || $file [ 0 ] == '.' ) {
$file = substr ( $file , 1 );
}
2007-07-19 10:40:28 +00:00
$file = $this -> RelativePath . $file ;
Filesystem :: makeFolder ( dirname ( " $base / $file " ));
2010-05-25 03:04:55 +00:00
$doubleBarrelledExts = array ( '.gz' , '.bz' , '.bz2' );
$ext = " " ;
if ( preg_match ( '/^(.*)(\.[^.]+)$/' , $file , $matches )) {
$file = $matches [ 1 ];
$ext = $matches [ 2 ];
// Special case for double-barrelled
if ( in_array ( $ext , $doubleBarrelledExts ) && preg_match ( '/^(.*)(\.[^.]+)$/' , $file , $matches )) {
$file = $matches [ 1 ];
$ext = $matches [ 2 ] . $ext ;
}
}
$origFile = $file ;
$i = 1 ;
while ( file_exists ( " $base / $file $ext " )) {
$i ++ ;
2007-07-19 10:40:28 +00:00
$oldFile = $file ;
2010-10-04 04:42:13 +00:00
if ( strpos ( $file , '.' ) !== false ) {
2010-10-04 04:44:14 +00:00
$file = ereg_replace ( '[0-9]*(\.[^.]+$)' , $i . '\\1' , $file );
} elseif ( strpos ( $file , '_' ) !== false ) {
$file = ereg_replace ( '_([^_]+$)' , '_' . $i , $file );
2010-10-04 04:42:13 +00:00
} else {
$file .= " _ $i " ;
}
2010-05-25 03:04:55 +00:00
if ( $oldFile == $file && $i > 2 ) user_error ( " Couldn't fix $file $ext with $i " , E_USER_ERROR );
2007-07-19 10:40:28 +00:00
}
2010-05-25 03:04:55 +00:00
if ( move_uploaded_file ( $tmpFile [ 'tmp_name' ], " $base / $file $ext " )) {
2007-07-19 10:40:28 +00:00
// Update with the new image
2010-05-25 03:04:55 +00:00
return $this -> constructChild ( basename ( $file . $ext ));
2007-07-19 10:40:28 +00:00
} else {
2009-07-01 22:27:18 +00:00
if ( ! file_exists ( $tmpFile [ 'tmp_name' ])) user_error ( " Folder::addUploadToFolder: ' $tmpFile[tmp_name] ' doesn't exist " , E_USER_ERROR );
2010-05-25 03:04:55 +00:00
else user_error ( " Folder::addUploadToFolder: Couldn't copy ' $tmpFile[tmp_name] ' to ' $base / $file $ext ' " , E_USER_ERROR );
2007-07-19 10:40:28 +00:00
return false ;
}
}
2010-10-12 23:02:10 +00:00
function validate () {
return new ValidationResult ( true );
}
2007-07-19 10:40:28 +00:00
//-------------------------------------------------------------------------------------------------
// Data Model Definition
function getRelativePath () {
return parent :: getRelativePath () . " / " ;
}
2010-10-15 03:20:47 +00:00
2007-07-19 10:40:28 +00:00
function onBeforeDelete () {
2009-01-10 11:35:50 +00:00
if ( $this -> ID && ( $children = $this -> AllChildren ())) {
2007-07-19 10:40:28 +00:00
foreach ( $children as $child ) {
if ( ! $this -> Filename || ! $this -> Name || ! file_exists ( $this -> getFullPath ())) {
$child -> setField ( 'Name' , null );
$child -> Filename = null ;
}
$child -> delete ();
}
}
// Do this after so a folder's contents are removed before we delete the folder.
if ( $this -> Filename && $this -> Name && file_exists ( $this -> getFullPath ())) {
$files = glob ( $this -> getFullPath () . '/*' );
if ( ! $files || ( count ( $files ) == 1 && preg_match ( '/\/_resampled$/' , $files [ 0 ] ) ) )
Filesystem :: removeFolder ( $this -> getFullPath () );
}
2010-10-15 03:20:47 +00:00
2007-07-19 10:40:28 +00:00
parent :: onBeforeDelete ();
}
2011-03-23 13:23:43 +13:00
/** Override setting the Title of Folders to that Name , Filename and Title are always in sync .
* Note that this is not appropriate for files , because someone might want to create a human - readable name
* of a file that is different from its name on disk . But folders should always match their name on disk . */
function setTitle ( $title ) {
$this -> setField ( 'Title' , $title );
parent :: setName ( $title ); //set the name and filename to match the title
}
function setName ( $name ) {
$this -> setField ( 'Title' , $name );
parent :: setName ( $name );
}
function setFilename ( $filename ) {
2011-03-30 12:05:05 +13:00
$this -> setField ( 'Title' , pathinfo ( $filename , PATHINFO_BASENAME ));
2011-03-23 13:23:43 +13:00
parent :: setFilename ( $filename );
}
2007-07-19 10:40:28 +00:00
/**
* Delete the database record ( recursively for folders ) without touching the filesystem
*/
function deleteDatabaseOnly () {
if ( $children = $this -> myChildren ()) {
foreach ( $children as $child ) $child -> deleteDatabaseOnly ();
}
parent :: deleteDatabaseOnly ();
}
public function myChildren () {
// Ugly, but functional.
$ancestors = ClassInfo :: ancestry ( $this -> class );
foreach ( $ancestors as $i => $a ) {
if ( isset ( $baseClass ) && $baseClass === - 1 ) {
$baseClass = $a ;
break ;
}
if ( $a == " DataObject " ) $baseClass = - 1 ;
}
2008-11-24 09:31:14 +00:00
$g = DataObject :: get ( $baseClass , " \" ParentID \" = " . $this -> ID );
2007-07-19 10:40:28 +00:00
return $g ;
}
/**
* Returns true if this folder has children
*/
public function hasChildren () {
2009-07-01 22:27:18 +00:00
return ( bool ) DB :: query ( " SELECT COUNT(*) FROM \" File \" WHERE ParentID = "
. ( int ) $this -> ID ) -> value ();
}
/**
* Returns true if this folder has children
*/
public function hasChildFolders () {
$SQL_folderClasses = Convert :: raw2sql ( ClassInfo :: subclassesFor ( 'Folder' ));
2010-10-12 21:55:17 +00:00
return ( bool ) DB :: query ( " SELECT COUNT(*) FROM \" File \" WHERE \" ParentID \" = " . ( int ) $this -> ID
2009-07-01 22:27:18 +00:00
. " AND \" ClassName \" IN (' " . implode ( " ',' " , $SQL_folderClasses ) . " ') " ) -> value ();
2007-07-19 10:40:28 +00:00
}
/**
2010-10-15 03:20:47 +00:00
* Overloaded to call recursively on all contained { @ link File } records .
2007-07-19 10:40:28 +00:00
*/
2010-10-15 03:20:47 +00:00
public function updateFilesystem () {
parent :: updateFilesystem ();
2007-07-19 10:40:28 +00:00
2010-10-15 03:20:47 +00:00
// Note: Folders will have been renamed on the filesystem already at this point,
// File->updateFilesystem() needs to take this into account.
2009-01-10 11:35:50 +00:00
if ( $this -> ID && ( $children = $this -> AllChildren ())) {
2007-07-19 10:40:28 +00:00
foreach ( $children as $child ) {
2010-10-15 03:20:47 +00:00
$child -> updateFilesystem ();
2007-07-19 10:40:28 +00:00
$child -> write ();
}
}
}
2008-02-25 02:10:37 +00:00
/**
* Return the FieldSet used to edit this folder in the CMS .
2011-04-15 19:35:30 +10:00
* You can modify this fieldset by subclassing folder , or by creating a { @ link DataExtension }
* and implemeting updateCMSFields ( FieldSet $fields ) on that extension .
2008-02-25 02:10:37 +00:00
*/
function getCMSFields () {
$fileList = new AssetTableField (
$this ,
" Files " ,
" File " ,
2009-10-15 22:19:25 +00:00
array ( " Title " => _t ( 'Folder.TITLE' , " Title " ), " Filename " => _t ( 'Folder.FILENAME' , " Filename " )),
2008-02-25 02:10:37 +00:00
" "
);
$fileList -> setFolder ( $this );
2008-10-10 17:35:24 +00:00
$fileList -> setPopupCaption ( _t ( 'Folder.VIEWEDITASSET' , " View/Edit Asset " ));
2008-02-25 02:10:37 +00:00
2010-04-12 23:09:15 +00:00
$titleField = ( $this -> ID && $this -> ID != " root " ) ? new TextField ( " Title " , _t ( 'Folder.TITLE' )) : new HiddenField ( " Title " );
2008-11-07 12:17:42 +00:00
if ( $this -> canEdit () ) {
2008-10-10 17:35:24 +00:00
$deleteButton = new InlineFormAction ( 'deletemarked' , _t ( 'Folder.DELSELECTED' , 'Delete selected files' ), 'delete' );
2008-02-25 02:10:37 +00:00
$deleteButton -> includeDefaultJS ( false );
} else {
$deleteButton = new HiddenField ( 'deletemarked' );
}
$fields = new FieldSet (
2010-04-12 23:09:15 +00:00
new HiddenField ( " Name " ),
2008-02-25 02:10:37 +00:00
new TabSet ( " Root " ,
2008-10-10 17:35:24 +00:00
new Tab ( " Files " , _t ( 'Folder.FILESTAB' , " Files " ),
2010-04-12 23:09:15 +00:00
$titleField ,
2008-02-25 02:10:37 +00:00
$fileList ,
new HiddenField ( " DestFolderID " )
),
2008-10-10 17:35:24 +00:00
new Tab ( " Details " , _t ( 'Folder.DETAILSTAB' , " Details " ),
new ReadonlyField ( " URL " , _t ( 'Folder.URL' , 'URL' )),
new ReadonlyField ( " ClassName " , _t ( 'Folder.TYPE' , 'Type' )),
new ReadonlyField ( " Created " , _t ( 'Folder.CREATED' , 'First Uploaded' )),
new ReadonlyField ( " LastEdited " , _t ( 'Folder.LASTEDITED' , 'Last Updated' ))
2008-02-25 02:10:37 +00:00
),
2008-10-10 17:35:24 +00:00
new Tab ( " Upload " , _t ( 'Folder.UPLOADTAB' , " Upload " ),
2008-02-25 02:10:37 +00:00
new LiteralField ( " UploadIframe " ,
$this -> getUploadIframe ()
)
2010-10-13 00:44:19 +00:00
)
2009-04-28 23:52:15 +00:00
),
2008-02-25 02:10:37 +00:00
new HiddenField ( " ID " )
);
2009-05-14 05:26:47 +00:00
if ( ! $this -> canEdit ()) {
$fields -> removeFieldFromTab ( " Root " , " Upload " );
}
2008-02-25 02:10:37 +00:00
$this -> extend ( 'updateCMSFields' , $fields );
return $fields ;
}
/**
* Display the upload form . Returns an iframe tag that will show admin / assets / uploadiframe .
*/
function getUploadIframe () {
return <<< HTML
2009-02-01 23:49:53 +00:00
< iframe name = " AssetAdmin_upload " src = " admin/assets/uploadiframe/ { $this -> ID } " id = " AssetAdmin_upload " border = " 0 " style = " border-style none !important; width: 97%; min-height: 300px; height: 100%; height: expression(document.body.clientHeight) !important; " >
2008-02-25 02:10:37 +00:00
</ iframe >
HTML ;
}
2007-12-13 21:47:07 +00:00
2009-07-01 22:27:18 +00:00
/**
* Get the children of this folder that are also folders .
*/
function ChildFolders () {
2009-08-31 06:06:44 +00:00
return DataObject :: get ( " Folder " , " \" ParentID \" = " . ( int ) $this -> ID );
2009-07-01 22:27:18 +00:00
}
2009-11-21 02:33:42 +00:00
/**
* @ return String
*/
function CMSTreeClasses ( $controller ) {
$classes = sprintf ( 'class-%s' , $this -> class );
if ( ! $this -> canDelete ())
$classes .= " nodelete " ;
if ( $controller -> isCurrentPage ( $this ))
$classes .= " current " ;
if ( ! $this -> canEdit ())
$classes .= " disabled " ;
$classes .= $this -> markingClasses ();
return $classes ;
}
2011-03-23 13:23:43 +13:00
}