login/list: option to order by seen date
[minimedit.git] / login / list.php
index eee2dc57a59197bc735250a7949ea7848d1d88a7..d3b1f177005ebc91be910f0af119e7dd9574690e 100644 (file)
@@ -8,11 +8,30 @@ foreach ($users as $col => $userdir) {
        $users[$col] = new User($userdir);
 }
 
-print '<ul class="gallery cat">';
+if (@$Place['order'] == 'seen') {
+       $order = array_map(function ($col) { return $col->seen; }, $users);
+#      $order = array_column($users, 'seen');  #TODO php7 simplification
+       array_multisort($order, SORT_DESC, SORT_NUMERIC, $users);
+}
+
+print '<ul';
+if (@$Place['view'] == 'avatar') {
+       print ' class="gallery cat"';
+}
+print ">\n";
 
 foreach ($users as $user) {
        $name = $user->name ?: ucfirst($user->login);
-       if (file_exists("{$user->dir}/avatar.jpg")) {
+       if (!empty($GLOBALS['User']['admin'])) {
+               $link = '/login/edit/'.$user->login;
+               $name = sprintf('<a href="%s">%s</a>', $link, $name);
+       }
+
+       switch (@$Place['view']) {
+       case 'avatar':
+               if (!file_exists("{$user->dir}/avatar.jpg")) {
+                       break;
+               }
                $avatar = sprintf(
                        '<img src="%s" alt="%s" />',
                        "/thumb/100/profile/{$user->login}/avatar.jpg",
@@ -22,7 +41,13 @@ foreach ($users as $user) {
                        '<figure>%s<figcaption>%s</figcaption></figure>',
                        $avatar, $name
                );
+               break;
+       default:
+               if ($user->admin) {
+                       $name .= ' <em>(beheerder)</em>';
+               }
        }
+
        print '<li>'.$name;
 }