diff options
author | Andrew Manning <tamanning@zoho.com> | 2016-04-20 21:05:01 -0400 |
---|---|---|
committer | Andrew Manning <tamanning@zoho.com> | 2016-04-20 21:05:01 -0400 |
commit | b96eb1c8230ae2f5986d6f22934c606bbca9728e (patch) | |
tree | fecd2279927b61da28801094dc7d6b1cfa8d98fe /mod/help.php | |
parent | 7594796ee11c0b245d02d145868a13ac3d84ebfc (diff) | |
parent | 635580091a227529cb491e6441a5acbfff3177be (diff) | |
download | volse-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.php | 289 |
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; - } - -} - |