Page
class Page extends Collection implements ObjectInterface, ObjectInterface, AssignableObjectInterface, TreeInterface, SiteAggregateInterface, ExportableInterface (View source)
The page object in Concrete encapsulates all the functionality used by a typical page and their contents including blocks, page metadata, page permissions.
Traits
Properties
$error | from ConcreteObject | ||
int|null deprecated | $cID | The collection ID. |
from Collection |
protected Version|null | $vObj | The collection version object. |
from Collection |
protected string|null | $cHandle | The collection handle. |
from Collection |
protected string|null | $cDateAdded | The date/time when the collection has been created. |
from Collection |
protected string|null | $cDateModified | The date/time when the collection was last modified. |
from Collection |
protected array | $attributes | from Collection | |
Tree|null deprecated | $siteTree | ||
protected PageController|null | $controller | The page controller. |
|
protected int[]|null | $blocksAliasedFromMasterCollection | The list of block IDs that are alias. |
|
protected int|null | $cPointerOriginalID | The original cID of a page (if it's a page alias). |
|
protected int|null | $cPointerOriginalSiteTreeID | The original siteTreeID of a page (if it's a page alias). |
|
protected string|null | $cPointerExternalLink | The link for the aliased page. |
|
protected bool|int|null | $cPointerExternalLinkNewWindow | Should the alias link to be opened in a new window? |
|
protected bool|int|null | $isMasterCollection | Is this page a page default? |
|
protected int|null | $cInheritPermissionsFromCID | The ID of the page from which this page inherits permissions from. |
|
protected bool | $cIsSystemPage | Is this a system page? |
|
protected int|null | $siteTreeID | The site tree ID. |
Methods
Destruct the class instance.
- Get a page given its ID.
Get a Collection by handle (provided that it's not a Page handle).
(Re)Index all the collections that are marked as to be (re)indexed.
Get the page handle.
Get the date/time when the collection was last modified.
Get the date/time when the collection has been created.
Create a new Collection instance, using the same theme as this instance (if it's a Page instance).
Load a specific collection version (you can retrieve it with the getVersionObject() method).
Get the Collection instance to be modified (this instance if it's a new or master Collection, a clone otherwise).
Get the automatic comment for the next collection version.
(Re)Index the contents of this collection (or mark the collection as to be reindexed if $actuallyDoReindex is falsy and the concrete.page.search.always_reindex configuration key is falsy).
Set the attribute value for the currently loaded collection version.
Return the value of the attribute with the handle $akHandle of the currently loaded version (if it's loaded).
Return the attribute value object with the handle $akHandle of the currently loaded version (if it's loaded).
Delete the values of the attributes associated to the currently loaded collection version.
Delete the value of a specific attribute key associated to the currently loaded collection version.
Get the list of attribute keys for which the currently loaded collection version has values.
Get an existing area associated to this collection.
Does this collection contain blocks that are aliased in other pages?
Get the custom style of an area in the currently loaded collection version.
Set the custom style of an area in the currently loaded collection version.
Delete all the custom styles of an area of the currently loaded collection version.
Retrieve all custom style rules that should be inserted into the header on a page, whether they are defined in areas or blocks.
Get the Collection Type ID.
List the blocks in the currently loaded collection version (or in a specific area within it).
List the block IDs and the associated area handles in the currently loaded collection version (or in a specific area within it).
Get the next value of the display order (to be used when adding new blocks to an area).
Fix the display order properties for all the blocks within the collection/area.
Get the list of assigned features.
Delete this page and all its child pages.
Create a clone of this collection, and all its versions, contents and attributes.
Clone the currently loaded version and returns a Page instance containing the new version.
No description
Initialize collection until we populate it.
Get a page given its path.
No description
No description
No description
No description
No description
Return a representation of the Page object as something easily serializable.
Get the page controller.
No description
Is the page in edit mode?
Get the package ID for a page (page thats added by a package) (returns 0 if its not in a package).
Get the handle the the package that added this page.
Forces the page to be checked in if its checked out.
No description
Is this a dashboard page?
Uses a Request object to determine which page to load. Queries by path and then by cID.
Persist the data associated to a block when it has been moved around in the page.
Is the page checked out?
Gets the user that is editing the current page.
Checks if the page is checked out by the current user.
Checks if the page is a single page.
No description
No description
Is this a draft page?
This is the legacy function that is called just by xml. We pass these values in as though they were the old ones.
Make an alias to a page.
Update the name, link, and to open in a new window for an external link.
Add a new external link as a child of this page.
Returns true if a page is a system page. A system page is either a page that is outside the site tree (has a site tree ID of 0) or a page that is in the site tree, but whose parent starts at 0. That means its a root level page. Why do we need this separate boolean then? Because we need to easily be able to filter all pages by whether they're a system page even if we don't necessarily know where their starting page is.
Gets the icon for a page (also fires the on_page_get_icon event).
Remove an external link/alias.
Create an array containing data about child pages.
Sort a list of pages, so that the order is correct for the deletion.
Sort a list of pages, so that the order is correct for the duplication.
Add this page and its subpages to the Delete Page queue.
Add this page and its subpages to the Delete Page Requests queue (or to a custom queue).
Add this page and its subpages to the Copy Page queue.
Get the uID for a page that is checked out (if any).
Get the path of this page.
Returns the PagePath object for the current page.
Add a non-canonical page path to the current page.
Set the canonical page path for a page.
Get all the page paths of this page.
Get all the non-canonical page paths of this page.
Clears all page paths for a page.
Returns full url for the current page.
No description
No description
Returns the path for a page from its cID.
Get the uID of the page author (if any).
Get the display name of the page type (if available).
Get the page type object.
Get the Page Template ID.
Get the Page Template Object (if available).
Get the handle of the Page Template (if available).
Get the handle of the Page Type (if available).
Get the theme ID for the collection (if available).
Get the collection's theme object.
Get the page name.
Get the collection ID for the aliased page (returns 0 unless used on an actual alias).
Get the link for the aliased page.
Should the alias link to be opened in a new window?
Is this page an alias page of another page?
Is this page an alias page or an external link?
Is this page an external link?
Get the original cID of a page (if it's a page alias).
Get the file name of a page (single pages).
Get the date/time when the current version was made public (or a falsy value if the current version doesn't have public date).
Get the date/time when the current version was made public (or NULL value if the current version doesn't have public date).
Get the description of a page.
Ges the cID of the parent page.
Get the parent cID of a page given its cID.
Get an array containint this cParentID and aliased parentIDs.
Is this page a page default?
Are template permissions overriden?
Get the position of the page in the sitemap, relative to its parent page.
Set the permissions of sub-collections added beneath this permissions to inherit from the template.
Set the permissions of sub-collections added beneath this permissions to inherit from the parent.
Get the ID of the page from which this page inherits permissions from.
Where permissions should be inherited from? 'PARENT' or 'TEMPLATE' or 'OVERRIDE'.
Get the ID of the page from which the parent page page inherits permissions from.
Get the page from which this page inherits permissions from.
Get the master page of this page, given its page template and page type.
Get the ID of the original collection.
Get the number of child pages.
Get the number of child pages (direct children only).
Get the first child of the current page, or null if there is no child.
Get the list of child page IDs, sorted by their display order.
Get the immediate children of the this page.
Update the collection name.
Does this page have theme customizations?
Clears the custom theme styles for this page.
Set the custom style for this page for a specific theme.
Get the CSS class to be used to wrap the whole page contents.
Write the page theme customization CSS files to the cache directory.
Clears the custom theme styles for every page.
Update the data of this page.
Clear all the page permissions.
Set this page permissions to be inherited from its parent page.
Set this page permissions to be inherited from its parent type defaults.
Set this page permissions to be manually specified.
Rescan the page areas ensuring that they are inheriting permissions properly.
Are template permissions overriden?
Set the child pages of a list of parent pages to inherit permissions from the specified page (provided that they previouly had the same inheritance page as this page).
Acquire the area permissions, copying them from the inherited ones.
Acquire the page permissions, copying them from the inherited ones.
Get the relations of this page.
Move this page under a new parent page.
Duplicate this page and all its child pages and return the new Page created.
Duplicate this page and return the new Page created.
Move this page and all its child pages to the trash.
Regenerate the display order of the child pages.
Is this the homepage for the site tree this page belongs to?
Get the ID of the homepage for the site tree this page belongs to.
Get a new PagePath object with the computed canonical page path.
Get the next available display order of child pages.
Get the URL-slug-based path to the current page (including any suffixes) in a string format. Does so in real time.
Recalculate the canonical page path for the current page and its sub-pages, based on its current version, URL slug, etc.
Set a new display order for this page (or for another page given its ID).
Make this page the first child of its parent.
Make this page the first child of its parent.
Move this page before of after another page.
Recalculate the "is a system page" state.
Is this page in the trash?
Make this page child of nothing, thus moving it to the root level.
Mark this page as non active.
Mark this page as non draft.
Mark this page as active.
Is this page marked as active?
Set the page index score (used by a PageList for instance).
Get the page index score (as set by a PageList for instance).
Get the indexed content of this page.
Add the home page to the system. Typically used only by the installation program.
Get the custom style for the currently loaded page version (if any).
Get the full-page cache flag (-1: use global setting; 0: no; 1: yes - NULL if page is not loaded).
Get the full-page cache lifetime criteria ('default': use default lifetime; 'forever': no expiration; 'custom': custom lifetime value - see getCollectionFullPageCachingLifetimeCustomValue(); other: use the default lifetime - NULL if page is not loaded).
Get the full-page cache custom lifetime in minutes (to be used if getCollectionFullPageCachingLifetime() is 'custom').
Get the actual full-page cache lifespan (in seconds).
Get the currently requested page.
Get the ID of the draft parent page ID.
Set the ID of the draft parent page ID.
Read the data from the database.
Populate the childrenCIDArray property (called by the getCollectionChildrenArray() method).
Duplicate all the child pages of a specific page which has already have been duplicated.
Get the canonical path string of this page .
Duplicate the master collection blocks/permissions to a newly created page.
Duplicate the master collection attributes to a newly created page.
Details
loadError($error)
No description
isError()
No description
getError()
No description
setPropertiesFromArray($arr)
No description
static
camelcase($file)
No description
static
uncamelcase($string)
No description
__destruct()
Destruct the class instance.
static Collection
getByID(int $cID, string|int|false $version = 'RECENT')
- Get a page given its ID.
static Collection|null
getByHandle(string $handle)
Get a Collection by handle (provided that it's not a Page handle).
If there's there's no collection with the specified handle, a new Collection will be created.
static int
reindexPendingPages()
(Re)Index all the collections that are marked as to be (re)indexed.
static Collection
createCollection(array $data)
Create a new Collection instance.
int|null
getCollectionID()
Get the collection ID.
string|null
getCollectionHandle()
Get the page handle.
string|null
getCollectionDateLastModified()
Get the date/time when the collection was last modified.
string|null
getCollectionDateAdded()
Get the date/time when the collection has been created.
int
getVersionID()
Get the ID of the currently loaded version.
Version|null
getVersionObject()
Get the currently loaded version object.
Collection
addCollection(array $data)
Create a new Collection instance, using the same theme as this instance (if it's a Page instance).
loadVersionObject(string|int $cvID = 'ACTIVE')
Load a specific collection version (you can retrieve it with the getVersionObject() method).
$this|Page
getVersionToModify()
Get the Collection instance to be modified (this instance if it's a new or master Collection, a clone otherwise).
string
getNextVersionComments()
Get the automatic comment for the next collection version.
bool|null
reindex(IndexedSearch|false $index = false, bool $actuallyDoReindex = true)
(Re)Index the contents of this collection (or mark the collection as to be reindexed if $actuallyDoReindex is falsy and the concrete.page.search.always_reindex configuration key is falsy).
PageValue
setAttribute(string|CollectionKey $ak, AbstractValue|mixed $value, bool $doReindexImmediately = true)
Set the attribute value for the currently loaded collection version.
mixed|null
getAttribute(string|CollectionKey $akHandle, string|false $displayMode = false)
Return the value of the attribute with the handle $akHandle of the currently loaded version (if it's loaded).
PageValue|null
getAttributeValueObject(string|CollectionKey $akHandle, bool $createIfNotExists = false)
Return the attribute value object with the handle $akHandle of the currently loaded version (if it's loaded).
clearCollectionAttributes(int[] $retainAKIDs = [])
Delete the values of the attributes associated to the currently loaded collection version.
clearAttribute(string|CollectionKey $ak, bool $doReindexImmediately = true)
Delete the value of a specific attribute key associated to the currently loaded collection version.
PageKey[]
getSetCollectionAttributes()
Get the list of attribute keys for which the currently loaded collection version has values.
Area|null
getArea(string $arHandle)
Get an existing area associated to this collection.
bool
hasAliasedContent()
Does this collection contain blocks that are aliased in other pages?
CustomStyle|null
getAreaCustomStyle(Area $area, bool $force = false)
Get the custom style of an area in the currently loaded collection version.
setCustomStyleSet(Area $area, StyleSet $set)
Set the custom style of an area in the currently loaded collection version.
resetAreaCustomStyle(Area $area)
Delete all the custom styles of an area of the currently loaded collection version.
string|null
outputCustomStyleHeaderItems(bool $return = false)
Retrieve all custom style rules that should be inserted into the header on a page, whether they are defined in areas or blocks.
null|false
relateVersionEdits(Collection $oc)
Associate the edits of another collection to this collection.
int|false
getPageTypeID()
Get the Collection Type ID.
refreshCache()
Empty the collection-related cache.
Block[]
getGlobalBlocks()
Get the blocks contained in the all the global areas.
Block[]
getBlocks(string|false $arHandle = false)
List the blocks in the currently loaded collection version (or in a specific area within it).
array
getBlockIDs(string|false $arHandle = false)
List the block IDs and the associated area handles in the currently loaded collection version (or in a specific area within it).
Block
addBlock(BlockType $bt, string|Area $a, array $data)
Add a new block to a specific area of the page.
int
getCollectionAreaDisplayOrder(string $arHandle, bool $ignoreVersions = false)
Get the next value of the display order (to be used when adding new blocks to an area).
rescanDisplayOrder(string $arHandle)
Fix the display order properties for all the blocks within the collection/area.
addFeature(Feature $fe)
Associate a feature to the currently loaded collection version.
CollectionVersionAssignment[]
getFeatureAssignments()
Get the list of assigned features.
markModified()
Update the last edit date/time.
delete()
Delete this page and all its child pages.
Collection
duplicateCollection()
Create a clone of this collection, and all its versions, contents and attributes.
Page
cloneVersion(string|null $versionComments, bool $createEmpty = false)
Clone the currently loaded version and returns a Page instance containing the new version.
PageValue|null
getAttributeValue(string|CollectionKey $ak)
deprecated
deprecated
No description
mixed|null
getCollectionAttributeValue(string|CollectionKey $akHandle)
deprecated
deprecated
No description
getCollectionTypeID()
deprecated
deprecated
No description
assignPermissions($userOrGroup, $permissions = [], $accessType = Key::ACCESS_TYPE_INCLUDE, $cascadeToChildren = true)
No description
__construct()
Initialize collection until we populate it.
static Page
getByPath(string $path, string $version = 'RECENT', TreeInterface $tree = null)
Get a page given its path.
CategoryInterface
getObjectAttributeCategory()
No description
ItemInterface
getExporter()
No description
getPermissionResponseClassName()
No description
getPermissionAssignmentClassName()
No description
getPermissionObjectKeyCategoryHandle()
No description
stdClass
getJSONObject()
Return a representation of the Page object as something easily serializable.
PageController
getPageController()
Get the page controller.
getPermissionObjectIdentifier()
No description
bool
isEditMode()
Is the page in edit mode?
int
getPackageID()
Get the package ID for a page (page thats added by a package) (returns 0 if its not in a package).
string|null
getPackageHandle()
Get the handle the the package that added this page.
false
isArrangeMode()
deprecated
deprecated
No description
forceCheckIn()
Forces the page to be checked in if its checked out.
static private
forceCheckInForAllPages()
No description
bool
isAdminArea()
Is this a dashboard page?
static Page
getFromRequest(Request $request)
Uses a Request object to determine which page to load. Queries by path and then by cID.
processArrangement(int $area_id, int $moved_block_id, int[] $block_order)
Persist the data associated to a block when it has been moved around in the page.
bool|null
isCheckedOut()
Is the page checked out?
string
getCollectionCheckedOutUserName()
Gets the user that is editing the current page.
bool
isCheckedOutByMe()
Checks if the page is checked out by the current user.
bool
isGeneratedCollection()
Checks if the page is a single page.
Generated collections are collections without templates, that have special cFilename attributes .
setPermissionsToOverride()
No description
setChildPermissionsToOverride()
No description
removePermissions(Group|Group[]|User|UserInfo|User $userOrGroup, string[] $permissions = [])
Remove specific permission keys for a specific access entity (user, group, group combination).
bool
isPageDraft()
Is this a draft page?
setController(PageController|null $controller)
Set the page controller.
PageController
getController()
deprecated
deprecated
No description
private
assignPermissionSet(SimpleXMLElement $px)
This is the legacy function that is called just by xml. We pass these values in as though they were the old ones.
int
addCollectionAlias(mixed $c)
Make an alias to a page.
updateCollectionAliasExternal(string $cName, string $cLink, bool $newWindow = 0)
Update the name, link, and to open in a new window for an external link.
int
addCollectionAliasExternal(string $cName, string $cLink, bool $newWindow = 0)
Add a new external link as a child of this page.
bool
isSystemPage()
Returns true if a page is a system page. A system page is either a page that is outside the site tree (has a site tree ID of 0) or a page that is in the site tree, but whose parent starts at 0. That means its a root level page. Why do we need this separate boolean then? Because we need to easily be able to filter all pages by whether they're a system page even if we don't necessarily know where their starting page is.
string
getCollectionIcon()
Gets the icon for a page (also fires the on_page_get_icon event).
int|null
removeThisAlias()
Remove an external link/alias.
array
populateRecursivePages(array $pages, array $pageRow, int $cParentID, int $level, bool $includeThisPage = true)
Create an array containing data about child pages.
int
queueForDeletionSort(array $a, array $b)
Sort a list of pages, so that the order is correct for the deletion.
int
queueForDuplicationSort(array $a, array $b)
Sort a list of pages, so that the order is correct for the duplication.
queueForDeletion()
Add this page and its subpages to the Delete Page queue.
queueForDeletionRequest(Queue|null $queue = null, bool $includeThisPage = true)
Add this page and its subpages to the Delete Page Requests queue (or to a custom queue).
queueForDuplication(Page $destination, bool $includeParent = true)
Add this page and its subpages to the Copy Page queue.
export(SimpleXMLElement $pageNode)
deprecated
deprecated
No description
int|null
getCollectionCheckedOutUserID()
Get the uID for a page that is checked out (if any).
string
getCollectionPath()
Get the path of this page.
PagePath|null
getCollectionPathObject()
Returns the PagePath object for the current page.
PagePath
addAdditionalPagePath(string $cPath, bool $commit = true)
Add a non-canonical page path to the current page.
setCanonicalPagePath(string $cPath, bool $isAutoGenerated = false)
Set the canonical page path for a page.
PagePath[]
getPagePaths()
Get all the page paths of this page.
PagePath[]
getAdditionalPagePaths()
Get all the non-canonical page paths of this page.
clearPagePaths()
Clears all page paths for a page.
string
getCollectionLink(bool $appendBaseURL = false)
Returns full url for the current page.
int|null
getSiteTreeID()
No description
Site
getSite()
No description
Tree|null
getSiteTreeObject()
No description
static
getCollectionPathFromID(mixed $cID)
Returns the path for a page from its cID.
int|null
getCollectionUserID()
Get the uID of the page author (if any).
string|null
getCollectionTypeName()
deprecated
deprecated
No description
string|null
getPageTypeName()
Get the display name of the page type (if available).
Type|null
getPageTypeObject()
Get the page type object.
int
getPageTemplateID()
Get the Page Template ID.
Template|null
getPageTemplateObject()
Get the Page Template Object (if available).
string|false
getPageTemplateHandle()
Get the handle of the Page Template (if available).
string|false
getPageTypeHandle()
Get the handle of the Page Type (if available).
string|false
getCollectionTypeHandle()
deprecated
deprecated
No description
int|null
getCollectionThemeID()
Get the theme ID for the collection (if available).
bool
isBlockAliasedFromMasterCollection(Block $b)
Check if a block is an alias from a page default.
Theme
getCollectionThemeObject()
Get the collection's theme object.
string
getCollectionName()
Get the page name.
int
getCollectionPointerID()
Get the collection ID for the aliased page (returns 0 unless used on an actual alias).
string|null
getCollectionPointerExternalLink()
Get the link for the aliased page.
bool|int|null
openCollectionPointerExternalLinkInNewWindow()
Should the alias link to be opened in a new window?
bool
isAliasPage()
Is this page an alias page of another page?
bool
isAliasPageOrExternalLink()
Is this page an alias page or an external link?
bool
isAlias()
deprecated
deprecated
No description
bool
isExternalLink()
Is this page an external link?
int
getCollectionPointerOriginalID()
Get the original cID of a page (if it's a page alias).
string
getCollectionFilename()
Get the file name of a page (single pages).
string
getCollectionDatePublic()
Get the date/time when the current version was made public (or a falsy value if the current version doesn't have public date).
DateTime|null
getCollectionDatePublicObject()
Get the date/time when the current version was made public (or NULL value if the current version doesn't have public date).
string
getCollectionDescription()
Get the description of a page.
int|null
getCollectionParentID()
Ges the cID of the parent page.
static int|null
getCollectionParentIDFromChildID(int $cID)
Get the parent cID of a page given its cID.
int[]
getCollectionParentIDs()
Get an array containint this cParentID and aliased parentIDs.
bool|int|null
isMasterCollection()
Is this page a page default?
bool|int|null
overrideTemplatePermissions()
Are template permissions overriden?
int|null
getCollectionDisplayOrder()
Get the position of the page in the sitemap, relative to its parent page.
setTheme(Theme $pl)
Set the theme of this page.
setPageType(Type $type = null)
Set the theme for a page using the page object.
setPermissionsInheritanceToTemplate()
Set the permissions of sub-collections added beneath this permissions to inherit from the template.
setPermissionsInheritanceToOverride()
Set the permissions of sub-collections added beneath this permissions to inherit from the parent.
int|null
getPermissionsCollectionID()
Get the ID of the page from which this page inherits permissions from.
string|null
getCollectionInheritance()
Where permissions should be inherited from? 'PARENT' or 'TEMPLATE' or 'OVERRIDE'.
int|null
getParentPermissionsCollectionID()
Get the ID of the page from which the parent page page inherits permissions from.
Page
getPermissionsCollectionObject()
Get the page from which this page inherits permissions from.
int
getMasterCollectionID()
Get the master page of this page, given its page template and page type.
int|null
getOriginalCollectionID()
Get the ID of the original collection.
int|null
getNumChildren()
Get the number of child pages.
int
getNumChildrenDirect()
Get the number of child pages (direct children only).
Page|false
getFirstChild(string $sortColumn = 'cDisplayOrder asc')
Get the first child of the current page, or null if there is no child.
int[]
getCollectionChildrenArray(bool $oneLevelOnly = 0)
Get the list of child page IDs, sorted by their display order.
Page[]
getCollectionChildren()
Get the immediate children of the this page.
bool
canMoveCopyTo(Collection $cobj)
Check if a collection is this page itself or one of its sub-pages.
updateCollectionName(string $name)
Update the collection name.
bool
hasPageThemeCustomizations()
Does this page have theme customizations?
resetCustomThemeStyles()
Clears the custom theme styles for this page.
CustomStyle
setCustomStyleObject(Theme $pt, ValueList $valueList, Preset|null|false $selectedPreset = false, CustomCssRecord $customCssRecord = null)
Set the custom style for this page for a specific theme.
string
getPageWrapperClass()
Get the CSS class to be used to wrap the whole page contents.
writePageThemeCustomizations()
Write the page theme customization CSS files to the cache directory.
static
resetAllCustomStyles()
Clears the custom theme styles for every page.
update(array $data)
Update the data of this page.
clearPagePermissions()
Clear all the page permissions.
inheritPermissionsFromParent()
Set this page permissions to be inherited from its parent page.
inheritPermissionsFromDefaults()
Set this page permissions to be inherited from its parent type defaults.
setPermissionsToManualOverride()
Set this page permissions to be manually specified.
rescanAreaPermissions()
Rescan the page areas ensuring that they are inheriting permissions properly.
setOverrideTemplatePermissions(bool|int $cOverrideTemplatePermissions)
Are template permissions overriden?
updatePermissionsCollectionID(int|string $cParentIDString, mixed $npID)
Set the child pages of a list of parent pages to inherit permissions from the specified page (provided that they previouly had the same inheritance page as this page).
acquireAreaPermissions(int $permissionsCollectionID)
Acquire the area permissions, copying them from the inherited ones.
acquirePagePermissions(int $permissionsCollectionID)
Acquire the page permissions, copying them from the inherited ones.
updateGroupsSubCollection(int|string $cParentIDString)
deprecated
deprecated
No description
SiblingRelation[]
getPageRelations()
Get the relations of this page.
move(mixed $nc)
Move this page under a new parent page.
Page
duplicateAll(null|mixed $nc = null, bool $preserveUserID = false, Site $site = null)
Duplicate this page and all its child pages and return the new Page created.
Page
duplicate(null|mixed $nc = null, bool $preserveUserID = false, TreeInterface $site = null)
Duplicate this page and return the new Page created.
moveToTrash()
Move this page and all its child pages to the trash.
rescanChildrenDisplayOrder()
Regenerate the display order of the child pages.
bool
isHomePage()
Is this the homepage for the site tree this page belongs to?
int|null
getSiteHomePageID()
Get the ID of the homepage for the site tree this page belongs to.
bool
isLocaleHomePage()
deprecated
deprecated
No description
static int|null
getHomePageID(Page|int $page = null)
Get the ID of the home page.
PagePath
getAutoGeneratedPagePathObject()
Get a new PagePath object with the computed canonical page path.
int
getNextSubPageDisplayOrder()
Get the next available display order of child pages.
string
generatePagePath()
Get the URL-slug-based path to the current page (including any suffixes) in a string format. Does so in real time.
rescanCollectionPath()
Recalculate the canonical page path for the current page and its sub-pages, based on its current version, URL slug, etc.
updateDisplayOrder(int $displayOrder, int|null $cID = 0)
Set a new display order for this page (or for another page given its ID).
movePageDisplayOrderToTop()
Make this page the first child of its parent.
movePageDisplayOrderToBottom()
Make this page the first child of its parent.
movePageDisplayOrderToSibling(Page $c, string $position = 'before')
Move this page before of after another page.
rescanSystemPageStatus()
Recalculate the "is a system page" state.
Looks at the current page. If the site tree ID is 0, sets system page to true. If the site tree is not user, looks at where the page falls in the hierarchy. If it's inside a page at the top level that has 0 as its parent, then it is considered a system page.
bool
isInTrash()
Is this page in the trash?
moveToRoot()
Make this page child of nothing, thus moving it to the root level.
deactivate()
Mark this page as non active.
setPageToDraft()
Mark this page as non draft.
activate()
Mark this page as active.
bool
isActive()
Is this page marked as active?
setPageIndexScore(float $score)
Set the page index score (used by a PageList for instance).
float
getPageIndexScore()
Get the page index score (as set by a PageList for instance).
string
getPageIndexContent()
Get the indexed content of this page.
static Page
addHomePage(TreeInterface $siteTree = null)
Add the home page to the system. Typically used only by the installation program.
Page
add(mixed $pt, array $data, mixed $template = false)
Add a new page, child of this page.
CustomStyle|null
getCustomStyleObject()
Get the custom style for the currently loaded page version (if any).
int|null
getCollectionFullPageCaching()
Get the full-page cache flag (-1: use global setting; 0: no; 1: yes - NULL if page is not loaded).
string|null
getCollectionFullPageCachingLifetime()
Get the full-page cache lifetime criteria ('default': use default lifetime; 'forever': no expiration; 'custom': custom lifetime value - see getCollectionFullPageCachingLifetimeCustomValue(); other: use the default lifetime - NULL if page is not loaded).
int|null
getCollectionFullPageCachingLifetimeCustomValue()
Get the full-page cache custom lifetime in minutes (to be used if getCollectionFullPageCachingLifetime() is 'custom').
int
getCollectionFullPageCachingLifetimeValue()
Get the actual full-page cache lifespan (in seconds).
static Page
addStatic(array $data, TreeInterface $parent = null)
Create a new page.
static Page|null
getCurrentPage()
Get the currently requested page.
int
getPageDraftTargetParentPageID()
Get the ID of the draft parent page ID.
setPageDraftTargetParentPageID(int $cParentID)
Set the ID of the draft parent page ID.
protected
populatePage(mixed $cInfo, string $where, string|int $cvID)
Read the data from the database.
protected
_getNumChildren(int $cID, bool $oneLevelOnly = 0, string $sortColumn = 'cDisplayOrder asc')
Populate the childrenCIDArray property (called by the getCollectionChildrenArray() method).
protected
_duplicateAll(mixed $cParent, mixed $cNewParent, bool $preserveUserID = false, Site $site = null)
Duplicate all the child pages of a specific page which has already have been duplicated.
protected string
computeCanonicalPagePath()
Get the canonical path string of this page .
This happens before any uniqueness checks get run.
protected
_associateMasterCollectionBlocks(int $newCID, mixed $masterCID, bool $cAcquireComposerOutputControls)
Duplicate the master collection blocks/permissions to a newly created page.
protected
_associateMasterCollectionAttributes(int $newCID, mixed $masterCID)
Duplicate the master collection attributes to a newly created page.
protected
acquireAreaStylesFromDefaults(Template $template)
Copy the area styles from a page template.
static private string[]
translatePermissionsXMLToKeys(SimpleXMLElement $node)
No description