stut-it Martin Stut - Information Technology Tailored to You
By Martin Stut, 2014-12-16
Update 2014-12-19: I have moved all code and documentation to https://github.com/martinstut/instruction-folding .
When you are writing technical instructions for a non-technical audience, e.g. about setting up an email client, addressing a group of entrepreneurs, you are in a dilemma:
If you write up all the details, the text gets too long. If you just write the key items, you're omitting required details for some trouble cases.
A solution to this dilemma is text folding: by default, display only the key items, but offer the reader a link or button "show details" which, when clicked, reveals additional information.
Many instruction pages are offered to an audience having somewhat different environments, for instance
Accomodating for all existing alternatives increases the size of the document (often doubling it), causes complex grammar and confuses readers about whether they should do A or B, just because they have a hard time (or no time, in case of fast reading) to decode whether "if this, but not that, except when having chosen option N" does or does not apply to them.
A solution is again text folding: offer a set of links or buttons corresponding to options, like "click this if you have Windows 7, click that if you have Windows 8." Of course the currently active option needs to be highlighted to indicate the fact that it is active.
In current web technology we have standardized JavaScript logic and DOM (Document Object Model) structure to selectively show or hide portions of text in web pages. But somehow the browser needs to know what to show and what to hide, so there needs to be some markup.
Nowadays many web authors need to edit HTML inside Content Management Systems, so the markup needs to be compatible with a restricted subset of HTML. Adding some SPANs or DIVs might be the most one can do.
A possible solution to this are class names. Every HTML node can be member of zero or more classes, using code like
<ol class="class1 class2 class3">...</ol>
This is what I've implemented. You can look at an example onĀ http://martinstut.github.io/instruction-folding/testtext.html .
Here is what you need to do to use this code:
Insert this line anywhere in the HTML file, preferably in the head section or at the end of the body section:
The JavaScript code implements a variable-value model to specify which sections should be shown or not. A section is shown if
If you want to show a section only if variable var has value val, then assign it the class if-var-val .
If you want to show a section if variable var has either value val1 or value val2, then assign it to multiple classes if-var-val1 if-var-val2 . You can also use more than two classes.
Variable names and values must not contain dashes, if-windows-version-windows-8 is doubly non-functional (variable name contains a dash, value contains a dash). Any character permissible in a class name is acceptable, but for clarity, you should restrict yourself to lower case letters and digits.
This text will be displayed for Windows Vista or Windows 7, but will be hidden for Windows 8.
To set variable var to value val, the user needs to click on an HTML node having the set-var-val class. This will add onclick code to this HTML node.
After clicking on a setter node, the clicked node will additionally be assigned to the setter-active class. This can be used as a CSS selector to highlight the currently active value.
It you want a certain setter to contain the default value that's effective before any setter is clicked, assign it to the class var-default . This will act as if this setter is being clicked right after the page is loaded.
Select your computer's operating system: Windows Vista Windows 7 Windows 8
This offers a choice of Windows Vista, 7 and 8, with Windows 7 being the default.
The setter class has no influence on the hiding logic, but is useful as a CSS selector to highlight areas that can be clicked on. It could have any other name.
IMO the "show/hide explanation" use case requires too much HTML code. It should be easier than now for the author to write such cases.