Skip to main content

Filtering / Profiling

Abstract

Learn how to use filtering, also known as profiling, to control which content is included in your outputs. Find out what you can filter and how the filtering works.

Filtering is also known as "profiling" or "conditional content" and you can use it to include or exclude content depending on certain conditions. For example, you can set a topic to be included in your publication if the intended audience is beginners, but excluded if the audience is experts.

You can use filtering to include or exclude:

  • Entire topics in a publication

  • Elements in a topic, such as paragraphs, procedures, or steps in a list.

Filtering gives you more control over your content and can also give you more opportunities for your topics. Let's say that you have a topic that could be reused, if only it did not contain a particular paragraph. By filtering that paragraph, you can make the topic suitable for reuse, as you can include or exclude the paragraph when needed.

Paligo has several different types of filtering, but to begin with, we recommend you learn about "regular" filtering.

The workflow for "regular" filtering is:

  1. You mark up the content that you want to filter. This tells Paligo what content can be filtered, and what conditions apply.

    To set the conditions, you choose a type of filtering to apply and you set a filter value.

    Paligo does not have one generic filter for everything. Instead, it has a range of filter types, called filter attributes. There are different filter attributes for filtering by product name, by audience, by country, and by market, among others.

    For example, to filter a paragraph so that it only appears in a user guide for a Windows version of a product, you could set a filter attribute of os (operating system) and a filter value of Windows.

    os-windows-section.jpg
  2. You set the filters you want Paligo to apply to the published output.

    profiling-attr-windows.jpg
  3. Paligo then:

    • Includes all of the content that does not use the filters attributes you chose for publishing.

    • Searches through your content to find any elements that have the filter attribute(s) that you set for the publication. For example, if you set an os filter attribute in the publication, Paligo will find all of the elements that are marked up to have an os filter attribute. These are the "matching" elements.

    • Searches through the "matching" elements to check the filter values. Those with the same value that you set for the publication are included in the published output. Those that have different values are excluded.

      Tip

      If you want to exclude content, create filter values for the conditions where it should be included and also for where it should be excluded. For examples, see Mark Up Elements for Filtering and Mark Up Topics for Filtering.

Note

The process for setting up filtering is different for scoped filtering, taxonomy filtering, and filtering by language.

There are several ways of applying filters to your content in Paligo. They all involve marking up your content for filtering and then setting filters on the publication. But the process for doing this is different depending on which method of filtering you choose to use.

The two main types of filtering are:

  • "Regular" filtering, where you edit a topic and apply a filter attribute and filter value to one or more elements. You can use "regular" filtering for filtering entire topics or individual elements in a topic.

    To get started with "regular" filtering, see:

    Filter Topics in a Publication

    Filter Block Elements in a Topic

  • Taxonomy filtering, where you set up taxonomy tags to represent the filter attributes and values, and you drag and drop them on to your topics. You can also set Paligo to use the taxonomy hierarchy for more complex filters, where Paligo uses the taxonomy hierarchy to determine which topics to include or exclude.

    See taxonomy filtering for more details.

There is also scoped filtering. This is for when you want to use the same content in the same publication, but apply different filters depending on where the content appears.

You can use a mix of the different filtering types, if needed.

When you set a filter in Paligo, there are many different types of filter you can use. Some are defined by the DocBook standard and some are custom filters that we have created for Paligo.

The following table shows the filters you can use:

Filter attribute

Source

Description

arch

DocBook

Filter by computer or chip architecture.

audience

DocBook

Filter the content based on the intended users, for example, internal staff or customers. You could use audience for the knowledge level too, such as beginner or expert. But there is a userlevel attribute specifically for that, so can use audience or userlevel, but it is important to be consistent.

condition

DocBook

This is a general purpose filter attribute. Use this filter if the other filters do not meet your requirements.

conformance

DocBook

Filter by conformance standards.

os

DocBook

Filter by operating system, for example, Windows.

revision

DocBook

Filter by publication revision, for example, v.3.1.

security

DocBook

Filter by security level, for example, Low.

userlevel

DocBook

Filter by knowledge level of the intended audience, for example, expert.

vendor

DocBook

Filter by product provider, such as a manufacturer or seller.

outputformat

DocBook

Filter by the type of output, for example PDF.

xinfo:product

Paligo

Filter by product name or model.

xinfo:country

Paligo

Filter by the country that the documentation is designed for, for example, USA.

xinfo:market

Paligo

This is similar to xinfo:country except that it is less geographically rigid, for example, you can filter for the Asia market or the North America market.

xinfo:version

Paligo

Filter by version. You can use this in combination with the version management features of Paligo, but this is not a requirement. The usage is up to you.

xinfo:proglang

Paligo

Filter by programming language or to publish to API style "on-the-fly" filtering HTML5.

Note

Paligo does not support using xinfo:proglang on table rows.

xml:lang

DocBook

Filter by natural language, for example, filter Swedish content. This filter attribute is a special case, as there is a different process for using language filters. To find out more, see Filter by Language.

To find out how to use filters in your content, see Filter Block Elements in a Topic , Filter Topics in a Publication, and Filter by Language.

Scoped filtering is a powerful feature in Paligo that allows you even more flexibility when it comes to profiling/filtering content. It is designed for when you want to:

  • Use the same content in multiple places in the same publication

    and

  • Apply different filters to that content, depending on where it appears in the publication.

Note

Scoped filtering is an advanced topic. Make sure you understand the basic profiling/filtering concepts before using scoped filtering.

To show you how scoped filtering can be used, we'll guide you through an example.

Example 1. Scoped filtering for applying different filters to reused content

Let's say you are documenting a product , for example, a fictional video conference software called ACME VCT. The software supports MacOS and Windows, and as most of the documentation is the same for both versions, you want to create a single user guide rather than two separate versions. The user guide will have a MacOS section and a Windows section.

In Paligo, you create the content and organize it in a publication structure like this:

overall-structure-scoped-filtering.png

You have a "chapter" for Windows content, called "Installing on Windows", and you have "Installing on MacOS" as a chapter about MacOS.

You have also reused two topics. The "Prerequisites" topic and the "System Requirements" topic are both used in the Windows and MacOS chapters. For this example, we will focus on the "System Requirements" topic.

In the "System Requirements" topic, you have some information that is for Windows only, and some that is for MacOS only.

A screenshot of a section of a Paligo topic in HTML5 output. There is an image and then an "Operating System Version" subsection and a "Supported Browsers" subsection. In each subsection is some content only relevant to Windows, and this is marked with a callout number (2). There is also some content only for Mac OS and this is marked with a callout number (1).

In the image above:

  1. This is for content that is only relevant to MacOS. You apply an os filter to this content and set the filter value to macos.

  2. This is content that is only relevant to Windows. You apply an os filter to this content and set the filter value to windows.

If you published the content as it is, you would only be able to set the os filter to be either Windows only, MacOS only, or include Windows and MacOS.

This is where scoped filtering comes in. You can use it to tell Paligo to use an os:windows filter in some places, but an os:macos filter in others.

To set the scoped filtering, set a "scope filter" on the section element of a topic that is at a higher level than the topic you want to filter. In this scenario, the higher level topic is called a "parent" and the lower level topic is called a "child".

Note that the "scope filter" is not a type of filter, it is the term we use to describe the filter that is set on the "parent" topic.

The structure view of a publication. It has an Installing on MacOS top level topic with a Prerequisites subtopic and a System Requirements subtopic. There is also an Installing on Windows top-level topic which also has Prerequisites and System Requirements subtopics. The Installing on Mac OS topic has a callout with number 1 on it. The Installing on Windows topic has a callout with number 2 on it.

In this example, there are two "scope filters" to set (1 and 2 on the image above):

  1. Set the "scope filter" for the Windows chapter on the section element of the "Installing on Windows" topic. The "scope filter" is the os filter with the value: windows.

    os-windows-section.jpg

    With this "scope filter" you are telling Paligo that if any "child" topics in this chapter contain os filters, Paligo should include any that have the value: windows. But it should exclude any that have different values.

  2. Set the "scope filter" for the MacOS chapter on the section element of the "Installing on MacOS" topic. The scope filter is the os filter with the value: macos.

    os-filter-mac.jpg

    This "scope filter" tells Paligo that if any "child" topics in this chapter contain os filters, Paligo can include any that have the value: macos. But it should exclude any that have different values.

You now have your content marked up for scoped filtering. The final step is to set the filter and values when you publish.

You publish your content and you edit the Profiling attributes on the Publish document dialog. You choose to include the os filter. Importantly, for scoped filtering, you include all of the os values that need to appear in the published output. In this case, you want the Windows filtered content to appear in one chapter and the MacOS content to appear in another chapter, so you include both values.

publish-scoped-filter.png

The published output will now have reused the same topic "System Requirements" in two parts of the documentation, but it will appear differently in the Windows and MacOS sections respectively, even though it is in the same output:

Windows version

MacOS version

windows-scope.png
macos-scope.png

From the example, you can see that the important principles of scoped filtering are:

  • Scoped filtering applies to content that is reused in the same publication.

  • With scoped filtering you can reuse topics and set them to use different filter values, depending on where the topic is positioned in the publication structure.

  • You tell Paligo which filter values a "child" topic should use by setting a "scope filter" on the "parent" topic

  • When you publish, you set the filters and include all of the values that you want to use in the publication.

When you have read the example and understand the principles of scoped filtering, you can apply it to your own content. The workflow you should follow is:

  1. Make sure scoped filtering is enabled. It is enabled by default, but it may have been disabled on your Paligo instance.

    Select Layout and then edit the layout that you are going to use. Make sure the Enable scoped profiling/filtering option is set to Enabled or Default. You can find the option in the Classes and Attributes settings on HTML layouts and in the General > Filtering and taxonomies settings for PDF.

  2. Organize your publication structure so that you have "parent" topics (high level) and "child" topics (lower level).

  3. Apply filters to your "child" topic elements.

  4. Apply the "scope filters" on "parent" topic elements. Typically, you should set the scope filters on the section element.

  5. Publish your content and include the filter attributes that are set on the "scope filters" and all of the filter values that should be used.

When you mark up your content for filtering, you can use the preview feature to see the effects of the filters. This is a good way of making sure that the filters work as expected, and is especially useful if you have used a combination of filters.

To preview the filters:

  1. Find the topic that contains the filters in the Content Manager, and open it in the editor.

  2. Select Preview > Profile settings.

  3. Select Profiling.

    profile-settings-blank.png
  4. For each filter attribute, select the field and choose the filter you want to apply for the preview. If you do not want to apply a particular filter, leave its field blank.

    profile-settings-values.png
  5. Select Apply.

    The filter is applied to the preview of the topic:

    • Any content that is not marked up to use the types of filter you have applied is included in the content.

    • Any content that is marked up to use the filters you have applied, with the same values you have set, is included in the content.

    • Any content that is marked up to use the filters you have applied, but with different values, is excluded.

    For example, if you set the preview to show the Market filter attribute with a value of Europe, the topic would show:

    • Any content that is not marked up to use the Market filter attribute

    • Any content that is marked up to use the Market filter attribute and a value of Europe

    The preview would exclude any content that has the Market filter attribute and any other value, such as Asia, North America, Australasia, etc.

  6. Repeat steps 4 and 5 to change the filters for the preview and see how they affect the content.

To stop applying the filter preview, display the Profile settings dialog select the Profiling tab, and then select Reset.

You can use the xml:lang attribute to filter content by (natural) language for HTML and PDF outputs. This means you can mark an element as being appropriate for a language, and the element will only be included if the content is published to that language. If you publish to different languages, the element is excluded.

The xml:lang attribute works a little differently to the other filter attributes. Firstly, to use it, you need to enable the feature on the layout that you will use for publishing. Then you can add it to elements that you want to filter, and finally, you publish and choose what languages to publish to. Paligo applies the language filters automatically, based on what languages you are publishing to.

  1. Select Layout and edit the layout you are going to use for publishing.

  2. Enable the Use xml:lang as profiling attribute setting. This is in the Classes and Attributes settings for HTML layouts and in the General > Filtering and Taxonomies section for PDF layouts.

    xml-lang-layout-editor.png
  3. In your content, select an element that you want to filter by language.

  4. Use the Element attributes section to add the xml:lang filter attribute and set its value to the appropriate language. For the language values, use the two letter language codes, for example, en for English, sv for Swedish.

    Important

    Use the two letter codes shown in the Languages section (see step 6). Only these two letter codes are supported. You cannot use alternative language codes.

    xml-lang-attribute-value.png
  5. Repeat steps 3 and 4 for other any other elements you want to filter by language.

  6. Publish your content and choose the layout you edited in step 1 and the language(s) that you want to publish to:

    filter-by-language-language-selection.png

    If you publish to a language that matches the value of the xml:lang filtered content, that content is included in the output.

    If you publish to a language that does not match the value of the xml:lang filtered content, that content is excluded from the output.

  7. Set any variables and other profiles as required, and then publish.

You can use the phrase element to apply filters to inline content. This is useful when you need to filter part of a block element, for example, if you wanted to filter one sentence in a paragraph rather than the entire paragraph.

To filter inline content:

  1. Select the content you want to filter.

    highlight-inline-text.jpg
  2. To display the element context menu, press Alt and Enter (Windows) or Option ⌥ and Enter (Mac).

  3. Add the phrase element.

    Paligo inserts your selected content into the phrase element.

  4. Click in your selected content so that the phrase element is shown in the Element Structure Menu.

    phrase-added.jpg
  5. In the Element attributes section, add the filter condition that you want to apply to the phrase. This works in the same way as filtering any other element, for example, you could set an xinfo:country attribute if you wanted to be able to include/exclude the phrase based on the country.

    phrase-filter-by-country.jpg

    To find out about filter types, see Filter Attributes.

  6. Set the value for the filter and apply it to your phrase element.

    To find out about filter values, see Filter Block Elements in a Topic.

  7. Select Save.

When you publish, you can choose which filters to apply to your content. As the inline content is now wrapped in a phrase element, it can be filtered in the same way as any other element. The settings you choose when you publish will determine whether the phrase is included or excluded from the published content.