diff --git a/admin/apps.php b/admin/apps.php index b433fe0875..bff3089dc5 100644 --- a/admin/apps.php +++ b/admin/apps.php @@ -29,8 +29,7 @@ if( !OC_USER::isLoggedIn() || !OC_GROUP::inGroup( $_SESSION['user_id'], 'admin' } // Load the files we need -//OC_UTIL::addStyle( "", "files" ); -//OC_UTIL::addScript( "", "files" ); +OC_UTIL::addStyle( "admin", "apps" ); if(isset($_GET['id'])) $id=$_GET['id']; else $id=0; @@ -41,7 +40,9 @@ $categories=OC_OCSCLIENT::getCategories(); if($id==0) { if($cat==0){ - $apps=OC_OCSCLIENT::getApplications($categories); + $numcats=array(); + foreach($categories as $key=>$value) $numcats[]=$key; + $apps=OC_OCSCLIENT::getApplications($numcats); }else{ $apps=OC_OCSCLIENT::getApplications($cat); } @@ -59,6 +60,7 @@ if($id==0) { $app=OC_OCSCLIENT::getApplication($id); $tmpl = new OC_TEMPLATE( "admin", "app", "admin" ); + $tmpl->assign( "categories", $categories ); $tmpl->assign( "app", $app ); $tmpl->printPage(); unset($tmpl); diff --git a/admin/css/apps.css b/admin/css/apps.css new file mode 100644 index 0000000000..68bd9cf63d --- /dev/null +++ b/admin/css/apps.css @@ -0,0 +1,42 @@ +/* APPS TABLE */ + +table td.date +{ + width: 5em; + padding: 0.5em 1em; + text-align: right; +} + +.preview +{ + padding: 3px; + text-align: left; +} + +table td.date +{ + width: 11em; + color: #555555; +} + +table td.selection, table th.selection, table td.fileaction +{ + width: 2em; + text-align: center; +} + +table td.name a +{ + padding: 6px; + text-decoration: none; + color: #555555; +} + +.type +{ + padding: 6px; + text-decoration: none; + color: #888888; + font-size: 0.8em; +} + diff --git a/admin/templates/apps.php b/admin/templates/apps.php index 2f58477581..36a7cd5302 100644 --- a/admin/templates/apps.php +++ b/admin/templates/apps.php @@ -12,16 +12,14 @@ Name Modified - - "") { echo(''); } ?> - + "") { echo(''); } ?> + " title="">
'.$app['typename'].''); ?> - + diff --git a/lib/ocsclient.php b/lib/ocsclient.php index d9ce11d537..921bd5489a 100644 --- a/lib/ocsclient.php +++ b/lib/ocsclient.php @@ -37,16 +37,13 @@ class OC_OCSCLIENT{ public static function getCategories(){ $url='http://api.opendesktop.org/v1/content/categories'; - $cats=array(); $xml=file_get_contents($url); $data=simplexml_load_string($xml); $tmp=$data->data->category; + $cats=array(); for($i = 0; $i < count($tmp); $i++) { - $cat=array(); - $cat['id']=$tmp[$i]->id; - $cat['name']=$tmp[$i]->name; - $cats[]=$cat; + $cats[$i]=$tmp[$i]->name; } return $cats; } @@ -58,8 +55,12 @@ class OC_OCSCLIENT{ * This function returns a list of all the applications on the OCS server */ public static function getApplications($categories){ - $categoriesstring=implode('x',$categories); - $url='http://api.opendesktop.org/v1/content/data?categories='.$ocscategories['ids'].'&sortmode=new&page=0&pagesize=10'; + if(is_array($categories)) { + $categoriesstring=implode('x',$categories); + }else{ + $categoriesstring=$categories; + } + $url='http://api.opendesktop.org/v1/content/data?categories='.urlencode($categoriesstring).'&sortmode=new&page=0&pagesize=10'; $apps=array(); $xml=file_get_contents($url); @@ -70,7 +71,8 @@ class OC_OCSCLIENT{ $app=array(); $app['id']=$tmp[$i]->id; $app['name']=$tmp[$i]->name; - $app['type']=$tmp[$i]->type; + $app['type']=$tmp[$i]->typeid; + $app['typename']=$tmp[$i]->typename; $app['personid']=$tmp[$i]->personid; $app['detailpage']=$tmp[$i]->detailpage; $app['preview']=$tmp[$i]->smallpreviewpic1; @@ -82,5 +84,38 @@ class OC_OCSCLIENT{ return $apps; } + + /** + * @brief Get an the applications from the OCS server + * @returns array with application data + * + * This function returns an applications from the OCS server + */ + public static function getApplication($id){ + $url='http://api.opendesktop.org/v1/content/data/'.urlencode($id); + + $xml=file_get_contents($url); + $data=simplexml_load_string($xml); + + $tmp=$data->data->content; + $app=array(); + $app['id']=$tmp->id; + $app['name']=$tmp->name; + $app['type']=$tmp->typeid; + $app['typename']=$tmp->typename; + $app['personid']=$tmp->personid; + $app['detailpage']=$tmp->detailpage; + $app['preview1']=$tmp->smallpreviewpic1; + $app['preview2']=$tmp->smallpreviewpic2; + $app['preview3']=$tmp->smallpreviewpic3; + $app['changed']=strtotime($tmp->changed); + $app['description']=$tmp->description; + + return $app; + } + + + + } ?>