Bläddra i källkod

Load plugin info from plugin file. Show README.md or README from plugin dir in plugin details page

tags/2.3beta1
Fabio Comuni 9 år sedan
förälder
incheckning
00e142e4f7
5 ändrade filer med 88 tillägg och 16 borttagningar
  1. +4
    -5
      addon/oembed/oembed.php
  2. +52
    -0
      boot.php
  3. +15
    -5
      mod/admin.php
  4. +3
    -4
      view/admin_plugins.tpl
  5. +14
    -2
      view/admin_plugins_details.tpl

+ 4
- 5
addon/oembed/oembed.php Visa fil

@@ -1,10 +1,9 @@
<?php
/**
* oembed plugin
*
* oEmbed is a format for allowing an embedded representation of a URL on third party sites
* http://www.oembed.com/
*
* Name: OEmbed
* Description: OEmbed is a format for allowing an embedded representation of a URL on third party sites http://www.oembed.com/
* Version: 1.2
* Author: Fabio Comuni <http://kirgroup.com/profile/fabrix>
*/

require_once('include/oembed.php');


+ 52
- 0
boot.php Visa fil

@@ -2828,3 +2828,55 @@ function is_site_admin() {
return false;
}}

/*
* parse plugin comment in search of plugin infos.
* like
*
* * Name: Plugin
* * Description: A plugin which plugs in
* * Version: 1.2.3
* * Author: John <profile url>
* * Author: Jane <email>
* *
*/

if (! function_exists('get_plugin_info')){
function get_plugin_info($plugin){
if (!is_file("addon/$plugin/$plugin.php")) return false;
$f = file_get_contents("addon/$plugin/$plugin.php");
$r = preg_match("|/\*.*\*/|msU", $f, $m);
$info=Array(
'name' => $plugin,
'description' => "",
'author' => array(),
'version' => ""
);
if ($r){
$ll = explode("\n", $m[0]);
foreach( $ll as $l ) {
$l = trim($l,"\t\n\r */");
if ($l!=""){
list($k,$v) = array_map("trim", explode(":",$l,2));
$k= strtolower($k);
if ($k=="author"){
$r=preg_match("|([^<]+)<([^>]+)>|", $v, $m);
if ($r) {
$info['author'][] = array('name'=>$m[1], 'link'=>$m[2]);
} else {
$info['author'][] = array('name'=>$v);
}
} else {
if (array_key_exists($k,$info)){
$info[$k]=$v;
}
}
}
}
}
return $info;
}}

+ 15
- 5
mod/admin.php Visa fil

@@ -340,7 +340,7 @@ function admin_page_plugins(&$a){
return; // NOTREACHED
}
// display plugin details
require_once('library/markdown.php');

if (in_array($plugin, $a->plugins)){
$status="on"; $action= t("Disable");
@@ -348,6 +348,14 @@ function admin_page_plugins(&$a){
$status="off"; $action= t("Enable");
}
$readme=Null;
if (is_file("addon/$plugin/README.md")){
$readme = file_get_contents("addon/$plugin/README.md");
$readme = Markdown($readme);
} else if (is_file("addon/$plugin/README")){
$readme = "<pre>". file_get_contents("addon/$plugin/README") ."</pre>";
}
$t = get_markup_template("admin_plugins_details.tpl");
return replace_macros($t, array(
'$title' => t('Administration'),
@@ -357,7 +365,10 @@ function admin_page_plugins(&$a){
'$plugin' => $plugin,
'$status' => $status,
'$action' => $action
'$action' => $action,
'$info' => get_plugin_info($plugin),
'$readme' => $readme
));
}
@@ -373,9 +384,8 @@ function admin_page_plugins(&$a){
foreach($files as $file) {
if (is_dir($file)){
list($tmp, $id)=array_map("trim", explode("/",$file));
// TODO: plugins info
$name=$author=$description=$homepage="";
$plugins[] = array( $id, (in_array($id, $a->plugins)?"on":"off") , $name, $author, $description, $homepage);
$info = get_plugin_info($id);
$plugins[] = array( $id, (in_array($id, $a->plugins)?"on":"off") , $info);
}
}
}


+ 3
- 4
view/admin_plugins.tpl Visa fil

@@ -4,10 +4,9 @@
<ul id='pluginslist'>
{{ for $plugins as $p }}
<li class='plugin $p.1'>
<a class='toggle' href='$baseurl/admin/plugins/$p.0?a=t'><span class='icon $p.1'></span></a>
<a href='$baseurl/admin/plugins/$p.0'>
<span class='name'>$p.0</span>
</a>
<a class='toggleplugin' href='$baseurl/admin/plugins/$p.0?a=t'><span class='icon $p.1'></span></a>
<a href='$baseurl/admin/plugins/$p.0'><span class='name'>$p.2.name</span></a> - <span class="version">$p.2.version</span>
<div class='desc'>$p.2.description</div>
</li>
{{ endfor }}
</ul>


+ 14
- 2
view/admin_plugins_details.tpl Visa fil

@@ -1,7 +1,19 @@
<div id='adminpage'>
<h1>$title - $page</h1>
<p><span class='icon $status'></span> $plugin</p>
<p><span class='toggleplugin icon $status'></span> $info.name - $info.version : <a href="$baseurl/admin/plugins/$plugin/?a=t">$action</a></p>
<p>$info.description</p>
<p>
{{ for $info.author as $a }}
<a href="$a.link">$a.name</a>
{{ endfor }}
</p>
<p><a href="$baseurl/admin/plugins/$plugin/?a=t">$action</a></p>

{{ if $readme }}
<h3>Readme</h3>
<div id="plugin_readme">
$readme
</div>
{{ endif }}
</div>

Laddar…
Avbryt
Spara