Fix formatting in mod/help

This commit is contained in:
Hypolite Petovan 2018-07-09 21:53:19 -04:00
parent 627fa08a1b
commit 4161908f43

View file

@ -2,31 +2,32 @@
/** /**
* @file mod/help.php * @file mod/help.php
*/ */
use Friendica\App; use Friendica\App;
use Friendica\Content\Nav; use Friendica\Content\Nav;
use Friendica\Content\Text\Markdown; use Friendica\Content\Text\Markdown;
use Friendica\Core\L10n; use Friendica\Core\L10n;
use Friendica\Core\System; use Friendica\Core\System;
if (!function_exists('load_doc_file')) { function load_doc_file($s)
{
function load_doc_file($s) { global $lang;
global $lang; if (!isset($lang)) $lang = 'en';
if (!isset($lang)) $b = basename($s);
$lang = 'en'; $d = dirname($s);
$b = basename($s); if (file_exists("$d/$lang/$b")) {
$d = dirname($s); return file_get_contents("$d/$lang/$b");
if (file_exists("$d/$lang/$b"))
return file_get_contents("$d/$lang/$b");
if (file_exists($s))
return file_get_contents($s);
return '';
} }
if (file_exists($s)) {
return file_get_contents($s);
}
return '';
} }
function help_content(App $a) { function help_content(App $a)
{
Nav::setSelected('help'); Nav::setSelected('help');
global $lang; global $lang;
@ -37,9 +38,11 @@ function help_content(App $a) {
$path = ''; $path = '';
// looping through the argv keys bigger than 0 to build // looping through the argv keys bigger than 0 to build
// a path relative to /help // a path relative to /help
for($x = 1; $x < argc(); $x ++) { for ($x = 1; $x < argc(); $x ++) {
if(strlen($path)) if (strlen($path)) {
$path .= '/'; $path .= '/';
}
$path .= argv($x); $path .= argv($x);
} }
$title = basename($path); $title = basename($path);
@ -47,6 +50,7 @@ function help_content(App $a) {
$text = load_doc_file('doc/' . $path . '.md'); $text = load_doc_file('doc/' . $path . '.md');
$a->page['title'] = L10n::t('Help:') . ' ' . str_replace('-', ' ', notags($title)); $a->page['title'] = L10n::t('Help:') . ' ' . str_replace('-', ' ', notags($title));
} }
$home = load_doc_file('doc/Home.md'); $home = load_doc_file('doc/Home.md');
if (!$text) { if (!$text) {
$text = $home; $text = $home;
@ -60,8 +64,8 @@ function help_content(App $a) {
header($_SERVER["SERVER_PROTOCOL"] . ' 404 ' . L10n::t('Not Found')); header($_SERVER["SERVER_PROTOCOL"] . ' 404 ' . L10n::t('Not Found'));
$tpl = get_markup_template("404.tpl"); $tpl = get_markup_template("404.tpl");
return replace_macros($tpl, [ return replace_macros($tpl, [
'$message' => L10n::t('Page not found.') '$message' => L10n::t('Page not found.')
]); ]);
} }
$html = Markdown::convert($text, false); $html = Markdown::convert($text, false);
@ -69,34 +73,46 @@ function help_content(App $a) {
if ($filename !== "Home") { if ($filename !== "Home") {
// create TOC but not for home // create TOC but not for home
$lines = explode("\n", $html); $lines = explode("\n", $html);
$toc="<h2>TOC</h2><ul id='toc'>"; $toc = "<h2>TOC</h2><ul id='toc'>";
$lastlevel=1; $lastlevel = 1;
$idnum = [0,0,0,0,0,0,0]; $idnum = [0, 0, 0, 0, 0, 0, 0];
foreach($lines as &$line){ foreach ($lines as &$line) {
if (substr($line,0,2)=="<h") { if (substr($line, 0, 2) == "<h") {
$level = substr($line,2,1); $level = substr($line, 2, 1);
if ($level!="r") { if ($level != "r") {
$level = intval($level); $level = intval($level);
if ($level<$lastlevel) { if ($level < $lastlevel) {
for($k=$level;$k<$lastlevel; $k++) $toc.="</ul>"; for ($k = $level; $k < $lastlevel; $k++) {
for($k=$level+1;$k<count($idnum);$k++) $idnum[$k]=0; $toc .= "</ul>";
}
for ($k = $level + 1; $k < count($idnum); $k++) {
$idnum[$k] = 0;
}
} }
if ($level>$lastlevel) $toc.="<ul>";
$idnum[$level]++; if ($level > $lastlevel) {
$id = implode("_", array_slice($idnum,1,$level)); $toc .= "<ul>";
$href = System::baseUrl()."/help/{$filename}#{$id}"; }
$toc .= "<li><a href='{$href}'>".strip_tags($line)."</a></li>";
$line = "<a name='{$id}'></a>".$line; $idnum[$level] ++;
$id = implode("_", array_slice($idnum, 1, $level));
$href = System::baseUrl() . "/help/{$filename}#{$id}";
$toc .= "<li><a href='{$href}'>" . strip_tags($line) . "</a></li>";
$line = "<a name='{$id}'></a>" . $line;
$lastlevel = $level; $lastlevel = $level;
} }
} }
} }
for($k=0;$k<$lastlevel; $k++) $toc.="</ul>";
$html = implode("\n",$lines); for ($k = 0; $k < $lastlevel; $k++) {
$toc .= "</ul>";
}
$html = implode("\n", $lines);
$a->page['aside'] = '<div class="help-aside-wrapper widget"><div id="toc-wrapper">' . $toc . '</div>' . $a->page['aside'] . '</div>'; $a->page['aside'] = '<div class="help-aside-wrapper widget"><div id="toc-wrapper">' . $toc . '</div>' . $a->page['aside'] . '</div>';
} }
return $html; return $html;
} }