'substition' (i.e. 'substitution'). * @public * @static */ function getType() { return 'substition'; } /** * Where to sort in? * * @param none * @return Integer 999. * @public * @static */ function getSort(){ return 999; } /** * Connect lookup pattern to lexer. * * @param $aMode String The desired rendermode. * @return none * @public * @see render() */ function connectTo($mode) { $this->Lexer->addSpecialPattern('.*?',$mode,'plugin_rtmchecklist'); } /** * Handler to prepare matched data for the rendering process. * *

* The $aState parameter gives the type of pattern * which triggered the call to this method: *

*
*
DOKU_LEXER_ENTER
*
a pattern set by addEntryPattern()
*
DOKU_LEXER_MATCHED
*
a pattern set by addPattern()
*
DOKU_LEXER_EXIT
*
a pattern set by addExitPattern()
*
DOKU_LEXER_SPECIAL
*
a pattern set by addSpecialPattern()
*
DOKU_LEXER_UNMATCHED
*
ordinary text encountered within the plugin's syntax mode * which doesn't match any pattern.
*
* @param $aMatch String The text matched by the patterns. * @param $aState Integer The lexer state for the match. * @param $aPos Integer The character position of the matched text. * @param $aHandler Object Reference to the Doku_Handler object. * @return Integer The current lexer state for the match. * @public * @see render() * @static */ function handle($match, $state, $pos, Doku_Handler $handler){ $tasks = array(); $start = false; $end = false; switch ($state) { case DOKU_LEXER_ENTER : $start = true; break; case DOKU_LEXER_MATCHED : break; case DOKU_LEXER_UNMATCHED : break; case DOKU_LEXER_EXIT : $end = true; break; case DOKU_LEXER_SPECIAL : $start = true; $end = true; $match = substr($match, 14, -15); $tasks = array(); //split tasks in lines $tasks = preg_split('/[\|\n]/u', $match); break; default: } return array('tasks' => $tasks, 'start' => $start, 'end' => $end); } /** * Handle the actual output creation. * *

* The method checks for the given $aFormat and returns * FALSE when a format isn't supported. $aRenderer * contains a reference to the renderer object which is currently * handling the rendering. The contents of $aData is the * return value of the handle() method. *

* @param $aFormat String The output format to generate. * @param $aRenderer Object A reference to the renderer object. * @param $aData Array The data created by the handle() * method. * @return Boolean TRUE if rendered successfully, or * FALSE otherwise. * @public * @see handle() */ function render($mode, Doku_Renderer $renderer, $data) { if($mode == 'xhtml'){ if($data['start']) { global $ID; $renderer->doc .= '
'; $renderer->doc .= ''; $renderer->doc .= ''; $renderer->doc .= ''; } $full_list = ""; foreach($data['tasks'] as $i=> $item) { if(strlen(preg_replace('/[\s\n\r]+/', '', $item))>0) { $renderer->doc .= '
  • '.htmlspecialchars($item).'
  • '; $full_list.=htmlspecialchars($item)."\n"; } } $renderer->doc .= ''; if($data['end']) { $renderer->doc .= '
    '; // onclick=\"sendRtmChecklist()\" ? $renderer->doc .= '

    '; } return true; } return false; } } //rtmchecklist class end