user_edit_my_account.html
278 lines
| 8.7 KiB
| text/html
|
HtmlLexer
r547 | ## -*- coding: utf-8 -*- | |||
<%inherit file="/base/base.html"/> | ||||
<%def name="title()"> | ||||
r619 | ${_('My account')} ${c.rhodecode_user.username} - ${c.rhodecode_name} | |||
r547 | </%def> | |||
<%def name="breadcrumbs_links()"> | ||||
${_('My Account')} | ||||
</%def> | ||||
<%def name="page_nav()"> | ||||
${self.menu('admin')} | ||||
</%def> | ||||
<%def name="main()"> | ||||
<div class="box box-left"> | ||||
<!-- box / title --> | ||||
<div class="title"> | ||||
r1888 | ${self.breadcrumbs()} | |||
r547 | </div> | |||
<!-- end box / title --> | ||||
r2353 | ${c.form|n} | |||
r1888 | </div> | |||
r547 | ||||
<div class="box box-right"> | ||||
<!-- box / title --> | ||||
<div class="title"> | ||||
r1888 | <h5> | |||
r2624 | <input class="q_filter_box" id="q_filter" size="15" type="text" name="filter" value="${_('quick filter...')}" style="display: none"/> | |||
r766 | </h5> | |||
r2624 | <ul class="links" style="color:#DADADA"> | |||
<li> | ||||
<span><a id="show_perms" class="link-white current" href="#perms">${_('My permissions')}</a> </span> | ||||
</li> | ||||
<li> | ||||
<span><a id="show_my" class="link-white" href="#my">${_('My repos')}</a> </span> | ||||
</li> | ||||
r766 | <li> | |||
r2886 | <span><a id="show_pullrequests" class="link-white" href="#pullrequests">${_('My pull requests')}</a> </span> | |||
r1888 | </li> | |||
r2624 | %if h.HasPermissionAny('hg.admin','hg.create.repository')(): | |||
<li> | ||||
<span>${h.link_to(_('Add repo'),h.url('admin_settings_create_repository'))}</span> | ||||
</li> | ||||
%endif | ||||
r1888 | </ul> | |||
r547 | </div> | |||
<!-- end box / title --> | ||||
r3154 | <div id="perms_container" class="table"> | |||
r2127 | %for section in sorted(c.rhodecode_user.permissions.keys()): | |||
<div class="perms_section_head">${section.replace("_"," ").capitalize()}</div> | ||||
r2129 | ||||
r2127 | <div id='tbl_list_wrap_${section}' class="yui-skin-sam"> | |||
<table id="tbl_list_${section}"> | ||||
<thead> | ||||
<tr> | ||||
<th class="left">${_('Name')}</th> | ||||
<th class="left">${_('Permission')}</th> | ||||
</thead> | ||||
<tbody> | ||||
%for k in c.rhodecode_user.permissions[section]: | ||||
r2131 | <% | |||
if section != 'global': | ||||
section_perm = c.rhodecode_user.permissions[section].get(k) | ||||
_perm = section_perm.split('.')[-1] | ||||
else: | ||||
_perm = section_perm = None | ||||
%> | ||||
%if _perm not in ['none']: | ||||
r2127 | <tr> | |||
r2128 | <td> | |||
%if section == 'repositories': | ||||
<a href="${h.url('summary_home',repo_name=k)}">${k}</a> | ||||
%elif section == 'repositories_groups': | ||||
<a href="${h.url('repos_group_home',group_name=k)}">${k}</a> | ||||
%else: | ||||
${k} | ||||
%endif | ||||
</td> | ||||
r2127 | <td> | |||
%if section == 'global': | ||||
r2128 | ${h.bool2icon(True)} | |||
r2127 | %else: | |||
r2131 | <span class="perm_tag ${_perm}">${section_perm}</span> | |||
r2127 | %endif | |||
</td> | ||||
</tr> | ||||
r2131 | %endif | |||
r2127 | %endfor | |||
</tbody> | ||||
</table> | ||||
</div> | ||||
%endfor | ||||
r547 | </div> | |||
r3154 | <div id="my_container" style="display:none"> | |||
<div class="table yui-skin-sam" id="repos_list_wrap"></div> | ||||
<div id="user-paginator" style="padding: 0px 0px 0px 20px"></div> | ||||
r2673 | </div> | |||
r3154 | <div id="pullrequests_container" class="table" style="display:none"> | |||
## loaded via AJAX | ||||
${_('Loading...')} | ||||
</div> | ||||
r547 | </div> | |||
r2722 | ||||
r1653 | <script type="text/javascript"> | |||
r2886 | ||||
var show_perms = function(e){ | ||||
YUD.addClass('show_perms', 'current'); | ||||
YUD.removeClass('show_my','current'); | ||||
YUD.removeClass('show_pullrequests','current'); | ||||
r2673 | ||||
r3154 | YUD.setStyle('my_container','display','none'); | |||
YUD.setStyle('pullrequests_container','display','none'); | ||||
YUD.setStyle('perms_container','display',''); | ||||
r2907 | YUD.setStyle('q_filter','display','none'); | |||
r2886 | } | |||
YUE.on('show_perms','click',function(e){ | ||||
show_perms(); | ||||
r2127 | }) | |||
r2886 | ||||
var show_my = function(e){ | ||||
r2624 | YUD.addClass('show_my', 'current'); | |||
YUD.removeClass('show_perms','current'); | ||||
YUD.removeClass('show_pullrequests','current'); | ||||
r2673 | ||||
r3154 | YUD.setStyle('perms_container','display','none'); | |||
YUD.setStyle('pullrequests_container','display','none'); | ||||
YUD.setStyle('my_container','display',''); | ||||
r2624 | YUD.setStyle('q_filter','display',''); | |||
r3154 | if(!YUD.hasClass('show_my', 'loaded')){ | |||
table_renderer(${c.data |n}); | ||||
YUD.addClass('show_my', 'loaded'); | ||||
} | ||||
r2886 | } | |||
YUE.on('show_my','click',function(e){ | ||||
show_my(e); | ||||
r2624 | }) | |||
r2886 | ||||
var show_pullrequests = function(e){ | ||||
r2624 | YUD.addClass('show_pullrequests', 'current'); | |||
YUD.removeClass('show_my','current'); | ||||
YUD.removeClass('show_perms','current'); | ||||
r3154 | YUD.setStyle('my_container','display','none'); | |||
YUD.setStyle('perms_container','display','none'); | ||||
YUD.setStyle('pullrequests_container','display',''); | ||||
r2624 | YUD.setStyle('q_filter','display','none'); | |||
r2907 | ||||
r2624 | var url = "${h.url('admin_settings_my_pullrequests')}"; | |||
r3154 | ypjax(url, 'pullrequests_container'); | |||
r2886 | } | |||
YUE.on('show_pullrequests','click',function(e){ | ||||
show_pullrequests(e) | ||||
r2127 | }) | |||
r2886 | var tabs = { | |||
'perms': show_perms, | ||||
'my': show_my, | ||||
'pullrequests': show_pullrequests | ||||
} | ||||
r2907 | var url = location.href.split('#'); | |||
if (url[1]) { | ||||
//We have a hash | ||||
r2886 | var tabHash = url[1]; | |||
r3120 | var func = tabs[tabHash] | |||
if (func){ | ||||
func(); | ||||
} | ||||
r2886 | } | |||
r3154 | function table_renderer(data){ | |||
var myDataSource = new YAHOO.util.DataSource(data); | ||||
myDataSource.responseType = YAHOO.util.DataSource.TYPE_JSON; | ||||
myDataSource.responseSchema = { | ||||
resultsList: "records", | ||||
fields: [ | ||||
{key:"menu"}, | ||||
{key:"raw_name"}, | ||||
{key:"name"}, | ||||
{key:"last_changeset"}, | ||||
{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_name.toLowerCase().indexOf(req) | ||||
if (pos != -1) { | ||||
filtered.push(data[i]); | ||||
} | ||||
} | ||||
res.results = filtered; | ||||
} | ||||
return res; | ||||
} | ||||
// main table sorting | ||||
var myColumnDefs = [ | ||||
{key:"menu",label:"",sortable:false,className:"quick_repo_menu hidden"}, | ||||
{key:"name",label:"${_('Name')}",sortable:true, | ||||
sortOptions: { sortFunction: nameSort }}, | ||||
{key:"last_changeset",label:"${_('Tip')}",sortable:true, | ||||
sortOptions: { sortFunction: revisionSort }}, | ||||
{key:"action",label:"${_('Action')}",sortable:false}, | ||||
]; | ||||
r2127 | ||||
r3154 | var myDataTable = new YAHOO.widget.DataTable("repos_list_wrap", myColumnDefs, myDataSource,{ | |||
sortedBy:{key:"name",dir:"asc"}, | ||||
paginator: new YAHOO.widget.Paginator({ | ||||
rowsPerPage: 50, | ||||
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) { | ||||
tooltip_activate(); | ||||
quick_repo_menu(); | ||||
}); | ||||
var filterTimeout = null; | ||||
r2127 | ||||
r3154 | updateFilter = function() { | |||
// Reset timeout | ||||
filterTimeout = null; | ||||
r2127 | ||||
r3154 | // Reset sort | |||
var state = myDataTable.getState(); | ||||
state.sortedBy = {key:'name', dir:YAHOO.widget.DataTable.CLASS_ASC}; | ||||
r2127 | ||||
r3154 | // Get filtered data | |||
myDataSource.sendRequest(YUD.get('q_filter').value,{ | ||||
success : myDataTable.onDataReturnInitializeTable, | ||||
failure : myDataTable.onDataReturnInitializeTable, | ||||
scope : myDataTable, | ||||
argument: state | ||||
}); | ||||
r2127 | ||||
r3154 | }; | |||
YUE.on('q_filter','click',function(){ | ||||
if(!YUD.hasClass('q_filter', 'loaded')){ | ||||
YUD.get('q_filter').value = ''; | ||||
//TODO: load here full list later to do search within groups | ||||
YUD.addClass('q_filter', 'loaded'); | ||||
} | ||||
}); | ||||
r2127 | ||||
r3154 | YUE.on('q_filter','keyup',function (e) { | |||
clearTimeout(filterTimeout); | ||||
filterTimeout = setTimeout(updateFilter,600); | ||||
}); | ||||
} | ||||
r1653 | </script> | |||
r1888 | </%def> | |||