Structdata Action Documentation
Not Included in official Wikka versionSee also:
Development: StructDataActionDocumentation
Short description
Enables to embed structured (or "semantically tagged", somehow like a database) data items in a page. You can then:- use a specific visual rendering (including microformats) to format and display only key informations of each data item
- call predefined requests (a la SQL) to select and process data items across all wiki pages
This is by essence not a turnkey tool, as you have to define your data items and the requests to be performed upon them.
Two examples are provided :
- a "To Do" list
- a contact card
Parameters
Parameters shall be of either of two (exclusive) types:- either a pair (type, data), if you want to define a data item
name | type | required? | default | description |
---|---|---|---|---|
type | string | required | The data item type. Predefined types are ToDo and Card (see explanation in the 'Long description' paragraph below) | |
data | string | required | field1='value1' field2='value2' etc. Optionality and allowed values depend on value of the 'type' parameter | |
string | optional | The display mode for the data item. Predefined types are false (no display), basic (inline of the type name), table (one-row table with one column per field) and list (table with one row per field) |
- or req with context-dependent p1, p2 and p3, if you want to perform a request
name | type | required? | default | description |
---|---|---|---|---|
req | string | required | The request id. Predefined generic types are ItemTable, ToDos and Cards (see explanation in the 'Long description' paragraph below) | |
p1 | string | optional | The request's first parameter.Typically used to filter or sort, but actual semantics are request-specific | |
p2 | string | optional | The request's second parameter.Typically used to filter or sort, but actual semantics are request-specific | |
p3 | string | optional | The request's third parameter.Typically used to filter or sort, but actual semantics are request-specific | |
help | string | optional | If this parameter is present, a one line description of the request and its parameters is displayed |
Notes:
- If you pass both a type and a req parameter, the req parameter will be ignored
Long description
Didn't you ever think: "these wikis are great, but if only I had a way to tag a chunk of page as containing the data for a contact card, a customer call or a calendar entry, in order to perform some database-style request on these data items?"Well, here is a solution. With the Structdata action you can do four things:
- embed in any page a "structured data item" which is defined by a type (e.g. a To-Do list entry) and a list of parameters (or fields, in the database terminology). Note that fields are not typed;
- validate the list of parameters. You can:
- check for the presence of a mandatory parameter; and
- perform any data validation desired.
An error message will indicate failure to validate a given data item. Note that this requires you to provide the corresponding code.
- control the visual rendering of each data item. You can choose:
- to make it invisible; or
- to display it as a list, a table or an inline text by using predefined display modes; or
- to display it as a microformat, where applicable
- to display it in any custom way you may provide code for.
- perform any selection, processing and aggregation request you wish (example: display all the open To-Do list entries with priority levels of 1 or 2). Of course, here again you have to provide some code.
Usage
{{structdata (type="datatype" data="fieldslist" [print="printmode"] | req="reqname" [p1="val1"][p2="val2"][p3="val3"] [help]) }}
Examples
Example 1: To-Do list structured data item
Definition of two To-Do list items. The second one will not be displayed{{structdata type="ToDo" print="table" data="date_open='2006-10-3' owner='jdoe' status='open' date_due='2007/11/13' desc='Complete logo design'"}}
{{structdata type="ToDo" print="false" data=" owner='kbill' status='open' desc='Book flight to Lake Tahoe' priority='2' date_open='2006-10-4' date_due='2006-12-2' "}}
Comments:
- four fields are mandatory: owner, desc (description of the task), date_open and date_due. Dates shall follow the 'yyyy-mm-dd' format.
- date existence check is performed for date_open and date_due.
- no specific visual rendering has been defined. print='table' usually gives good results:
date_open | owner | status | date_due | desc |
---|---|---|---|---|
2006-10-3 | jdoe | open | 2007/11/13 | Complete logo design |
Predefined requests
A request called ToDos is predefined. It displays all To-Do list items in a table, sorted in reverse order of date_open. If parameter p1 is present, only data items whose owner equals p1 are selected. If parameter p2 is present, only data items whose status is equal to p2 are selected. With the two To-do list items defined above, {{structdata req="ToDos"}} would display the following:
owner | description | due date | page link |
---|---|---|---|
kbill | Book flight to Lake Tahoe | 2006-12-2 | StructDataActionInfo |
jdoe | Complete logo design | 2007/11/13 | StructDataActionInfo |
Example 2: Contact card structured data item
Definition of a contact card{{structdata type="Card" data="n='DOE;John' email='jdoe@his_organization.org' fax='(123) 654-898' tel='(+41) 123 4567' org='His_org'"}}
Comments:
Sample stylesheet for hCard microformat rendering
This stylesheet will render the example card as :
.vcard .additional-name { display: none; } .vcard .tel, .vcard .email { font-size: smaller; } .vcard .org { display: inline; font-style: italic; margin-left: 0.5em; } .vcard span.n .org { margin: 0; }
This stylesheet will render the example card as :
- one field is mandatory: n, containing the name of the contact, formatted as 'last_name[;given_name[;middle_name]]'
- optional fields are:
2.1. org (organization): use the same value as the 'n' field if the contact is an organization instead of a person
2.2. email
2.3. tel and/or fax
2.4. adr (address), formatted as 'street_adress;[city_name];[postal_code];[region_or_state];[country_name]'
2.5. title
2.6. url (personal or organizational web address)
2.7. note (any further information)
- no data validation is performed.
- a contact card is rendered by default as an inline text displaying the contact's name and (if any) organization, with a 'mailto' hyperlink to the contact's email address and a tooltip showing his/her phone and fax numbers. Example: John Doe (His_org).
- optionally, a contact card can be displayed as a hCard microformat. Just add the print="hCard" parameter. The visual rendering of the hCard can be customized by adding classes to the wikka.css stylesheet (an example is given in the right-hand side box.)
Predefined requests
A request called Cards is predefined. It displays all contact cards in a table, sorted by name. If parameter p1 is present, only contacts whose organization equals p1 are selected. If parameter p2 is present, its value is used as the name of the field to sort on. As an example, {{structdata req="Cards"}} yields the following table:
Last name | Given name | Phone | Fax | Organization | |
---|---|---|---|---|---|
Doe | John | jdoe@his_organization.org | (+41) 123 4567 | (123) 654-898 | His_org |
Finally, parameter p3 controls the way the contact cards are formatted:
- if p3 is absent or p3="table", the cards are displayed in a table as shown above
- if p3="vCard", a download button is displayed, which allows to grab a file containing the contact cards in the vCard format (which can be imported into a Personal Information Manager or a phone). In this example, {{structdata req="Cards" p3="vCard"}} displays a button giving access to a file containing:
BEGIN:VCARD VERSION:2.1 N:DOE;John FN:John Doe ORG:His_org TEL:(+41) 123 4567 TEL;FAX:(123) 654-898 EMAIL;INTERNET:jdoe@his_organization.org END:VCARD
Example 3: ItemTable request
This is a predefined request which can be used with any type of data item. What it does is displaying in a single table all the data items of a given type (passed as parameter p1) present on the page. This allows a more compact rendering compared to displaying each data item as an independent table. Usually, data items are entered with the print='false' parameter; otherwise they will be displayed twice.As an example, {{structdata req="ItemTable" p1="ToDo"}} groups the two data items defined in example 1 in the following table:
date_open | owner | status | date_due | desc | priority |
---|---|---|---|---|---|
2006-10-3 | jdoe | open | 2007/11/13 | Complete logo design | 2 |
2006-10-4 | kbill | open | 2006-12-2 | Book flight to Lake Tahoe |
If you want to control the column order, you can optionally provide a (comma-separated) column list as the p2 parameter.
Thus, {{structdata req="ItemTable" p1="ToDo" p2="owner,desc,status"}} displays:
owner | desc | status | date_open | date_due | priority |
---|---|---|---|---|---|
jdoe | Complete logo design | open | 2006-10-3 | 2007/11/13 | 2 |
kbill | Book flight to Lake Tahoe | open | 2006-10-4 | 2006-12-2 |
Finally, you can control the request's scope (the set of pages whose data items will be listed) with the p3 parameter. Possible values are:
- "page" (default value; only items from current page are displayed)
- "user" (all pages owned by current user)
- "all" (all pages to which current user has read-access)
To-do, bugs and limitations
- Double and single quotes around parameters and values shall be used in the same way as in the examples.
- A field can not be multi-line (should be fixed in release 1.1.7.)
- A possible path of development would be to provide dynamic edition/validation capabilities for data items by embedding a HTML/Javascript form into the page.
- Possible refactoring: use an object approach to dynamically extend a base class with new structured data item types, each packaged in its own file.
Other considerations
- A nice feature of this action is that it is possible to freely mix regular wiki page content and structured data items, without any change to the database structure. However, this approach relies on regular expressions and is probably not very scalable in terms of the performance achieved when processing requests.
- One could wish, instead of having pre-cooked requests, to be able to run SQL-style SELECT statements. This would require a syntactic parser and is currently beyond my resources.
Author
DomBonjCategoryDocumentation