Fix formatting in mod/help
This commit is contained in:
parent
627fa08a1b
commit
4161908f43
1 changed files with 54 additions and 38 deletions
92
mod/help.php
92
mod/help.php
|
@ -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;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue