wiki:plugins_editor

Editor plugins

Bootstrap Wrapper pageDeveloper's documentation site

This adds many different bootstrap graphical page elements to the Bootstrap3 template. Not all have been used in this wiki, but here are some examples of those that have been used.

These are the most prevalent, with examples found on nearly every page in the Works section, such as Kingdom of Kaldor. Most are of the default type.

Sample code Output
<button icon="fa fa-file-pdf-o">[[https://www.lythia.com/harnworld/places/kaldoran-hundreds/|  get pdf]]</button>   get pdf
<btn size="xs">[[https://www.lythia.com/|Main website]]</btn> Main website

It is often appealing to use non-breaking spaces (Alt+0160) before the link label to force more space to be rendered between that text and the button's icon. Several icon libraries are available for use here, with the most common being the following:

Several of the default link target settings have been changed in this wiki's configuration, so external and interwiki links will open in a new browser tab.

These are used in the start pages of namespaces under works, such as Chybisa works, to separate the canon works from the fanon. In outline, their use looks like this.

<tabs justified="true">
  * {{mdi>checkbox-marked}} [[#tab-canon|Canon]]
  * {{mdi>fan}} [[#tab-fanon|Fanon]]

<pane id="tab-canon">
       ...
</pane>

<pane id="tab-fanon">
       ...
</pane>
</tabs>

These have been used in plain vanilla style, alone and within other bootstrap3 elements, such as the accordion. They were also used to put a frame around the heading examples in Works vs. world style guide. Basically <panel tags are placed around the enclosed content like so:

<panel>
       ...
</panel>

One accordion has been used in conjunction with panels to tackle the extensive credits in HârnWorld Bestiary. The code is long, but looks something like this.

<accordion>
<panel title="Aquatics #4614">
|  table | of credits |
       ...
</panel>
<panel title="Bats #4633">
       ...
</panel>       
       ...
</accordion>

DataTables plugin page

This plugin makes regular DokuWiki tables sortable and searchable. It's written by the same developer as the bootstrap3 theme, Bootstrap Wrapper, and Advanced plugins, so it works well in that milieu.

In the default case, simply enclose a standard table in <datatables> tags, as follows:

<datatables>
^ Make table ^ As usual ^
| 123        | 456      |
</datatables>

In HârnWiki, this is often used with several options included in the opening tag. For instance, the Kaldor and Atlas Keléstia works pages look like this.

<datatables info="false" paging="false">

The info=“false” option suppresses the “Showing 1 thru X of X entries” message below the table, and the paging=“false” forces all lines to be displayed rather than the first 10 along with buttons to navigate further.

On the Atlas Hârnica works page, another option is in evidence.

<datatables info="false" paging="false" order='[[0, "asc"]]'>

This may not strictly be necessary anymore, since this is merely the default value for the order setting. However—though it's been some time and memory fades—it may have been useful earlier, before all of the pages in that column had been created, to force the proper sorting of present and missing ones.

Other plugins have been considered for this role and may very well be preferable in some instances, should circumstances allow. They are discussed on their own pages, sortablejs plugin and database2 plugin.

Icons plugin page

This, by the same developer as the Bootstrap3 template and Bootstrap Wrapper plugin, allows for the insertion of icons from several icon libraries. Note: there are other ways of placing icons, such as Bootstrap Wrapper buttons having an optional icon setting directly within them.

There are many more options available for formatting icons provided by the plugin, but the use in HârnWiki has thus far followed the KISS principle. At least, it does until the Wrap plugin and CSS get involved.

For the checked box icon denoting canon Works, we use the mdi-checkbox-marked icon from the Material Design Icons library. Note how the icon syntax is just different enough than the name (and also than the Bootstrap Wrapper icon syntax) to keep one on one's toes.

{{mdi>checkbox-marked}}

However, the default size is too big for general use, so the size parameter is employed, after a question mark, to set it to 12 pixels.

{{mdi>checkbox-marked?size=12}}

In some cases, one may wish to use a non-breaking space (Alt+0160) between the icon and the text immediately after to ensure that they stay together.

Several icon libraries are available for use here. These aren't the very latest versions of them, but this is what the plugin provides. Presently, the most commonly used in HârnWiki are the following:

There isn't any focus on a consistent style among the images. Just go with what communicates the idea and looks good.

In HârnWiki icons are used in the right sidebars and navbar of the Works section and in the references there from the Hârn and other “World” sections. They are also used “under the hood” on the pages from which the Works header icons are drawn.

For these roles, there are presently three icons in use, all of which are from MDI.

Use Code Icon
Canon works {{mdi>checkbox-marked?size=12}}
Fanon works {{mdi>fan?size=12}}
Out-of-print works {{mdi>grave-stone?size=12}}

The icon precedes the link to a work's page and shows what type of work it is. Canon works are those produced by Columbia Games, Inc. and Keléstia Productions Ltd., and fanon are those produced by others. Out-of-print works are canon works that are no longer available in that form (though this is sometimes murky when piles of old print persist in the warehouse).

As these icons are usually used in lists, it is not necessary to follow them with a non-breaking space.

The navbar page of the Works namespace uses icons for the dropdown menus in the upper left in order to take up less space than words. Things can get pretty cramped there when the Register and Login buttons are out, and the bar itself can grow and obscure the window if too many wide elements are there.

Use Code Icon
Realm works (from Hârn realms) {{ra>castle-flag?14}}
Other works (from Hârnic Lore works} {{ra>scroll-unfurled?14}}

In this instance, the icons are from the RPG Awesome library, the ra-castle-flag and ra-scroll-unfurled ones, respectively. Also, the size= parameter has not been explicitly included, but just providing a number will implicitly invoke it. I guess the present editor wasn't in the mood that day.

Works heading icons

More visibly, this plugin forms the basis of the icons over the headings of pages in the Works namespace to symbolize each documents contents. That scheme is shown here.

Icons also appear on a page that have nothing to do with this plugin. As mentioned above, many elements from Boostrap Wrapper have their own icon parameters. Also, DokuWiki handles the icons for outside and interwiki links.

Image Map plugin page

This is used to make the map of Hârn work to link pages dedicated to particular Atlas Hârnica maps, such as in Atlas Hârnica Map K5: Kaldor (East). Pages in the Atlas Ivinia and Atlas Keléstia sections use it on their own images as well. Not yet developed but planned are similar uses in the Hârn by map square and Ivinia by map square sections.

This plugin is a bit wonky. Sometimes the desired areas don't align with the image as they should if the image has been resized to fit the page. Usually, refreshing the page in the browser a time or two (or three, or…) will set it right.

It has also been hacked to make the shaded portion under the cursor more visible. Be aware that this will have to be redone upon updating the plugin. See below for details.

First, a raster image is uploaded to the wiki via the Media Manager. An opening {{map>...}} tag links to it. A list follows mapping links to pixel-defined regions within the image. At the end, a closing {{<map}} tag follows the list.

{{map>works:atlas_harnica:harn_image_map_atlas_100.png}}
  * [[works:atlas_harnica:atlas_harn_open_sea   |Atlas Hârnica Map A1: Sea of Itikir                       @32,36,95,97]]

    ...

{{<map}}

In all of the cases in HârnWiki, the same image map has been employed at the bottoms of many similar pages. This heavily favors making one master page for each and using the include plugin to put them everywhere they need to go. Perhaps they're stable now, but making the same change to the list of links on many pages got old fast.

A wiki can never have too many links, so here they are.

The file, /lib/plugins/imagemapping/scripts.js, controls much of the action. Unfortunately, the value given for the opacity of the selected region under the cursor is too low to be readily seen.

  1. /* DOKUWIKI:include_once jquery.imagemapster.js */
  2.  
  3. (function($){
  4.  
  5. $(function(){
  6. $('img[usemap]').mapster({
  7. fillColor: 'ffffff',
  8. fillOpacity: 0.1,
  9. wrapClass: true,
  10. wrapCss: true,
  11. clickNavigate: true
  12. });
  13. });
  14.  
  15. $(window).resize(function(){
  16. $('img[usemap]').each(function() {
  17. $(this).mapster('resize', $(this.offsetParent).width());
  18. });
  19. });
  20.  
  21. })(jQuery);
  22.  
  23. function addBtnActionImagemap(btn, props, edid) {
  24. // Not implemented yet
  25. }

To remedy this, the file was first renamed scripts.js.dist. Trouble arose with it interfering with the replacement file if it was left in place. If the plugin is updated and the original file restored, this may be why the selected area is hard to see again.

The file contents were then copied to a new location at /conf/userscript.js. This was done to protect the change from being overwritten by subsequent updates to the plugin. There is currently no other custom use of javascript in HârnWiki, so the file was created for this purpose and is otherwise clean.

Two modifications were made: the link to jquery.imagemapster.jsat the top was redirected relative to the new file location, and the opacity was boosted to the value desired.

  1. /* DOKUWIKI:include_once ../lib/plugins/imagemapping/jquery.imagemapster.js */
  2.  
  3. (function($){
  4.  
  5. $(function(){
  6. $('img[usemap]').mapster({
  7. fillColor: 'ffffff',
  8. fillOpacity: 0.4,
  9. wrapClass: true,
  10. wrapCss: true,
  11. clickNavigate: true
  12. });
  13. });
  14.  
  15. $(window).resize(function(){
  16. $('img[usemap]').each(function() {
  17. $(this).mapster('resize', $(this.offsetParent).width());
  18. });
  19. });
  20.  
  21. })(jQuery);
  22.  
  23. function addBtnActionImagemap(btn, props, edid) {
  24. // Not implemented yet
  25. }

Include plugin page

This allows the contents of one page to be included in another. It is helpful here to ease the maintenance of sidebars and image maps by allowing changes to be made in one or two places rather than in every page they appear. This can also kludge pages for out-of-print works into other additional namespaces so that they can have the same sidebars, such as Quimen Keep.

One can simply write a page > link to the desired page to include its contents on the current page.

{{page>inclusions:core_works}}

Note that the results will vary depending on settings made on the Administration page. HârnWiki has several departures from plugin defaults with the aim of making the Works header icons entries brief. This means that, with current settings, a plugin-default display can be had with the following:

{{page>inclusions:core_works&header&footer&editbutton}}

Those and other flags may be set when including a page. Here are some that the present editor has found useful.

noheader/showheader

Sometimes it is desirable to show the first header from the included page, and sometimes not. The big difference apparent so far is what happens to the other headings on the page. For instance, this very page has itself been included on Editor plugins like so:

{{page>include_plugin&showheader&editbutton}}

For the positive case, either &header or &showheader may be used.

Note how what is Heading 1 on this standalone page becomes a Heading 2 on that page, and so on down the line. This effect is useful in this case, when a composite page is formed from several also-independent ones. It would not be desirable on a page like Atlas Keléstia IVAE-DX (Tavu), where—in addition to the main heading text being more tailored to one or the other atlas—the “Pages citing this work” heading needs to stay at h2 to match the general style.

noeditbutton/editbutton

This, as in the example above, shows a button allowing the user to edit the included page from the page on which it is included. It is very useful but does sometimes stack oddly with the other section-editing buttons.

The main thing is to remember that this otherwise-shown-by-default setting has been reversed in HârnWiki and that it saves a bit of hassle later to type it in now.

Abbreviated flags also work: &noeditbtn and &editbtn

The present editor doesn't have any use for the generated footer which includes things like the time modified, the user who modified it, etc. It's clutter that mars the invisibility of the inclusion that is often desired. So while this Administrator setting is unlikely to change, one can still include a &nofooter flag for insurance's sake. Indeed, several persist on the pages of the wiki from an earlier time.

inline

This option is used in all of the Works: header icons so that they can all share a line rather than appear running down the page.

{{page>icons:cgi&inline}}
{{page>icons:kaldor&inline}}

Pages included inside Bootstrap Wrapper plugin tab controls utilize this flag as well. This can also be used in a table as a way of placing a multi-paragraph entry in a single cell. I don't think any examples persist in this wiki. Indeed, this section may have been the only one where that was in evidence, long ago.

Move plugin page

Though listed among the Admin plugins, this does have one function open to all editors, that of renaming the current page and updating all links to it. This come in handy when one makes a mistake in naming a page or assigns it to the wrong namespace.

When this plugin is installed, an additional button is visible in the group under the Edit Page button at the right of the page. It looks like a paint roller.

move_button.jpg

Clicking that button opens a dialog where the editor can adjust the page's name.

The plugin is also available on the Administration page, under the “Additional Plugins” heading as “Move pages and namespaces”. Clicking that opens a page where either the current or current namespace can be renamed. Again, this adjusts all of the links elsewhere in the wiki that pointed to the old page(s).

A link there goes to a tree-based, drag-and-drop view of the whole wiki for even more involved reorganization. The current editor just noticed that for the first time while writing this. Huh.

Navigation plugin page

This plugin is used in the wiki sidebar to automate the opening and closing of its link nodes depending on which page the user is currently viewing. Absent this, the sidebar can be populated with lists of links as any page might, but it would either be static for all pages or require a different sidebar page for each namespace to achieve a more dynamic effect.

In HârnWiki, there is one sidebar page for the entire wiki. Its contents are simply two lines.

~~NOCACHE~~
{{navi>navilist?ns}}

The first disables caching to ensure that the page is rendered anew each time for each user. Otherwise, the node configuration from the previous page would persist while viewing the current one.

The second line invokes the plugin and links the page, navilist, for the list of links comprising the sidebar's content. It further uses the ns option to use the namespace(s) of the current page to help inform which nodes should be closed or open.

This navilist page may hold just one standard list of links, though it may be nested to the depths desired to populate different nodes. At the time of this writing, the list begins like this, and one can see how the nested levels correspond to nodes that can open and close on the sidebar.

  * [[https://www.lythia.com|Lýthia.com home]]
  * [[start|HârnWiki welcome]]
  * [[https://www.lythia.com/forum/|HârnForum]]
  * [[harn:]]
    * [[harn:azadmere:]]
      * [[harn:azadmere:azadmere_city]]
      * [[harn:azadmere:habe]]
      * [[harn:azadmere:zerhun]]
    * [[harn:chybisa:]]
      * [[harn:chybisa:burzyn]]

        ...

Links within the wiki work best and others are iffy. This is why the external links to Lýthia.com home and HârnForum are separated by the link to the wiki start page. Otherwise, the first doesn't show up at all.

Previously, there was a text formatting issue when this plugin was used within the Bootstrap3 template. Closed nodes appeared larger and bolder than other items. This was eventually corrected but only for the #dokuwiki__aside element specifically.

In HârnWiki, this plugin is also used in the right sidebar, the #dokuwiki__rightaside, within the credits: namespace. To correct the appearance of those nodes, the CSS fix was copied from /lib/plugins/navi/style.less, modified, and added to /lib/tpl/harnstrap3/css/plugins/navi.css.

nspages plugin page

This generates lists of links based on page namespaces. It used to be in wider use as the wiki was developed, and it works well. However, a different, tag-based approach with the Tag plugin gradually came to be preferred.

The primary advantage of using this (or Tag) to make lists is that they are dynamic. As pages are added to the wiki, items are added to the appropriate lists automatically. This saves having to remember all the places that pages like a new one have been linked and having to add links to them manually. Neither, alas, can be used with the Navigation plugin, however.

Here are a few places where the plugin is still used in the wiki. They serve to illustrate just a few of the options available.

All works in "works" namespace

The plugin is used to create the All works, alphabetized listing. That style of multi-column, labelled listing is produced in this way.

<nspages -h1 -sortId -textPages="" -r  -exclude -exclude:[start navbar rightsidebar by_creation_date publishers:]>

Here is what the different settings do.

-h1 Display the first heading on each page in the list.
-sortId Sort the list by the page names, without namespaces.
-textPages Suppress the list title by making it a blank string, “”.
-r Look recursively through all sub-namespaces of the current one.
-exclude Exclude the current page from the listing.
-exclude:[…] Exclude the pages between the brackets from the listing.

All names in "credits" namespace

The main credits page is similar, but it is sorted by the heading values rather than the page names. The former are written last-name-first while the latter are not.

<nspages -h1 -textPages="" -exclude -exclude:[ambiguous_names some_person c_template a_c d_g h_k l_o p_s t_z]>

Name subgroups in "credits" namespace

The sub-pages of partial names within credits:, like Credits: A thru C, use an additional setting, -pregPagesTitleOn.

<nspages -h1 -textPages="" -exclude -exclude:start -exclude:[ambiguous_names d_g h_k l_o p_s t_z] -pregPagesTitleOn="/^[A-C].*/i">

This returns the pages that satisfy a regular expression. The pattern to be matched is enclosed between two slashes. That pattern, ^[A-C].*, matches page headings that start with “A”, “B”, or “C” and everything that follows. the i at the end makes the matching case-insensitive.

All pages in "inclusions" namespace

This is the simplest one. Not all of these pages in Inclusions even have Heading 1 values written on them, so the unvarnished page names are displayed instead.

<nspages -textPages="" -exclude>

Sub-namespaces of "works" namespace

The use in the "Other series" section on the main works: page differs in many ways. Most obviously, it has a tree, or nested list, layout.

<nspages -subns -noPages -tree -r -h1 -sortID -idAndTitle -exclude:[: core: other: magazines:] -textNS="">

Here is what the differing settings do.

-subns Display namespaces, linking to their start pages.
-noPages Do not display pages that aren't namespace pages as above.
-tree Display listing in the tree style.
-exclude:[…] This time, entries are followed by a colon, indicating namespaces. The colon by itself excludes namespaces without start pages.
-textNX Suppress namespaces title by setting it to a blank string.

Works by creation date

The instance on Works by creation date introduces yet more options, shown and explained below.

<nspages -title -r -exclude -exclude:start -exclude:publishers: -sortByCreationDate -simpleLineBreak -hideNoPages -textPages="" -hideNoSubns>
-title An alias of -h1.
-sortByCreationDate Sort the list by the date on which the page was created.
-simpleLineBreak Display each listing item on its own line without any list structure.
-hideNoPages Hide a header and message if there are no pages.
-hideNoSubns Hide a header and message if there are no sub-namespaces present.

Like a Khuzan bridge in Kaldor from the Codominium, remnants of this plugin's former glory persist in the wiki today. It conditioned the wiki's development and the use of namespaces in its organization. Indeed, with the Tags plugin in use now, one could argue that that organization could be flattened and so simplified.

This has been resisted, however. Mostly, this is due to inertia and the knowledge that, once done, it would be difficult to undo should regrets ensue. Also, some hierarchy is needed to differentiate harn:kaldor:, information on the kingdom, and works:harn:kaldor:kaldor, the kingdom module itself. Besides, namespaces are useful and used within the Tag plugin as well.

It used to be worse, you know. works:fanon: used to be a namespace, and all fanon works had to be in there, branching identically to all the other ramifications of works:. Count your blessings.

Pagelist plugin page

This is required by the Tag plugin. When a user clicks a particular tag, this creates the page containing links to all the other so-tagged pages.

Its options are available from the use of Tag, but the present editor hasn't used them and can't show any examples.

RefNotes plugin page

This is the most recently-added plugin, and its uses are still being explored. The references dictionary upon which it relies has been implemented in the quickest, simplest way, but this may change.

The conventions for its use are still being developed as well. There too, what is presented here is subject to change. The upshot is that this is how works in the works: section of the wiki are cited from the harn: and other “World” sections.

The plugin is invoked with a syntax resembling that of standard DokuWiki footnotes. It looks something like this, taken from the page for Albernet Manor in Kaldor.

“Loral is the second eldest of Clan Ebor. Loral has a younger brother at Iversen. His older brother Minal will likely soon succeed his sickly father as Bailiff of Albernet.”[1]:p.14


The reference is made in this way.

"Loral is the second eldest of Clan Ebor. Loral has a younger brother at Iversen. His older brother Minal will likely soon succeed his sickly father as Bailiff of Albernet."[(:ref:abriel)]<sup>:p.14</sup>

Here we see a quotation from the work, Abriel Abbey in the main body of the page. following it is the relevant reference to the works: page from the dictionary, :ref:abriel, enclosed in brackets and parentheses, [()]. In the vast majority of cases, that reference name is simply :ref: followed by the base page name—without any namespaces—of the works: page.

Following that, since, in this usage, the plugin doesn't provide it, is a manual, superscripted page number following a colon, :p.14. The colon is there and there is no space after the period because reasons. A multi-page reference might look like :pp.14--5, with the two hyphens resolving to a suitable en dash.

Optionally, the location of the generated references can be defined with the ~~REFNOTES ref~~ command. By default, the plugin will put them at the bottom of the page, so this is often not necessary.

----
~~REFNOTES ref~~

A more detailed discussion of what can be done with the syntax can be found here.

Yeah, that's pretty clunky. It may change. Suggestions are welcome.

This is the general idea, however. A quotation, or a paraphrase, or some other datum drawn from a source is written in the main body of a page in the harn: section of the wiki, and a citation is made to a page in the works: section with a footnote linking it. The model in mind is something like Wikipedia, or even a term paper from school.

There is a more sophisticated way of using the plugin that does format page numbers, the Harvard engine. However, this requires that the references dictionary be redone. Doing so may yield other benefits (fingers crossed), but that has not yet been determined.

However, even if that all works, we would still have to abuse the data to get something better-suited to our own needs. The citation style that results is geared toward the papers of academic writing. For HârnWiki, citations such as “(Crossby, N. Robin, 1985)” or “(Mould, Kerry, 2005)” would obfuscate more than they reveal.

Use of this plugin threatens to force the resolution of a thorny issue, that of Composite Works. Many works are sold loose-leaf, and some comprise several separate articles, numbered individually. This allows people to organize their collections as they see fit, and thus Hârnic convention doesn't use a “p.” in a page number at all. Rather, the citation above would be given as “Abriel 14”, including the name of the article. This seems too long for superscript, however, and the name of the work is right there if one hovers the pointer over the reference.

To date, the wiki's handling of composite works is still inconsistent. Referring to them with this plugin means that even more composite works ought to be divided into their constituent articles with separate pages for each. In this way, “Pilot” p. 1 can be cited more readily than Pilot's Almanac p., um, 7? 5? 1?

Luckily, the several “World” sections of the wiki are slow-filling, so that resolution gets deferred. Hopefully, that will be done as the present editor's grand scheme to create a database from all the Hârn data and create all the pages in an automated fashion therefrom comes to fruition.

The References dictionary is currently the simplest implementation, a big, two-column table of reference names and text on one page. It was readily-enough generated by running a Python script ( zip download) on a local, offline copy of the wiki. The present editor does not recall if some additional, hand-done editing of it was still required or if that was solved programmatically, but there wasn't much needed.

This is not a very clean process for a live wiki, however. Subsequent additions to the works: section then need corresponding edits to this table. This isn't hard, but it's another thing to remember.

There are other ways of doing this. The most involved is maintaining a collection of pages for each reference that each contain a structured data element. This would (probably? maybe?) require one or the other of the Structured Data plugin or Struct plugin be employed.

This seems like even more work, but then we already have a namespace full of individual pages for each reference. It could be that the works: section itself could be made to serve this purpose as well as what it presently does. The advantage would be that it's much more natural to then include the necessary data while adding a new page. More work needs to be done to explore this possibility before anything more can be said.

Tag plugin page

This is a way of grouping pages along several different relationships and then generating lists of those related pages. For instance, Kiban Castle, is tagged with its publisher, region, realm, as a castle, and under its own name.

This provides two useful features. The wiki user can click on any of those tags to see pages listing other works by Columbia Games, Inc., others set in Hârn and in Kaldor, other castles, and—since a few other works detail additional information in and around the place—more about Kiban itself.

The second use is on the page collecting all works pertaining to Kaldor, and other pages like it. Each section of that page has a list, or “topic”, generated by the plugin that groups pages with the appropriate combination of tags. New pages added to the wiki then appear in all the correct lists automatically without further maintenance from editors.

That latter function is similar to what the nspages plugin can do but comes at it from a different angle. It can be used within or without namespaces as needed.

Those two uses look like this.

Tagging pages

When a new page is created in the works: section, a page template will provide the start of a line of tags just under the page heading that looks like this.

{{tag>cgi ldc works:some_tag}} FIXME

This is edited as needed. The first two are different publishers, Columbia Games and Lýthia Dot Com. One of those should be removed, both if a different tag—like kpl for Keléstia Productions Ltd.—is needed instead.

The next tag, works:some_tag, shows the general form of tags in this section. The works: part is the tag namespace used for all tags about pages in the works: page namespace. Those are two different kinds of namespaces. The tags one doesn't have any sub-namespaces like the pages one does.

That namespace is added for works: pages to allow for different tags to be usable in the Hârn and other “World” sections of the wiki. However, it has not yet been determined just how those will be set up. It is enough for now to ensure that page lists of works:kaldor tags won't have pages with kaldor tags mixed in.

The FIXME just prints a reminder to editors that there is something to be edited here. It should be removed when the line is adjusted to look something along the lines of Kiban's:

{{tag>cgi works:harn works:kaldor works:castle works:kiban}}

Listing tagged pages

The other aspect is generating the lists with topic statements. The Kaldor works page is probably a bad example, since the sheer mass of materials led to finer distinctions made there than elsewhere. But we'll run with it.

On the Canon tab of the page, the principal works are those regarding the kingdom, or “realm”, itself and the holds within. These are made with two different topic statements in order to place the big ones at the top.

===== Realm and holds canon =====
{{topic>.?works:realm works:overview works:city +cgi&simplelist}}
{{topic>.?cgi kpl -works:realm -works:overview -works:city -works:location -works:harnic_lore&simplelist}}

They start with the enclosing brackets and topic>. The next part, .? constrains the search to the current page namespace, in this case works:harn:kaldor:. It can be omitted in order to search everywhere.

Following that is a list of the tags for the pages desired. In the first topic, the block of works:realm works:overview works:city gets pages with any one (or more) of those tags. The last tag, cgi, is preceded by a plus sign which works as a logical and. So pages with cgi works:realm or cgi works:overview or cgi works:city are returned.

The last term, &simplelist tells the plugin how to style the output. The present editor has found that it needs to come immediately after the last tag without a space in order to work.

For the second topic, the logic is reversed. The two canon publishers, cgi and kpl form the or grouping. then, the tags from the first topic are excluded with a minus sign, -, so they don't appear in both lists. Next come two other tags that we wish to list separately elsewhere on the page.

There aren't any ways to group logical blocks, as with parentheses, so some trial and error is required find just what works. It is going to be a headache in that first topic should Keléstia get into the Kaldor business. Their tag isn't strictly needed in the second—yet—but is included for future-proofing.

Further down the Canon tab are the sections of related works. They each search within the appropriate page namespace, so instead of leading with .?, they have works:adventures? and the like.

===== Related canon =====

==== Adventures canon ====
{{topic>works:adventures?cgi kpl -works:adventure_seed +works:kaldor&simplelist}}

==== Atlas Hârnica canon ====
{{topic>works:atlas_harnica?cgi kpl +works:kaldor&simplelist}}

==== Religion canon ====
{{topic>works:religion?cgi kpl +works:kaldor&simplelist}}

==== Wilderness canon ====
{{topic>works:wilderness?cgi kpl +works:kaldor -works:trade&simplelist}}

=== Trade Routes canon ===
{{topic>works:wilderness?cgi kpl +works:kaldor +works:trade&simplelist}}

On the Fanon tab, the logic works a little differently. The General Fanon topic is works:kaldor and a whole lot of not, including both canon publishers.

===== General fanon =====
{{topic>.?works:kaldor -works:series -works:tashal -works:city -works:castle -works:keep -works:manor -works:abbey -works:ruin -works:location -works:map -works:data -works:kaldor_port -works:succession -cgi -kpl&simplelist}}

Rather than a topic for all fanon holds, Kaldor has one for the major settlements and lists the minor ones elsewhere.

===== Castles & keeps fanon =====
{{topic>.?works:castle works:keep -works:map -works:location -cgi -kpl&simplelist}}

In other realms, there are usually, works:city works:manor works:abbey joining the big or with the castles and keeps.

Maps and locations are generally given under their own headings. There is material extant about locations in Kiban, which is why that tag was created.

===== Locations fanon =====

    ...

=== Kiban ===
{{topic>works:kiban +works:location -cgi -kpl&simplelist}}

Frankly, the tags have proliferated over time like weeds and the reasoning behind them may have drifted. A listing of every tag present in the wiki can be found here, and the number of them makes the search capability there a bit unwieldy.

Still, there should be some guidance regarding which tags to use where. Someone should get on that. tag_conventions

One plugin, Pagelist, is required for Tag to work. This actually forms the pages of lists to which each tag links. Some of its flags can be used from within Tag.

The SearchIndex Manager plugin is an Admin utility that isn't required but can come in handy. If, for instance, several wiki pages are moved around in one mass action, the index upon which Tag relies can lag behind those changes. This can rebuild the index from the current state of the wiki.

TemplatePageName plugin page

This plugin is a convenience to make new page templates easier to edit. Otherwise, changes to files in the data pages directory named _template or __template can only be made by those with access to the backend wiki files on the web server.

To use the plugin, simply create a wiki page as normal, including namespace template syntax. Pages named c_template are then applied to all new pages created in that namespace. Pages named i_template are also applied to new pages in sub-namespaces of the current one if no overriding c_template is present.

Wrap plugin page

This allows all manner of customized formatting of page elements. On the editor's end, one may enclose block-type page content within <WRAP class[ another-class etc]>…</WRAP> markup tags. That refers to things that, in the page's underlying HTML code, might be formatted in <div>, <p>, or suchlike elements. One can also format inline <span>-type elements as <wrap class[ another-class etc]>…</wrap> in lowercase.

The limiting factor is that those classes must already be present in the wiki's CSS stack. This is usually out of the hands of editors, and even wiki admins may not necessarily have access to the wiki's backend files. Editors and wiki admins must work together with site admins to put the desired code in place to be used.

Once that is done, formatting can be handled just as in any other HTML/CSS interaction. The difference is that editors can then start inserting those classes at will.

The basic use has already been described above: wrap page content in <WRAP> or <wrap> tags.

Uses specific to HârnWiki include the heading styles in the works: and “World” sections. More about the page text, the CSS, and the wiki settings in the latter case can be found here.

The plugin's own page of built-in use examples can be seen here. This reveals a few problems as that page is rendered into the current wiki template's style. The plugin looks up default DokuWiki colors, but the Bootstrap3 template uses colors according to the Bootswatch theme in use. This makes for many mismatches.

A few other classes have been taken from the DokuWiki site and included. Notably, these include alternate ways of effecting multiple columns.

The HârnWiki classes available to editors at the time of this writing is here.

Since the Bootstrap Wrapper plugin is also installed, many of the built-in wrap effects may be better implemented with that instead of wrap. Certainly, things that rely on the theme colors are more simply done that way. On the other hand, elements that are often repeated may just be easier to have wrap styles developed for them.

A cogitation on blockquotes in light of this can be found here.

  • wiki/plugins_editor.txt
  • Last modified: 2023/02/18 06:44
  • by suedunham