| 1 | <?php | 
|---|
| 2 | /** | 
|---|
| 3 | * @package Dotclear | 
|---|
| 4 | * @subpackage Backend | 
|---|
| 5 | * | 
|---|
| 6 | * @copyright Olivier Meunier & Association Dotclear | 
|---|
| 7 | * @copyright GPL-2.0-only | 
|---|
| 8 | */ | 
|---|
| 9 |  | 
|---|
| 10 | require dirname(__FILE__) . '/../inc/admin/prepend.php'; | 
|---|
| 11 |  | 
|---|
| 12 | dcPage::checkSuper(); | 
|---|
| 13 |  | 
|---|
| 14 | # Creating filter combo boxes | 
|---|
| 15 | $sortby_combo = array( | 
|---|
| 16 | __('Username')          => 'user_id', | 
|---|
| 17 | __('Last Name')         => 'user_name', | 
|---|
| 18 | __('First Name')        => 'user_firstname', | 
|---|
| 19 | __('Display name')      => 'user_displayname', | 
|---|
| 20 | __('Number of entries') => 'nb_post' | 
|---|
| 21 | ); | 
|---|
| 22 |  | 
|---|
| 23 | $sortby_lex = array( | 
|---|
| 24 | // key in sorty_combo (see above) => field in SQL request | 
|---|
| 25 | 'user_id'          => 'U.user_id', | 
|---|
| 26 | 'user_name'        => 'user_name', | 
|---|
| 27 | 'user_firstname'   => 'user_firstname', | 
|---|
| 28 | 'user_displayname' => 'user_displayname'); | 
|---|
| 29 |  | 
|---|
| 30 | $order_combo = array( | 
|---|
| 31 | __('Descending') => 'desc', | 
|---|
| 32 | __('Ascending')  => 'asc' | 
|---|
| 33 | ); | 
|---|
| 34 |  | 
|---|
| 35 | # Actions combo box | 
|---|
| 36 | $combo_action = array( | 
|---|
| 37 | __('Set permissions') => 'blogs', | 
|---|
| 38 | __('Delete')          => 'deleteuser' | 
|---|
| 39 | ); | 
|---|
| 40 |  | 
|---|
| 41 | # --BEHAVIOR-- adminUsersActionsCombo | 
|---|
| 42 | $core->callBehavior('adminUsersActionsCombo', array(&$combo_action)); | 
|---|
| 43 |  | 
|---|
| 44 | $show_filters = false; | 
|---|
| 45 |  | 
|---|
| 46 | #?Get users | 
|---|
| 47 | $page        = !empty($_GET['page']) ? max(1, (integer) $_GET['page']) : 1; | 
|---|
| 48 | $nb_per_page = 30; | 
|---|
| 49 |  | 
|---|
| 50 | if (!empty($_GET['nb']) && (integer) $_GET['nb'] > 0) { | 
|---|
| 51 | if ($nb_per_page != (integer) $_GET['nb']) { | 
|---|
| 52 | $show_filters = true; | 
|---|
| 53 | } | 
|---|
| 54 | $nb_per_page = (integer) $_GET['nb']; | 
|---|
| 55 | } | 
|---|
| 56 |  | 
|---|
| 57 | $q      = !empty($_GET['q']) ? $_GET['q'] : ''; | 
|---|
| 58 | $sortby = !empty($_GET['sortby']) ? $_GET['sortby'] : 'user_id'; | 
|---|
| 59 | $order  = !empty($_GET['order']) ? $_GET['order'] : 'asc'; | 
|---|
| 60 |  | 
|---|
| 61 | $params['limit'] = array((($page - 1) * $nb_per_page), $nb_per_page); | 
|---|
| 62 |  | 
|---|
| 63 | # - Search filter | 
|---|
| 64 | if ($q) { | 
|---|
| 65 | $params['q']  = $q; | 
|---|
| 66 | $show_filters = true; | 
|---|
| 67 | } | 
|---|
| 68 |  | 
|---|
| 69 | # - Sortby and order filter | 
|---|
| 70 | if ($sortby !== '' && in_array($sortby, $sortby_combo, true)) { | 
|---|
| 71 | if (array_key_exists($sortby, $sortby_lex)) { | 
|---|
| 72 | $params['order'] = $core->con->lexFields($sortby_lex[$sortby]); | 
|---|
| 73 | } else { | 
|---|
| 74 | $params['order'] = $sortby; | 
|---|
| 75 | } | 
|---|
| 76 | if ($order !== '' && in_array($order, $order_combo, true)) { | 
|---|
| 77 | $params['order'] .= ' ' . $order; | 
|---|
| 78 | } else { | 
|---|
| 79 | $order = 'asc'; | 
|---|
| 80 | } | 
|---|
| 81 | } else { | 
|---|
| 82 | $sortby = 'user_id'; | 
|---|
| 83 | $order  = 'asc'; | 
|---|
| 84 | } | 
|---|
| 85 | if ($sortby != 'user_id' || $order != 'asc') { | 
|---|
| 86 | $show_filters = true; | 
|---|
| 87 | } | 
|---|
| 88 |  | 
|---|
| 89 | # Get users | 
|---|
| 90 | try { | 
|---|
| 91 | $rs       = $core->getUsers($params); | 
|---|
| 92 | $counter  = $core->getUsers($params, 1); | 
|---|
| 93 | $rsStatic = $rs->toStatic(); | 
|---|
| 94 | if ($sortby != 'nb_post') { | 
|---|
| 95 | // Sort user list using lexical order if necessary | 
|---|
| 96 | $rsStatic->extend('rsExtUser'); | 
|---|
| 97 | $rsStatic = $rsStatic->toExtStatic(); | 
|---|
| 98 | $rsStatic->lexicalSort($sortby, $order); | 
|---|
| 99 | } | 
|---|
| 100 | $user_list = new adminUserList($core, $rsStatic, $counter->f(0)); | 
|---|
| 101 | } catch (Exception $e) { | 
|---|
| 102 | $core->error->add($e->getMessage()); | 
|---|
| 103 | } | 
|---|
| 104 |  | 
|---|
| 105 | /* DISPLAY | 
|---|
| 106 | -------------------------------------------------------- */ | 
|---|
| 107 |  | 
|---|
| 108 | dcPage::open(__('Users'), | 
|---|
| 109 | dcPage::jsLoad('js/_users.js') . dcPage::jsFilterControl($show_filters), | 
|---|
| 110 | dcPage::breadcrumb( | 
|---|
| 111 | array( | 
|---|
| 112 | __('System') => '', | 
|---|
| 113 | __('Users')  => '' | 
|---|
| 114 | )) | 
|---|
| 115 | ); | 
|---|
| 116 |  | 
|---|
| 117 | if (!$core->error->flag()) { | 
|---|
| 118 | if (!empty($_GET['del'])) { | 
|---|
| 119 | dcPage::message(__('User has been successfully removed.')); | 
|---|
| 120 | } | 
|---|
| 121 | if (!empty($_GET['upd'])) { | 
|---|
| 122 | dcPage::message(__('The permissions have been successfully updated.')); | 
|---|
| 123 | } | 
|---|
| 124 |  | 
|---|
| 125 | echo | 
|---|
| 126 | '<p class="top-add"><strong><a class="button add" href="' . $core->adminurl->get("admin.user") . '">' . __('New user') . '</a></strong></p>' . | 
|---|
| 127 | '<form action="' . $core->adminurl->get("admin.users") . '" method="get" id="filters-form">' . | 
|---|
| 128 | '<h3 class="out-of-screen-if-js">' . __('Show filters and display options') . '</h3>' . | 
|---|
| 129 |  | 
|---|
| 130 | '<div class="table">' . | 
|---|
| 131 | '<div class="cell">' . | 
|---|
| 132 | '<h4>' . __('Filters') . '</h4>' . | 
|---|
| 133 | '<p><label for="q" class="ib">' . __('Search:') . '</label> ' . | 
|---|
| 134 | form::field('q', 20, 255, html::escapeHTML($q)) . '</p>' . | 
|---|
| 135 | '</div>' . | 
|---|
| 136 |  | 
|---|
| 137 | '<div class="cell filters-options">' . | 
|---|
| 138 | '<h4>' . __('Display options') . '</h4>' . | 
|---|
| 139 | '<p><label for="sortby" class="ib">' . __('Order by:') . '</label> ' . | 
|---|
| 140 | form::combo('sortby', $sortby_combo, $sortby) . '</p> ' . | 
|---|
| 141 | '<p><label for="order" class="ib">' . __('Sort:') . '</label> ' . | 
|---|
| 142 | form::combo('order', $order_combo, $order) . '</p>' . | 
|---|
| 143 | '<p><span class="label ib">' . __('Show') . '</span> <label for="nb" class="classic">' . | 
|---|
| 144 | form::number('nb', 0, 999, $nb_per_page) . ' ' . __('users per page') . '</label></p> ' . | 
|---|
| 145 | '</div>' . | 
|---|
| 146 | '</div>' . | 
|---|
| 147 |  | 
|---|
| 148 | '<p><input type="submit" value="' . __('Apply filters and display options') . '" />' . | 
|---|
| 149 | '<br class="clear" /></p>' . //Opera sucks | 
|---|
| 150 | '</form>'; | 
|---|
| 151 |  | 
|---|
| 152 | # Show users | 
|---|
| 153 | $user_list->display($page, $nb_per_page, | 
|---|
| 154 | '<form action="' . $core->adminurl->get("admin.user.actions") . '" method="post" id="form-users">' . | 
|---|
| 155 |  | 
|---|
| 156 | '%s' . | 
|---|
| 157 |  | 
|---|
| 158 | '<div class="two-cols">' . | 
|---|
| 159 | '<p class="col checkboxes-helpers"></p>' . | 
|---|
| 160 |  | 
|---|
| 161 | '<p class="col right"><label for="action" class="classic">' . | 
|---|
| 162 | __('Selected users action:') . ' ' . | 
|---|
| 163 | form::combo('action', $combo_action) . | 
|---|
| 164 | '</label> ' . | 
|---|
| 165 | '<input id="do-action" type="submit" value="' . __('ok') . '" />' . | 
|---|
| 166 | form::hidden(array('q'), html::escapeHTML($q)) . | 
|---|
| 167 | form::hidden(array('sortby'), $sortby) . | 
|---|
| 168 | form::hidden(array('order'), $order) . | 
|---|
| 169 | form::hidden(array('page'), $page) . | 
|---|
| 170 | form::hidden(array('nb'), $nb_per_page) . | 
|---|
| 171 | $core->formNonce() . | 
|---|
| 172 | '</p>' . | 
|---|
| 173 | '</div>' . | 
|---|
| 174 | '</form>', | 
|---|
| 175 | $show_filters | 
|---|
| 176 | ); | 
|---|
| 177 | } | 
|---|
| 178 | dcPage::helpBlock('core_users'); | 
|---|
| 179 | dcPage::close(); | 
|---|