|
|
## -*- coding: utf-8 -*-
|
|
|
<%namespace name="base" file="/base/base.mako"/>
|
|
|
|
|
|
<div class="panel panel-default">
|
|
|
<div class="panel-heading">
|
|
|
<h3 class="panel-title">
|
|
|
<i class="icon-user-group" title="${_('User group')}"></i>
|
|
|
${h.link_to_group(c.user_group.users_group_name)}
|
|
|
- ${_('Settings')}
|
|
|
</h3>
|
|
|
</div>
|
|
|
<div class="panel-body">
|
|
|
${h.secure_form(h.route_path('user_groups_update', user_group_id=c.user_group.users_group_id), id='edit_user_group', request=request)}
|
|
|
<div class="form">
|
|
|
<!-- fields -->
|
|
|
<div class="fields">
|
|
|
<div class="field">
|
|
|
<div class="label">
|
|
|
<label for="users_group_name">${_('Group name')}:</label>
|
|
|
</div>
|
|
|
<div class="input">
|
|
|
${h.text('users_group_name',class_='medium')}
|
|
|
</div>
|
|
|
</div>
|
|
|
|
|
|
<div class="field badged-field">
|
|
|
<div class="label">
|
|
|
<label for="user">${_('Owner')}:</label>
|
|
|
</div>
|
|
|
<div class="input">
|
|
|
<div class="badge-input-container">
|
|
|
<div class="user-badge">
|
|
|
${base.gravatar_with_user(c.user_group.user.email, show_disabled=not c.user_group.user.active)}
|
|
|
</div>
|
|
|
<div class="badge-input-wrap">
|
|
|
${h.text('user', class_="medium", autocomplete="off")}
|
|
|
</div>
|
|
|
</div>
|
|
|
<form:error name="user"/>
|
|
|
<p class="help-block">${_('Change owner of this user group.')}</p>
|
|
|
</div>
|
|
|
</div>
|
|
|
|
|
|
<div class="field">
|
|
|
<div class="label label-textarea">
|
|
|
<label for="user_group_description">${_('Description')}:</label>
|
|
|
</div>
|
|
|
<div class="textarea textarea-small editor">
|
|
|
${h.textarea('user_group_description',cols=23,rows=5,class_="medium")}
|
|
|
<span class="help-block">${_('Short, optional description for this user group.')}</span>
|
|
|
</div>
|
|
|
</div>
|
|
|
<div class="field">
|
|
|
<div class="label label-checkbox">
|
|
|
<label for="users_group_active">${_('Active')}:</label>
|
|
|
</div>
|
|
|
<div class="checkboxes">
|
|
|
${h.checkbox('users_group_active',value=True)}
|
|
|
</div>
|
|
|
</div>
|
|
|
|
|
|
<div class="field">
|
|
|
<div class="label label-checkbox">
|
|
|
<label for="users_group_active">${_('Add members')}:</label>
|
|
|
</div>
|
|
|
<div class="input">
|
|
|
${h.text('user_group_add_members', placeholder="user/usergroup", class_="medium")}
|
|
|
</div>
|
|
|
</div>
|
|
|
|
|
|
<input type="hidden" name="__start__" value="user_group_members:sequence"/>
|
|
|
<table id="group_members_placeholder" class="rctable group_members">
|
|
|
<tr>
|
|
|
<th>${_('Username')}</th>
|
|
|
<th>${_('Action')}</th>
|
|
|
</tr>
|
|
|
|
|
|
% if c.group_members_obj:
|
|
|
% for user in c.group_members_obj:
|
|
|
<tr>
|
|
|
<td id="member_user_${user.user_id}" class="td-author">
|
|
|
<div class="group_member">
|
|
|
${base.gravatar(user.email, 16, user=user, tooltip=True)}
|
|
|
<span class="username user">${h.link_to(h.person(user), h.route_path('user_edit',user_id=user.user_id))}</span>
|
|
|
<input type="hidden" name="__start__" value="member:mapping">
|
|
|
<input type="hidden" name="member_user_id" value="${user.user_id}">
|
|
|
<input type="hidden" name="type" value="existing" id="member_${user.user_id}">
|
|
|
<input type="hidden" name="__end__" value="member:mapping">
|
|
|
</div>
|
|
|
</td>
|
|
|
<td class="">
|
|
|
<div class="usergroup_member_remove action_button" onclick="removeUserGroupMember(${user.user_id}, true)" style="visibility: visible;">
|
|
|
<i class="icon-remove"></i>
|
|
|
</div>
|
|
|
</td>
|
|
|
</tr>
|
|
|
% endfor
|
|
|
|
|
|
% else:
|
|
|
<tr><td colspan="2">${_('No members yet')}</td></tr>
|
|
|
% endif
|
|
|
</table>
|
|
|
<input type="hidden" name="__end__" value="user_group_members:sequence"/>
|
|
|
|
|
|
<div class="buttons">
|
|
|
${h.submit('Save',_('Save'),class_="btn")}
|
|
|
</div>
|
|
|
</div>
|
|
|
</div>
|
|
|
${h.end_form()}
|
|
|
</div>
|
|
|
</div>
|
|
|
<script>
|
|
|
$(document).ready(function(){
|
|
|
$("#group_parent_id").select2({
|
|
|
'containerCssClass': "drop-menu",
|
|
|
'dropdownCssClass': "drop-menu-dropdown",
|
|
|
'dropdownAutoWidth': true
|
|
|
});
|
|
|
|
|
|
removeUserGroupMember = function(userId){
|
|
|
$('#member_'+userId).val('remove');
|
|
|
$('#member_user_'+userId).addClass('to-delete');
|
|
|
};
|
|
|
|
|
|
$('#user_group_add_members').autocomplete({
|
|
|
serviceUrl: pyroutes.url('user_autocomplete_data'),
|
|
|
minChars:2,
|
|
|
maxHeight:400,
|
|
|
width:300,
|
|
|
deferRequestBy: 300, //miliseconds
|
|
|
showNoSuggestionNotice: true,
|
|
|
params: { user_groups:true },
|
|
|
formatResult: autocompleteFormatResult,
|
|
|
lookupFilter: autocompleteFilterResult,
|
|
|
onSelect: function(element, suggestion){
|
|
|
|
|
|
function addMember(user, fromUserGroup) {
|
|
|
var gravatar = user.icon_link;
|
|
|
var username = user.value_display;
|
|
|
var userLink = pyroutes.url('user_edit', {"user_id": user.id});
|
|
|
var uid = user.id;
|
|
|
|
|
|
if (fromUserGroup) {
|
|
|
username = username +" "+ _gettext('(from usergroup {0})'.format(fromUserGroup))
|
|
|
}
|
|
|
|
|
|
var elem = $(
|
|
|
('<tr>'+
|
|
|
'<td id="member_user_{6}" class="td-author td-author-new-entry">'+
|
|
|
'<div class="group_member">'+
|
|
|
'<img class="gravatar" src="{0}" height="16" width="16">'+
|
|
|
'<span class="username user"><a href="{1}">{2}</a></span>'+
|
|
|
'<input type="hidden" name="__start__" value="member:mapping">'+
|
|
|
'<input type="hidden" name="member_user_id" value="{3}">'+
|
|
|
'<input type="hidden" name="type" value="new" id="member_{4}">'+
|
|
|
'<input type="hidden" name="__end__" value="member:mapping">'+
|
|
|
'</div>'+
|
|
|
'</td>'+
|
|
|
'<td class="td-author-new-entry">'+
|
|
|
'<div class="usergroup_member_remove action_button" onclick="removeUserGroupMember({5}, true)" style="visibility: visible;">'+
|
|
|
'<i class="icon-remove"></i>'+
|
|
|
'</div>'+
|
|
|
'</td>'+
|
|
|
'</tr>').format(gravatar, userLink, username,
|
|
|
uid, uid, uid, uid)
|
|
|
);
|
|
|
$('#group_members_placeholder').append(elem)
|
|
|
}
|
|
|
|
|
|
if (suggestion.value_type == 'user_group') {
|
|
|
$.getJSON(
|
|
|
pyroutes.url('user_group_members_data',
|
|
|
{'user_group_id': suggestion.id}),
|
|
|
function(data) {
|
|
|
$.each(data.members, function(idx, user) {
|
|
|
addMember(user, suggestion.value)
|
|
|
});
|
|
|
}
|
|
|
);
|
|
|
} else if (suggestion.value_type == 'user') {
|
|
|
addMember(suggestion, null);
|
|
|
}
|
|
|
}
|
|
|
});
|
|
|
|
|
|
|
|
|
UsersAutoComplete('user', '${c.rhodecode_user.user_id}');
|
|
|
})
|
|
|
</script>
|
|
|
|