2011-04-13 07:07:21 -07:00
|
|
|
<?php
|
2018-01-15 14:51:56 -05:00
|
|
|
/**
|
|
|
|
* @file mod/help.php
|
|
|
|
*/
|
2018-07-09 21:53:19 -04:00
|
|
|
|
2017-04-30 00:07:00 -04:00
|
|
|
use Friendica\App;
|
2018-01-15 14:51:56 -05:00
|
|
|
use Friendica\Content\Nav;
|
2018-01-14 18:59:08 -05:00
|
|
|
use Friendica\Content\Text\Markdown;
|
2018-07-09 22:37:51 -04:00
|
|
|
use Friendica\Core\Config;
|
2018-01-22 07:29:50 -05:00
|
|
|
use Friendica\Core\L10n;
|
2018-10-31 10:35:50 -04:00
|
|
|
use Friendica\Core\Renderer;
|
2017-08-26 06:04:21 +00:00
|
|
|
use Friendica\Core\System;
|
2018-11-08 10:14:37 -05:00
|
|
|
use Friendica\Util\Strings;
|
2017-04-30 00:07:00 -04:00
|
|
|
|
2018-07-09 21:53:19 -04:00
|
|
|
function load_doc_file($s)
|
|
|
|
{
|
2018-07-09 22:37:51 -04:00
|
|
|
$lang = Config::get('system', 'language');
|
2018-07-09 21:53:19 -04:00
|
|
|
$b = basename($s);
|
|
|
|
$d = dirname($s);
|
|
|
|
if (file_exists("$d/$lang/$b")) {
|
|
|
|
return file_get_contents("$d/$lang/$b");
|
2012-11-09 03:56:45 -05:00
|
|
|
}
|
|
|
|
|
2018-07-09 21:53:19 -04:00
|
|
|
if (file_exists($s)) {
|
|
|
|
return file_get_contents($s);
|
|
|
|
}
|
2011-04-13 07:07:21 -07:00
|
|
|
|
2018-07-09 21:53:19 -04:00
|
|
|
return '';
|
|
|
|
}
|
2015-02-23 23:56:44 +01:00
|
|
|
|
2018-07-09 21:53:19 -04:00
|
|
|
function help_content(App $a)
|
|
|
|
{
|
2018-01-15 14:51:56 -05:00
|
|
|
Nav::setSelected('help');
|
2011-04-13 07:07:21 -07:00
|
|
|
|
|
|
|
$text = '';
|
|
|
|
|
2012-11-09 03:56:45 -05:00
|
|
|
if ($a->argc > 1) {
|
2015-12-26 16:06:38 +01:00
|
|
|
$path = '';
|
2015-12-28 03:17:55 +01:00
|
|
|
// looping through the argv keys bigger than 0 to build
|
|
|
|
// a path relative to /help
|
2018-10-13 18:57:31 +02:00
|
|
|
for ($x = 1; $x < $a->argc; $x ++) {
|
2018-07-09 21:53:19 -04:00
|
|
|
if (strlen($path)) {
|
2015-12-26 16:06:38 +01:00
|
|
|
$path .= '/';
|
2018-07-09 21:53:19 -04:00
|
|
|
}
|
|
|
|
|
2018-10-13 18:57:31 +02:00
|
|
|
$path .= $a->getArgumentValue($x);
|
2015-12-26 16:06:38 +01:00
|
|
|
}
|
|
|
|
$title = basename($path);
|
2015-12-28 10:13:28 +01:00
|
|
|
$filename = $path;
|
2015-12-26 16:06:38 +01:00
|
|
|
$text = load_doc_file('doc/' . $path . '.md');
|
2018-11-09 13:29:42 -05:00
|
|
|
$a->page['title'] = L10n::t('Help:') . ' ' . str_replace('-', ' ', Strings::escapeTags($title));
|
2011-04-14 02:34:43 -07:00
|
|
|
}
|
2018-07-09 21:53:19 -04:00
|
|
|
|
2012-11-09 03:56:45 -05:00
|
|
|
$home = load_doc_file('doc/Home.md');
|
|
|
|
if (!$text) {
|
|
|
|
$text = $home;
|
2015-12-28 10:13:28 +01:00
|
|
|
$filename = "Home";
|
2018-01-22 07:29:50 -05:00
|
|
|
$a->page['title'] = L10n::t('Help');
|
2012-11-09 03:56:45 -05:00
|
|
|
} else {
|
2018-01-14 18:59:08 -05:00
|
|
|
$a->page['aside'] = Markdown::convert($home, false);
|
2011-04-13 07:07:21 -07:00
|
|
|
}
|
2012-11-09 03:56:45 -05:00
|
|
|
|
|
|
|
if (!strlen($text)) {
|
2018-01-22 07:29:50 -05:00
|
|
|
header($_SERVER["SERVER_PROTOCOL"] . ' 404 ' . L10n::t('Not Found'));
|
2018-10-31 10:44:06 -04:00
|
|
|
$tpl = Renderer::getMarkupTemplate("404.tpl");
|
2018-10-31 10:35:50 -04:00
|
|
|
return Renderer::replaceMacros($tpl, [
|
2018-07-09 21:53:19 -04:00
|
|
|
'$message' => L10n::t('Page not found.')
|
|
|
|
]);
|
2011-08-15 20:16:00 -07:00
|
|
|
}
|
2015-02-23 23:56:44 +01:00
|
|
|
|
2018-01-14 18:59:08 -05:00
|
|
|
$html = Markdown::convert($text, false);
|
2015-12-28 10:13:28 +01:00
|
|
|
|
2015-12-28 10:21:34 +01:00
|
|
|
if ($filename !== "Home") {
|
|
|
|
// create TOC but not for home
|
|
|
|
$lines = explode("\n", $html);
|
2018-07-09 21:53:19 -04:00
|
|
|
$toc = "<h2>TOC</h2><ul id='toc'>";
|
|
|
|
$lastlevel = 1;
|
|
|
|
$idnum = [0, 0, 0, 0, 0, 0, 0];
|
|
|
|
foreach ($lines as &$line) {
|
|
|
|
if (substr($line, 0, 2) == "<h") {
|
|
|
|
$level = substr($line, 2, 1);
|
|
|
|
if ($level != "r") {
|
2015-12-28 10:21:34 +01:00
|
|
|
$level = intval($level);
|
2018-07-09 21:53:19 -04:00
|
|
|
if ($level < $lastlevel) {
|
|
|
|
for ($k = $level; $k < $lastlevel; $k++) {
|
|
|
|
$toc .= "</ul>";
|
|
|
|
}
|
|
|
|
|
|
|
|
for ($k = $level + 1; $k < count($idnum); $k++) {
|
|
|
|
$idnum[$k] = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($level > $lastlevel) {
|
|
|
|
$toc .= "<ul>";
|
2015-12-28 10:21:34 +01:00
|
|
|
}
|
2018-07-09 21:53:19 -04:00
|
|
|
|
|
|
|
$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;
|
2015-12-28 10:21:34 +01:00
|
|
|
$lastlevel = $level;
|
2015-12-28 10:13:28 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-07-09 21:53:19 -04:00
|
|
|
|
|
|
|
for ($k = 0; $k < $lastlevel; $k++) {
|
|
|
|
$toc .= "</ul>";
|
|
|
|
}
|
|
|
|
|
|
|
|
$html = implode("\n", $lines);
|
2015-12-28 10:13:28 +01:00
|
|
|
|
2018-04-25 23:30:56 +02:00
|
|
|
$a->page['aside'] = '<div class="help-aside-wrapper widget"><div id="toc-wrapper">' . $toc . '</div>' . $a->page['aside'] . '</div>';
|
2015-12-28 10:21:34 +01:00
|
|
|
}
|
2015-12-28 10:13:28 +01:00
|
|
|
|
2012-11-09 03:56:45 -05:00
|
|
|
return $html;
|
2011-08-17 18:36:24 +02:00
|
|
|
}
|