This is an offshoot of this rant.
Basically, while I can appreciate the po plugin for more or less "static" site, or more organised wikis, for certain wikis, it's way too overhead.
Stories
The following stories should be answered by that plugin:
- a user browses the wiki, finds that the page is translated in another language and clicks on the language to see that page translated
- a user browses the wiki and gets automatically the right language
- an editor creates a wiki page, and it gets assigned a language
- a translator sees that page and translates it to another language, and that page is linked with the first one, both ways (in that stories 1 and 2 can work)
- (optional) a translator can see the list of pages needing translation and translate pages
- (optional) an editor changes a wiki page, the translated page is marked as "dirty" (ie. needing translation)
Fundamental constraints
This issue is about creating a "wikipedia-like" translation structure where:
- there's no "master language"
- there's a loose connexion between pages
- not all pages are necessarily translated, nor is it a goal
Those are fundamental constraints that should be required by that plugin. It doesn't mean that the plugin cannot be used otherwise, but that's all it needs to respect to fulfill the requirements here.
Optional constraints
There can be more constraints that we may want to impose or not, which will make things more or less complicated:
- the page URLs need to be translatable - it would make Content negotiation fail, so it would require the CGI for story 2. it would also make it harder to create the connexion between pages, as metadata would be needed in each page
- the language must not be visible in the URL - same as #4
- translation system must also be usable from the commandline/git repository - #5 and #6 would be basically impossible to implement there
Basic spec
- a hook that looks for foo.la.mdwn pages, where la is a language code (defined where..?), and that lists available translations - this is where most of the work needs to happen. we can probably reuse the builtin template stuff that got injected with the po plugin was imported, to start with
- instructions on how to setup Content negotiation so that the above works out of the box - just documentation
- a button to create such translations - that would be through the pageactions hook
- a default language setting? - that's obviously the getsetup hook
- a set of language code settings? - same
- content-negotiation - the po module has good code for that