*/ // must be run within Dokuwiki if (!defined('DOKU_INC')) die(); if(!defined('DOKU_PLUGIN')) define('DOKU_PLUGIN',DOKU_INC.'lib/plugins/'); require_once(DOKU_PLUGIN.'syntax.php'); class syntax_plugin_blog_draft extends DokuWiki_Syntax_Plugin { function getInfo() { return array( 'author' => 'Gina Häußge, Michael Klier, Esther Brunner', 'email' => 'dokuwiki@chimeric.de', 'date' => @file_get_contents(DOKU_PLUGIN . 'blog/VERSION'), 'name' => 'Blog Plugin (draft component)', 'desc' => 'Marks the current page as draft', 'url' => 'http://wiki.splitbrain.org/plugin:blog', ); } function getType() { return 'substition'; } function getSort() { return 99; } function connectTo($mode) { $this->Lexer->addSpecialPattern('~~DRAFT~~', $mode, 'plugin_blog_draft'); } function handle($match, $state, $pos, &$handler) { return true; } /** * The only thing this plugin component does is to set the metadata 'type' to 'draft' */ function render($mode, &$renderer, $data) { if ($mode == 'xthml') { return true; // don't output anything } elseif ($mode == 'metadata') { $renderer->meta['type'] = 'draft'; } } } // vim:ts=4:sw=4:et:enc=utf-8: