These are the steps required to publish content to Doc Books.
DocBook as OLE help - pdf, html, webhelp
- Peri worked with Jeff to add the documents to SVN. See Developing Rice DocBook Documentation
(Kuali OLE followed Rice and is currently using the DocBook 5 format for documentation and the docbkx-maven plugin to generate the documentation as part of our maven build.)
The difference between OLE and Rice documentation is that OLE has decided to use Webhelp output for our documentation whereas Rice uses only HTML. See the plugin documentation here: http://docbkx-tools.sourceforge.net/docbkx-maven-plugin/plugin-info.html. Needed to change the image file references to ../images/filename.png and reference files to ../html/linkname (for html)
Example:<link xlink:href="../html/releaseNotes.html">HTML</link> <link xlink:href="../pdf/releaseNotes.pdf">PDF</link>
For webhelp, when linking FROM the index page (which follows the html format), links appear the same way
<link xlink:href="../webhelp/ADMIN/index.html">Webhelp</link>
However IF you are inserting a link from webhelp back to the index page or to another webhelp space, format is
<link xlink:href="../../../html/Index.html"> <link xlink:href="../../../webhelp/BASICS/index.html">OLE Basic Functionality and Key Concepts</link>
Separated out the chapters into individual xml files and pasted the docbook document type declaration in the chapter element:
<chapter xmlns:xlink="http://www.w3.org/1999/xlink" xmlns="http://docbook.org/ns/docbook" version="5.0" xml:lang="en-US">
- Created an index page
Additional steps for editing and committing documentation
- Needed to complete a CLA (on the Subversion wiki page)
- Needed to complete OWASP training
- Checked out the project via Oxygen (Oxygen is available from iuware for those at IU, may be available through other universities also)
- Tools > SVN client > Repository > host: https://svn.kuali.org/repos/ole > currently, the project is in branches/kole-{current release}-Docbook/src/site/docbook
- Checked out to local computer
- Modify
- Check back in through Tools > SVN client > working copy > Refresh, then right click copy and "commit"
- Once saved but before committing, you can view changes locally through the command line.
- Enter your local OLE directory, once per day run
1. svn update
2. mvn clean install -DskipTests=true
Each time, to test type "mvn clean pre-site -N".
- To view the changes, open Windows Explorer and dig into the correct folder: your local OLE directory > target > site > reference > pdf, html or html-multi.
- Enter your local OLE directory, once per day run
DocBook as built-in help (webhelp)
Peri had to do some modifications to get the webhelp to display correctly. We had to modify images and tables to get them to display correctly. Webhelp pages are now linked with OLE.
See the plugin documentation: http://docbkx-tools.sourceforge.net/docbkx-maven-plugin/plugin-info.html
DocBook Notes
I typically use the GUI (author mode) of oXygen to modify DocBook and I display full tags with attributes when I am editing (so that I do not accidentally put text or tags in the wrong location).
The structure for OLE
docbook folder in trunk contains
- guide folders (one per module)
- chapters for each submenu in OLE
- chapters for Introductions
- chapters for appendixes
- images
- books
- Index
- one book per tab/module (these books contain the links to each chapter)
- overviews are also included
Adding a Book or Article
The simplest way to add a new book or article is to look in the books folder and copy a similar file and change the pertinent information. New books or articles need to be in the books folder to be processed at build time.
Adding a Chapter to a Book
- The simplest way to add a new chapter is to copy a chapter file in an existing book and change the pertinent information.
For example: copy "batchAdministrativeDocuments" in the "admin-guide" folder and make modifications - Add the new chapter file to the top level book file in the books directory.
For example: In the "books" folder, open "ADMIN". Viewing the xml, add an additional "<xi:include xmlns:xi..." statement that includes the new chapter name. Be sure to keep the new chapter in order: for OLE, we are maintaining the documentation to keep in order of the columns within each tab.
Adding Sections
- Sections are added with the <section> tag.
- Sections can be nested within sections.
Each section has a title. The structure is as follows:
<section> <title>Section Level One</title> <section> <title>Section Level Two</title> </section> </section>
- Depending on the level, sections will usually appear in the table of contents.
To prevent a section from appearing in the table of contents, use this construct:
<section role="NotInToc"><title>Do Not Show In TOC</title>
Adding an Image File
- Create the image file and add to the images directory.
Use oXygen to link to the image file and you should be able to navigate to the image file in the GUI and the path will be generated for you. Image paths should be relative, i.e. "../images/image_name.png" and use underscores instead of spaces since they are more web friendly.
Make sure the image is sized properly by building the webhelp and PDF versions and ensuring that they show up ok. Improperly sized images can look pretty bad, especially in the PDF output. Tools like Gimp are free and can be used to do the resizing.
Image files are inserted this ways into docbooks.
<inlinemediaobject><alt>example1</alt><imageobject><imagedata fileref="../images/EDL_Guide/example1.png" width="100%"/>
-OR-
<inlinemediaobject><alt>example1</alt><imageobject><imagedata fileref="../images/EDL_Guide/example1.png"/>
Screenshots are labeled as such:
<para> <screenshot> <mediaobject> <alt>E-Resource Note Tab</alt> <imageobject> <imagedata fileref="../images/eresource-42.png" width="100%"/> </imageobject> </mediaobject> </screenshot> </para>
Again, if they are small enough, do not include the "width="100%"
FYI: The alt tag is added for accessibility. In the webhelp and HTML outputs, the tag will also be displayed in the mouse-over.
Creating Hyperlinks
In DocBook 5, the preference is to have xlinks for hyperlinks. If you use the oXygen GUI (author view) to add the link, you'll need to right-click on the link and add the xlink:href property with the url of your link as the value.
Links to external documents (in a different module) within a release should be entered like this
<link xlink:href="../../../webhelp/BASICS/content/ch02s04.html#_Describe_Workbench>OLE Search Workbench</link>
Note: In the above example, this presumes we have the following anchor within the BASICS books:
<section xml:id="_Describe_Workbench">
Links to internal documents (i.e. another section of the same module/chapter) should be entered as:
<link linkend="_Editors">MARC Editor</link>
where the anchor exists somewhere else in the document:
<section xml:id="_Editors">
To link to a figure, set up the figure to have an xml id as follows:
<figure xml:id="fig1"><title>Service Based Architecture</title>
Then link to it from anywhere within the same book, with the auto generated figure number and given title "My Figure" as follows:
The SOA architecture is depicted in <xref linkend="fig1"></xref>
The above text will be rendered as (something like)
The SOA architecture is depicted in Figure 1.1, "Service Based Architecture".
(except that the figure number may be different depending upon the context, since it is dynamically generated)
Tables
Using "CALS" tables instead of "HTML" tables appears to produce better looking output if you want a table with borders.
Adjust the heading, frame and column data:
<para role="TableHeading"><emphasis role="bold">Location Information tab definition</emphasis></para> <informaltable frame="top"> <tgroup cols="2"> <colspec colname="col1" colnum="1"/> <colspec colname="col2" colnum="2"/>
Make sure that the "rowsep" and the "colsep" both equal 1
<row> <entry colname="col1" colsep="1" rowsep="1" valign="top"> <para role="Table Cells">Title</para> </entry> <entry colname="col2" colsep="1" rowsep="1" valign="top"> <para role="Table Cells">Description</para> </entry> </row>
- Generate and review the PDF and Webhelp output, and make any further adjustments
Lists
There are 4 types of lists available. From Oxygen's GUI, these lists are easily created at the push of an icon - exactly the same way as Microsoft Word. Several examples of the available code are below. Note you can easily add a list within a list.
To create a bulletted list:
<itemizedlist mark="disc" spacing="normal"> <listitem> <para">To add a new vendor ('parent Vendor record')</para> </listitem> <listitem> <para>To create a new division to an existing vendor ('child Vendor record')</para> </listitem> <listitem> <para>To edit information about an existing vendor or division</para> </listitem> </itemizedlist>
To create steps/ a numerical list:
<orderedlist numeration="arabic" spacing="normal"> <listitem> <para>Search for 'In Process' purchase orders using the Order Holding Queue or document search and click the document ID to open it. </para> </listitem> <listitem> <para>Complete the standard tabs as necessary.</para> </listitem> <listitem> <para>Complete the <emphasis role="bold">Vendor</emphasis> and other </emphasis>tabs as necessary. To add information to these sections, click the <emphasis role="bold">amend</emphasis> button at the bottom of the PO.</para> </listitem> <listitem> <para>Click submit</para> </listitem> </orderedlist>
Modifying and keeping current
To continue updating DocBook:
OLE is tagged for a release and the code along with the documentation cannot be updated. However, SMEs continue to work on updates past this point. SMEs are updating via Google Docs. The instructions are listed in Documentation Templates and Guides. Once complete, I make these changes in DocBook.
In the meantime, Rich, Jain and Megan were trained to use Oxygen to update DocBook in November 2013.
Update notes- tasks to do with each release
- review the screens - see what links have been added or removed. Verify they were intended to be removed and not just removed accidentally.
- List out changes and additions that will need to be written/modified. Use OLE Current Release Status Report and note changes when reviewing screens
- Update docbook - menu tab images, menu lists, location of sections. Maintenance documents will remain with their rightful DocBook.
References
- DocBook: The Definitive Guide - clear, concise, normative reference to the DocBook DTD,the official documentation for the DocBook DTD
- docbook.org - main DocBook site
- DocBook XSL: The Complete Guide - definitive guide to DocBook stylesheets
- DocBkx Maven Plugin - reference for the plugin used to generate the DocBook docs, anything usually run as a command line option is set in maven
- DocBook Quick Reference put together by the Ubuntu community
- Developing Rice DocBook Documentation - yes, some of their information was copied to this page. Thank you Rice team for paving the way!