Feb 8, 2011
visibility 3907
star star star star star
(1 votes)

Common properties amongst the pages

Instead of using a lot of dynamic properties one can create a special settings page. On this page all site-wide settings are saved all together. Then you make only the name of this page to be a dynamic property (ref. to http://www.meadow.se/wordpress/?cat=12). This is a common solution. However, code in the code-behind files becomes a little more complicated if you want to retrieve the settings from the settings page.

For example:

PropertyCriteriaCollection

        propertyCriteriaCollection = new PropertyCriteriaCollection();

PropertyCriteria criteria = new PropertyCriteria();

criteria.Condition = CompareCondition.Equal;

criteria.Name = "PageTypeID";

criteria.Type = PropertyDataType.PageType;

criteria.Value = PageType.Load("SettingsPage").ID.ToString();

criteria.Required = true;

propertyCriteriaCollection.Add(criteria);

PageDataCollection pageDataCollection

                = DataFactory.Instance.FindPagesWithCriteria

                    (PageReference.RootPage, propertyCriteriaCollection);

if (pageDataCollection == null || pageDataCollection.Count == 0)

                return;

                      

if (pageDataCollection[0]["SomeProperty"] != null)

                TextBox1.Text =

                       pageDataCollection[0] ["SomeProperty"].ToString();

 

You see how many actions should be performed with a single aim – to get the SettingsPage’s SomeProperty value. Evidently it’s tiresome and error prone.

Instead you can force the page to load properties values from some other page. For this just open the Shortcut/External Link tab in edit mode, assign  “Fetch data from page in EPiServer CMS” to Link type , and choose the page the properties are loaded from (f.e. SettingsPage):

image

From this time you can apply to SettingsPage as if they belonged to the w1ef page:

string someProperty = CurrentPage["SomeProperty"] as string;

or:

<EPiServer:Property PropertyName="SomeProperty" runat="server" />

Feb 08, 2011

Comments

Feb 8, 2011 04:18 PM

What if you need both settings and data from another page? I like the PluginProperty approach:

[PlugInProperty(
Description = "PageTypeID: Start Page",
AdminControl = typeof(InputPageType),
AdminControlValue = "PageTypeID")]
public int StartPageTypeID { get; set; }

... and a singelton class to retrieve them.

Feb 8, 2011 05:26 PM

Sure, it's suitable if you want to get data from one page (not more)

Feb 9, 2011 09:46 AM

Sure, it's suitable if you want to get data from one page (not more)

error Please login to comment.
Latest blogs
Finding Thomas Part 3 - The Moment of Recognition

Remember Thomas? In digital landscape, Thomas is the returning visitor who reads everything, opens every email, converts on nothing. In standard...

Ritu Madan | Jun 26, 2026

Add more scheduled job settings from the Optimizely CMS 12 admin UI -- with OptiScheduledJob.ExtraParameters

  Optimizely (EPiServer) CMS 12 ships a great scheduled-jobs framework, but it has one frustrating gap: a job has nowhere to store its own...

Binh Nguyen Thi | Jun 25, 2026

Automated Search & Navigation to Graph Migration with Claude Code

A Claude Code plugin that scans your S&N codebase, applies Graph SDK transformations, and validates the result. Install once, run one command. CMS ...

Connor Fortin | Jun 24, 2026

Migrating from Find to Graph: Lessons Learned from a Real CMS 13 Project

While migrating a search solution from Optimizely Search & Navigation (Find) to Optimizely Graph in CMS 13, I encountered several issues that were...

Binh Nguyen Thi | Jun 24, 2026