Dynamic content

What is dynamic content?

Several user assistance components allow you to provide dynamic content. This means the content can change depending on the user's environment or context. For example, you may want a section of your help document or welcome page to only appear if the user has a certain functionality enabled.

There are two basic ways to create dynamic content. One is to add tags and attributes (annotations) to your XML markup instructing the system to filter out sections or documents, include sections from other documents, or extend documents by contributing into anchors or replacing elements.

The other method is to write your own content producer by plugging in some Java code that will write the content from scratch or process existing static documents on-the-fly. Let's examine both approaches.

XML Annotations

The simplest way to create dynamic content is to use the XML markup annotations. You simply add some special attributes and tags to your XML markup and the system will process the instructions. You can use this markup to:

To learn more about each aspect of the markup, follow the links above or find the topics in the table of contents.

This is demonstrated in the XHTML fragment shown below:


<p>
This is a static paragraph.
</p>

<!-- This tag will be replaced with the referenced tag -->
<include path="my.plugin.id/path/my_other_document.xhtml/element_id"/>

<ul>
   <li>
      This is a static list item.
   </li>
   <li>
      This only shows when running on Windows and plugin com.myplugin is not installed.
      <enablement>
         <systemTest property="osgi.os" value="win32"/>
         <not>
            <with variable="platform">
               <test property="org.eclipse.core.runtime.isBundleInstalled" args="com.myplugin"/>
            </with>
         </not>
      </enablement>
   </li>
</ul>

<!-- An element with an id that can be replaced by another element -->
<p id="my.paragraph">
   This paragraph can be replaced because it has an id.
</p>

<!-- A place where others can add content -->
<anchor id="my.anchor.id"/>

Content producers

A content producer is a mechanism for plugging-in Java code to produce the document content on-the-fly. Content producers are more powerful than XML annotations, but are more complex to use.

Content producers are supported in the following areas of user assistance: