Difference between revisions of "Extension:ExpandableTables.php"
From Organic Design wiki
(bug fix) |
(bug fixed) |
||
Line 4: | Line 4: | ||
$wgHooks['ParserAfterTidy'][] = 'allowExpandables'; | $wgHooks['ParserAfterTidy'][] = 'allowExpandables'; | ||
function allowExpandables(&$parser,&$text) { | function allowExpandables(&$parser,&$text) { | ||
− | if ($GLOBALS['allowex-done']++) return; | + | if ($GLOBALS['allowex-done']++) return true; |
# Replace all the expandable tables with html containing CSS classes and the show/hide links | # Replace all the expandable tables with html containing CSS classes and the show/hide links | ||
$text = preg_replace_callback( | $text = preg_replace_callback( |
Revision as of 09:16, 6 March 2007
<?
- Expandables
- - CSS is the same as XmlWiki's expandables at the end of [[default-skin.css]]
$wgHooks['ParserAfterTidy'][] = 'allowExpandables'; function allowExpandables(&$parser,&$text) { if ($GLOBALS['allowex-done']++) return true; # Replace all the expandable tables with html containing CSS classes and the show/hide links $text = preg_replace_callback(
'/
(.+?<\\/table\\s*?>)/s', 'expandableCallback', "\n<script type='text/javascript'> function toggleExpandable(id) { var heading = document.getElementById('expandable-heading-'+id); var content = document.getElementById('expandable-content-'+id); if (content.style.display == 'none') content.style.display = ; else content.style.display = 'none'; this.parent.focus(); } </script>\n$text" ); return true; }- Callback function executed for rendering each expandable table
<a class=expandable-link href="javascript:toggleExpandable('.$i.')">► '.$matches[1].'</a> |
'.$matches[3].' } |