aboutsummaryrefslogtreecommitdiffstats
path: root/mod/help.php
diff options
context:
space:
mode:
authorAndrew Manning <tamanning@zoho.com>2016-04-20 21:05:01 -0400
committerAndrew Manning <tamanning@zoho.com>2016-04-20 21:05:01 -0400
commitb96eb1c8230ae2f5986d6f22934c606bbca9728e (patch)
treefecd2279927b61da28801094dc7d6b1cfa8d98fe /mod/help.php
parent7594796ee11c0b245d02d145868a13ac3d84ebfc (diff)
parent635580091a227529cb491e6441a5acbfff3177be (diff)
downloadvolse-hubzilla-b96eb1c8230ae2f5986d6f22934c606bbca9728e.tar.gz
volse-hubzilla-b96eb1c8230ae2f5986d6f22934c606bbca9728e.tar.bz2
volse-hubzilla-b96eb1c8230ae2f5986d6f22934c606bbca9728e.zip
Merge branch 'dev' into toggle-context-help
Diffstat (limited to 'mod/help.php')
-rw-r--r--mod/help.php289
1 files changed, 0 insertions, 289 deletions
diff --git a/mod/help.php b/mod/help.php
deleted file mode 100644
index 8c27156ab..000000000
--- a/mod/help.php
+++ /dev/null
@@ -1,289 +0,0 @@
-<?php
-
-/**
- * You can create local site resources in doc/Site.md and either link to doc/Home.md for the standard resources
- * or use our include mechanism to include it on your local page.
- *
- * #include doc/Home.md;
- *
- * The syntax is somewhat strict.
- *
- */
-
-
-
-function load_doc_file($s) {
- $lang = App::$language;
- if(! isset($lang))
- $lang = 'en';
- $b = basename($s);
- $d = dirname($s);
-
- $c = find_doc_file("$d/$lang/$b");
- if($c)
- return $c;
- $c = find_doc_file($s);
- if($c)
- return $c;
- return '';
-}
-
-function find_doc_file($s) {
- if(file_exists($s))
- return file_get_contents($s);
- return '';
-}
-
-function search_doc_files($s) {
-
- $a = get_app();
-
- $itemspage = get_pconfig(local_channel(),'system','itemspage');
- App::set_pager_itemspage(((intval($itemspage)) ? $itemspage : 20));
- $pager_sql = sprintf(" LIMIT %d OFFSET %d ", intval(App::$pager['itemspage']), intval(App::$pager['start']));
-
- $regexop = db_getfunc('REGEXP');
-
- $r = q("select item_id.sid, item.* from item left join item_id on item.id = item_id.iid where service = 'docfile' and
- body $regexop '%s' and item_type = %d $pager_sql",
- dbesc($s),
- intval(ITEM_TYPE_DOC)
- );
-
- $r = fetch_post_tags($r,true);
-
- for($x = 0; $x < count($r); $x ++) {
-
- $r[$x]['text'] = $r[$x]['body'];
-
- $r[$x]['rank'] = 0;
- if($r[$x]['term']) {
- foreach($r[$x]['term'] as $t) {
- if(stristr($t['term'],$s)) {
- $r[$x]['rank'] ++;
- }
- }
- }
- if(stristr($r[$x]['sid'],$s))
- $r[$x]['rank'] ++;
- $r[$x]['rank'] += substr_count(strtolower($r[$x]['text']),strtolower($s));
- // bias the results to the observer's native language
- if($r[$x]['lang'] === App::$language)
- $r[$x]['rank'] = $r[$x]['rank'] + 10;
-
- }
- usort($r,'doc_rank_sort');
- return $r;
-}
-
-
-function doc_rank_sort($s1,$s2) {
- if($s1['rank'] == $s2['rank'])
- return 0;
- return (($s1['rank'] < $s2['rank']) ? 1 : (-1));
-}
-
-
-function load_context_help() {
-
- $path = App::$cmd;
- $args = App::$argv;
- $lang = App::$language;
-
- if(! isset($lang) || !is_dir('doc/context/' . $lang . '/')) {
- $lang = 'en';
- }
- while($path) {
- $context_help = load_doc_file('doc/context/' . $lang . '/' . $path . '/help.html');
- if(!$context_help) {
- // Fallback to English if the translation is absent
- $context_help = load_doc_file('doc/context/en/' . $path . '/help.html');
- }
- if($context_help)
- break;
- array_pop($args);
- $path = implode($args,'/');
- }
-
- return $context_help;
-}
-
-
-function store_doc_file($s) {
-
- if(is_dir($s))
- return;
-
- $item = array();
- $sys = get_sys_channel();
-
- $item['aid'] = 0;
- $item['uid'] = $sys['channel_id'];
-
-
- if(strpos($s,'.md'))
- $mimetype = 'text/markdown';
- elseif(strpos($s,'.html'))
- $mimetype = 'text/html';
- else
- $mimetype = 'text/bbcode';
-
- require_once('include/html2plain.php');
-
- $item['body'] = html2plain(prepare_text(file_get_contents($s),$mimetype, true));
- $item['mimetype'] = 'text/plain';
-
- $item['plink'] = z_root() . '/' . str_replace('doc','help',$s);
- $item['owner_xchan'] = $item['author_xchan'] = $sys['channel_hash'];
- $item['item_type'] = ITEM_TYPE_DOC;
-
- $r = q("select item.* from item left join item_id on item.id = item_id.iid where service = 'docfile' and
- sid = '%s' and item_type = %d limit 1",
- dbesc($s),
- intval(ITEM_TYPE_DOC)
- );
-
- if($r) {
- $item['id'] = $r[0]['id'];
- $item['mid'] = $item['parent_mid'] = $r[0]['mid'];
- $x = item_store_update($item);
- }
- else {
- $item['mid'] = $item['parent_mid'] = item_message_id();
- $x = item_store($item);
- }
-
- if($x['success']) {
- update_remote_id($sys,$x['item_id'],ITEM_TYPE_DOC,$s,'docfile',0,$item['mid']);
- }
-
-
-}
-
-
-function help_content(&$a) {
- nav_set_selected('help');
-
- if($_REQUEST['search']) {
-
- $o .= '<div id="help-content" class="generic-content-wrapper">';
- $o .= '<div class="section-title-wrapper">';
- $o .= '<h2>' . t('Documentation Search') . ' - ' . htmlspecialchars($_REQUEST['search']) . '</h2>';
- $o .= '</div>';
- $o .= '<div class="section-content-wrapper">';
-
- $r = search_doc_files($_REQUEST['search']);
- if($r) {
- $o .= '<ul class="help-searchlist">';
- foreach($r as $rr) {
- $dirname = dirname($rr['sid']);
- $fname = basename($rr['sid']);
- $fname = substr($fname,0,strrpos($fname,'.'));
- $path = trim(substr($dirname,4),'/');
-
- $o .= '<li><a href="help/' . (($path) ? $path . '/' : '') . $fname . '" >' . ucwords(str_replace('_',' ',notags($fname))) . '</a><br />' .
- str_replace('$Projectname',Zotlabs\Project\System::get_platform_name(),substr($rr['text'],0,200)) . '...<br /><br /></li>';
-
- }
- $o .= '</ul>';
- $o .= '</div>';
- $o .= '</div>';
- }
- return $o;
- }
-
-
- global $lang;
-
- $doctype = 'markdown';
-
- $text = '';
-
- if(argc() > 1) {
- $path = '';
- for($x = 1; $x < argc(); $x ++) {
- if(strlen($path))
- $path .= '/';
- $path .= argv($x);
- }
- $title = basename($path);
-
- $text = load_doc_file('doc/' . $path . '.md');
- App::$page['title'] = t('Help:') . ' ' . ucwords(str_replace('-',' ',notags($title)));
-
- if(! $text) {
- $text = load_doc_file('doc/' . $path . '.bb');
- if($text)
- $doctype = 'bbcode';
- App::$page['title'] = t('Help:') . ' ' . ucwords(str_replace('_',' ',notags($title)));
- }
- if(! $text) {
- $text = load_doc_file('doc/' . $path . '.html');
- if($text)
- $doctype = 'html';
- App::$page['title'] = t('Help:') . ' ' . ucwords(str_replace('-',' ',notags($title)));
- }
- }
-
- if(! $text) {
- $text = load_doc_file('doc/Site.md');
- App::$page['title'] = t('Help');
- }
- if(! $text) {
- $doctype = 'bbcode';
- $text = load_doc_file('doc/main.bb');
- App::$page['title'] = t('Help');
- }
-
- if(! strlen($text)) {
- header($_SERVER["SERVER_PROTOCOL"] . ' 404 ' . t('Not Found'));
- $tpl = get_markup_template("404.tpl");
- return replace_macros($tpl, array(
- '$message' => t('Page not found.' )
- ));
- }
-
- if($doctype === 'html')
- $content = $text;
- if($doctype === 'markdown') {
- require_once('library/markdown.php');
- # escape #include tags
- $text = preg_replace('/#include/ism', '%%include', $text);
- $content = Markdown($text);
- $content = preg_replace('/%%include/ism', '#include', $content);
- }
- if($doctype === 'bbcode') {
- require_once('include/bbcode.php');
- $content = bbcode($text);
- // bbcode retargets external content to new windows. This content is internal.
- $content = str_replace(' target="_blank"','',$content);
- }
-
- $content = preg_replace_callback("/#include (.*?)\;/ism", 'preg_callback_help_include', $content);
-
- return replace_macros(get_markup_template("help.tpl"), array(
- '$title' => t('$Projectname Documentation'),
- '$content' => translate_projectname($content)
- ));
-
-}
-
-
-function preg_callback_help_include($matches) {
-
- if($matches[1]) {
- $include = str_replace($matches[0],load_doc_file($matches[1]),$matches[0]);
- if(preg_match('/\.bb$/', $matches[1]) || preg_match('/\.txt$/', $matches[1])) {
- require_once('include/bbcode.php');
- $include = bbcode($include);
- $include = str_replace(' target="_blank"','',$include);
- }
- elseif(preg_match('/\.md$/', $matches[1])) {
- require_once('library/markdown.php');
- $include = Markdown($include);
- }
- return $include;
- }
-
-}
-