plug_adminusers.php 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. <?php
  2. if (!class_exists("plug_adminusers")) {
  3. class plug_adminusers {
  4. function __construct($ns) {
  5. $this->title = __("adminusers", "dagsopt");
  6. $this->pluginname = $ns->pluginname;
  7. $this->file = $ns->file;
  8. $this->ns = $ns;
  9. }
  10. function start() {
  11. add_filter('manage_users_custom_column', array(&$this, 'imel_custom_column_userfield'), 12, 3);
  12. add_filter('manage_users_columns', array(&$this, 'imel_column_userfield'), 12, 1);
  13. add_filter('manage_users_sortable_columns', array(&$this, 'user_sortable_columns'), 14, 1);
  14. if (is_admin()) {
  15. //prolly not necessary, but I do want to be sure this only runs within the admin
  16. add_action('pre_user_query', array(&$this, 'my_user_query'));
  17. }
  18. }
  19. function help() {
  20. ?>
  21. <?php echo (__("Adds adminusers functions", "dagsopt")) ?>
  22. <?php
  23. }
  24. function Option($pre) {
  25. // update_option($pre . '_support_splash', $_POST[$pre . '_support_splash']);
  26. }
  27. function admin_line($pre) {
  28. ?>
  29. <hr>
  30. <?php
  31. }
  32. function imel_column_userfield($defaults) {
  33. $defaults['lastlogin'] = __('Seneste Login', 'lastlogin-column');
  34. $defaults['lastview'] = __('Sidst set', 'lastlogin-column');
  35. $defaults['proselect'] = __('Pro/Select', 'user-column');
  36. $defaults['gruppe'] = __('Gruppe', 'id-column');
  37. $defaults['navn'] = __('Navn', 'navn-column');
  38. $defaults['session'] = __('Sessions', 'session-column');
  39. $defaults['id'] = __('id', 'id-column');
  40. return $defaults;
  41. }
  42. function imel_custom_column_userfield($value, $column_name, $id) {
  43. if ($column_name == 'lastlogin') {
  44. $ss = get_user_meta($id, 'last_login', true);
  45. if ($ss) {
  46. $the_login_date = human_time_diff($ss);
  47. return $the_login_date;
  48. } else {
  49. return " ";
  50. }
  51. }
  52. if ($column_name == 'lastview') {
  53. $ss = get_user_meta($id, 'last_view', true);
  54. if ($ss) {
  55. $the_login_date = human_time_diff($ss);
  56. return $the_login_date;
  57. } else {
  58. return " ";
  59. }
  60. }
  61. if ($column_name == 'proselect') {
  62. $s = get_user_meta($id, 'Proselect', true);
  63. return $s;
  64. }
  65. if ($column_name == 'gruppe') {
  66. $s = get_user_meta($id, 'Gruppe', true);
  67. return $s;
  68. }
  69. if ($column_name == 'id') {
  70. return $id;
  71. }
  72. if ($column_name == 'navn') {
  73. return get_user_meta($id, 'Navn', true);
  74. }
  75. if ($column_name == 'session') {
  76. $ss = get_user_meta($id, 'session_tokens', true);
  77. if ($ss) {
  78. $s = "";
  79. $i = 0;
  80. foreach ($ss as $name => $obj) {
  81. if ($i < 2) {
  82. $s .= human_time_diff($obj['login']) . " ";
  83. }
  84. $i++;
  85. }
  86. return count($ss) . ' | ' . $s . '';
  87. } else {
  88. return "N";
  89. }
  90. }
  91. return $value;
  92. }
  93. function user_sortable_columns($columns) {
  94. $columns['session'] = 'session';
  95. $columns['id'] = 'id';
  96. $columns['gruppe'] = 'gruppe';
  97. $columns['proselect'] = 'proselect';
  98. $columns['lastlogin'] = 'lastlogin';
  99. $columns['lastview'] = 'lastview';
  100. return $columns;
  101. }
  102. function my_user_query($userquery) {
  103. if ('session' == $userquery->query_vars['orderby']) {
  104. global $wpdb;
  105. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  106. $userquery->query_where .= " AND alias.meta_key = 'session_tokens' "; //which meta are we sorting with?
  107. $userquery->query_orderby = " ORDER BY length(alias.meta_value) " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  108. }
  109. if ('proselect' == $userquery->query_vars['orderby']) {
  110. global $wpdb;
  111. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  112. $userquery->query_where .= " AND alias.meta_key = 'Proselect' "; //which meta are we sorting with?
  113. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  114. }
  115. if ('gruppe' == $userquery->query_vars['orderby']) {
  116. global $wpdb;
  117. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  118. $userquery->query_where .= " AND alias.meta_key = 'Gruppe' "; //which meta are we sorting with?
  119. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  120. }
  121. if ('lastlogin' == $userquery->query_vars['orderby']) {
  122. global $wpdb;
  123. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  124. $userquery->query_where .= " AND alias.meta_key = 'last_login' "; //which meta are we sorting with?
  125. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  126. }
  127. if ('lastview' == $userquery->query_vars['orderby']) {
  128. global $wpdb;
  129. $userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  130. $userquery->query_where .= " AND alias.meta_key = 'last_view' "; //which meta are we sorting with?
  131. $userquery->query_orderby = " ORDER BY alias.meta_value " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  132. }
  133. if ('id' == $userquery->query_vars['orderby']) {
  134. global $wpdb;
  135. //$userquery->query_from .= " LEFT OUTER JOIN $wpdb->usermeta AS alias ON ($wpdb->users.ID = alias.user_id) "; //note use of alias
  136. //$userquery->query_where .= " AND alias.meta_key = 'session_tokens' "; //which meta are we sorting with?
  137. $userquery->query_orderby = " ORDER BY ID " . ($userquery->query_vars["order"] == "ASC" ? "asc " : "desc "); //set sort order
  138. }
  139. }
  140. }
  141. global $plug_adminusers;
  142. $plug_adminusers = new plug_adminusers($this);
  143. $this->dagsopt['plug_adminusers'] = $plug_adminusers;
  144. }