users.html
145 lines
| 4.4 KiB
| text/html
|
HtmlLexer
r547 | ## -*- coding: utf-8 -*- | |||
<%inherit file="/base/base.html"/> | ||||
<%def name="title()"> | ||||
r619 | ${_('Users administration')} - ${c.rhodecode_name} | |||
r547 | </%def> | |||
<%def name="breadcrumbs_links()"> | ||||
r2658 | <input class="q_filter_box" id="q_filter" size="15" type="text" name="filter" value="${_('quick filter...')}"/> ${h.link_to(_('Admin'),h.url('admin_home'))} » <span id="user_count">0</span> ${_('users')} | |||
r547 | </%def> | |||
<%def name="page_nav()"> | ||||
${self.menu('admin')} | ||||
</%def> | ||||
<%def name="main()"> | ||||
<div class="box"> | ||||
<!-- box / title --> | ||||
<div class="title"> | ||||
r2658 | ${self.breadcrumbs()} | |||
r547 | <ul class="links"> | |||
<li> | ||||
Augusto Herrmann
|
r1472 | <span>${h.link_to(_(u'ADD NEW USER'),h.url('new_user'))}</span> | ||
r547 | </li> | |||
r1888 | </ul> | |||
r547 | </div> | |||
<!-- end box / title --> | ||||
r2658 | <div class="table yui-skin-sam" id="users_list_wrap"></div> | |||
<div id="user-paginator" style="padding: 0px 0px 0px 20px"></div> | ||||
r547 | </div> | |||
r2658 | ||||
<script> | ||||
var url = "${h.url('formatted_users', format='json')}"; | ||||
var data = ${c.data|n}; | ||||
var myDataSource = new YAHOO.util.DataSource(data); | ||||
myDataSource.responseType = YAHOO.util.DataSource.TYPE_JSON; | ||||
myDataSource.responseSchema = { | ||||
resultsList: "records", | ||||
fields: [ | ||||
{key: "gravatar"}, | ||||
{key: "raw_username"}, | ||||
{key: "username"}, | ||||
{key: "firstname"}, | ||||
{key: "lastname"}, | ||||
{key: "last_login"}, | ||||
{key: "active"}, | ||||
{key: "admin"}, | ||||
{key: "ldap"}, | ||||
{key: "action"}, | ||||
] | ||||
}; | ||||
myDataSource.doBeforeCallback = function(req,raw,res,cb) { | ||||
// This is the filter function | ||||
var data = res.results || [], | ||||
filtered = [], | ||||
i,l; | ||||
if (req) { | ||||
req = req.toLowerCase(); | ||||
for (i = 0; i<data.length; i++) { | ||||
var pos = data[i].raw_username.toLowerCase().indexOf(req) | ||||
if (pos != -1) { | ||||
filtered.push(data[i]); | ||||
} | ||||
} | ||||
res.results = filtered; | ||||
} | ||||
YUD.get('user_count').innerHTML = res.results.length; | ||||
return res; | ||||
} | ||||
// main table sorting | ||||
var myColumnDefs = [ | ||||
{key:"gravatar",label:"",sortable:false,}, | ||||
{key:"username",label:"${_('username')}",sortable:true, | ||||
sortOptions: { sortFunction: linkSort } | ||||
}, | ||||
{key:"firstname",label:"${_('firstname')}",sortable:true,}, | ||||
{key:"lastname",label:"${_('lastname')}",sortable:true,}, | ||||
{key:"last_login",label:"${_('last login')}",sortable:true,}, | ||||
{key:"active",label:"${_('active')}",sortable:true,}, | ||||
{key:"admin",label:"${_('admin')}",sortable:true,}, | ||||
{key:"ldap",label:"${_('ldap')}",sortable:true,}, | ||||
{key:"action",label:"${_('action')}",sortable:false}, | ||||
]; | ||||
var myDataTable = new YAHOO.widget.DataTable("users_list_wrap", myColumnDefs, myDataSource,{ | ||||
sortedBy:{key:"username",dir:"asc"}, | ||||
paginator: new YAHOO.widget.Paginator({ | ||||
rowsPerPage: 15, | ||||
alwaysVisible: false, | ||||
template : "{PreviousPageLink} {FirstPageLink} {PageLinks} {LastPageLink} {NextPageLink}", | ||||
pageLinks: 5, | ||||
containerClass: 'pagination-wh', | ||||
currentPageClass: 'pager_curpage', | ||||
pageLinkClass: 'pager_link', | ||||
nextPageLinkLabel: '>', | ||||
previousPageLinkLabel: '<', | ||||
firstPageLinkLabel: '<<', | ||||
lastPageLinkLabel: '>>', | ||||
containers:['user-paginator'] | ||||
}), | ||||
MSG_SORTASC:"${_('Click to sort ascending')}", | ||||
MSG_SORTDESC:"${_('Click to sort descending')}", | ||||
MSG_EMPTY:"${_('No records found.')}", | ||||
MSG_ERROR:"${_('Data error.')}", | ||||
MSG_LOADING:"${_('Loading...')}", | ||||
} | ||||
); | ||||
myDataTable.subscribe('postRenderEvent',function(oArgs) { | ||||
}); | ||||
var filterTimeout = null; | ||||
updateFilter = function () { | ||||
// Reset timeout | ||||
filterTimeout = null; | ||||
// Reset sort | ||||
var state = myDataTable.getState(); | ||||
state.sortedBy = {key:'username', dir:YAHOO.widget.DataTable.CLASS_ASC}; | ||||
// Get filtered data | ||||
myDataSource.sendRequest(YUD.get('q_filter').value,{ | ||||
success : myDataTable.onDataReturnInitializeTable, | ||||
failure : myDataTable.onDataReturnInitializeTable, | ||||
scope : myDataTable, | ||||
argument: state | ||||
}); | ||||
}; | ||||
YUE.on('q_filter','click',function(){ | ||||
YUD.get('q_filter').value = ''; | ||||
}); | ||||
YUE.on('q_filter','keyup',function (e) { | ||||
clearTimeout(filterTimeout); | ||||
filterTimeout = setTimeout(updateFilter,600); | ||||
}); | ||||
</script> | ||||
r547 | </%def> | |||