Improve content authoring with this Kentico Xperience module. It allows providing automatic content asset folders for pages in the Xperience content tree.
A common way way to improve content authoring in Kentico Xperience is to allow multiple pieces of child content to be organized with each page in the content tree. This provides an easy way for authors to organize the child content that belongs to each page.
This solution uses Xperience's global events to automatically create asset folders for authors whenever they create a new page. This solution is configurable, so that developers can determine which types of pages are given asset folders, and the page type used to create each asset folders. By allowing the use of a separate folder type for each page type, the solution allows you to control what child types are allowed under each page or folder. This provides authors a nicely trimmed list of options when they add content to a folder, so they do not have overwhelming choices, and are not allowed to create unsupported content.
- .NET 4.6.1 or higher
- Kentico Xperience versions
- 12.0.29 or higher (use KenticoCommunity.PageAssetFolders 12.0.0)
- 13.0.0 or higher (use KenticoCommunity.PageAssetFolders 13.0.0)
To install, add the NuGet package, "KenticoCommunity.PageAssetFolders", to your CMS project and then add the web.config sections described below.
After adding the NuGet package to your CMS project, the Page Asset Folder module is installed. It will look for a web.config section to determine what default folders to create.
Note: You can also register your own IAssetFolderRegistrationListFactory
, if you'd rather configure the module in code. If that's your preference, jump to the section, Create your own configuration factory.
Add the following line to the configSections
element of the web.config.
<section name="defaultAssetFolders" type="KenticoCommunity.PageAssetFolders.Configurations.DefaultAssetFoldersSection,KenticoCommunity.PageAssetFolders" />
Here's an example of adding configurations for two types of pages. Notice for each type of page, the type of folder is specified, as well as the default name for new folders.
<defaultAssetFolders>
<assetFolder parentClass="cms.menuitem" childClass="cms.folder" defaultName="Page assets"/>
<assetFolder parentClass="Acme.LandingPage" childClass="Acme.LandingPageAssetFolder" defaultName="Page assets"/>
</defaultAssetFolders>
If you'd prefer to configure this module in code, simply create your own implementation of IAssetFolderRegistrationListFactory
and register it using Kentico's RegisterImplementation
assembly attribute. Here's a sample:
using CMS;
using CMSApp.Acme.Factories;
using KenticoCommunity.PageAssetFolders.Interfaces;
using KenticoCommunity.PageAssetFolders.Models;
using System.Collections.Generic;
[assembly: RegisterImplementation(typeof(IAssetFolderRegistrationListFactory), typeof(AssetFolderRegistrationListFactory))]
namespace CMSApp.Acme.Factories
{
public class AssetFolderRegistrationListFactory : IAssetFolderRegistrationListFactory
{
public List<AssetFolderRegistration> GetAssetFolderRegistrations()
=> new List<AssetFolderRegistration>()
{
new AssetFolderRegistration()
{
ParentClass = "cms.menuitem",
ChildClass = "cms.folder",
DefaultName = "Assets"
},
new AssetFolderRegistration()
{
ParentClass = "Acme.LandingPage",
ChildClass = "Acme.LandingPageAssetFolder",
DefaultName = "Assets"
}
};
}
}
IMPORTANT: Global system events fire when pages are created through the Xperience Staging module. This will cause the custom module to create the page asset folder, even though the same folder would be staged from the source environment. The end result would be staging conflicts, because the module created an asset folder in the destination environment that conflicts with the one coming from the source environment.
To prevent this, add the following appSetting key to the web.config. This setting will prevent events from DocumentEvents class from being raised when processing staging tasks.
<add key="CMSStagingUseTreeCustomHandlers" value="false" />
This project uses a standard MIT license which can be found here.
Contributions are welcome. Feel free to submit pull requests to the repo.
Please report bugs as issues in this GitHub repo. We'll respond as soon as possible.