Version 4.5 by Clément Desableau on 2023/06/21

Show last authors
1 There might be cases where you want to display a Wiki Macro parameter as a select picker. However, for this you will need a Java Enum defined in the wiki that will correspond to the possible values your parameter can take. The easiest way to have that (for now) is to create a Java Enum and bundle it as a jar dependency of your project.
2
3 Here is, for example, how to implement a custom {{{ Ascending }}} / {{{ Descending }}} select picker for a sort order parameter.
4
5 == Step 1: Java enum ==
6
7 Write your custom java enum:
8
9 {{code language="java"}}
10 package your.enum.package;
11
12 public enum SortOrderEnum
13 {
14 asc,
15 desc;
16 }
17 {{/code}}
18
19 {{info}}
20 The values you choose for your enum will correspond to the values saved for your parameter. They are the one that will end up being editable from the wiki editor, so you might prefer using camelCase values instead of ALL_CAPS.
21 {{/info}}
22
23 Then bundle it as a jar, and import it in your instance (by manually placing it in the {{{ WEB-INF/lib }}} directory, or using the extension manager).
24
25 == Step 2: Wiki Macro parameter type ==
26
27 Simply set your parameter type to {{{ your.enum.package.SortOrderEnum }}} in the Wiki Macro page.
28
29 == Step 3: Translations ==
30
31 For now, values are being displayed as is. To display a custom title for each value, you'll have to setup translation keys.
32 Create a page with a {{{ XWiki.TranslationDocumentClass }}} object, where translation keys are your enum full name concatenated with the enum value:
33
34 {{code language="plain"}}
35 your.enum.package.SortOrderEnum.asc=Ascending
36 your.enum.package.SortOrderEnum.desc=Descending
37 {{/code}}

Get Connected