knockout binding between available roles and user assigned roles

git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1230554 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Olivier Lamy 2012-01-12 14:12:18 +00:00
parent a429442f62
commit 82e113d72f
3 changed files with 51 additions and 24 deletions
archiva-modules/archiva-web/archiva-webapp-js/src/main/webapp/js/redback

View File

@ -259,15 +259,15 @@ $(function() {
ApplicationRoles = function(name,description,globalRoles,roleTemplates,resources){ ApplicationRoles = function(name,description,globalRoles,roleTemplates,resources){
//private String name; //private String name;
this.name = name; this.name = ko.observable(name);
//private String description; //private String description;
this.description = description; this.description = description? ko.observable(description):"";
//private Collection<String> globalRoles; //private Collection<String> globalRoles;
this.globalRoles = globalRoles; this.globalRoles = ko.observableArray(globalRoles);
//private Collection<RoleTemplate> roleTemplates; //private Collection<RoleTemplate> roleTemplates;
this.roleTemplates = roleTemplates; this.roleTemplates = ko.observableArray(roleTemplates);
//private Collection<String> resources; //private Collection<String> resources;
this.resources = resources; this.resources = ko.observableArray(resources);
} }
mapApplicationRoles=function(data){ mapApplicationRoles=function(data){
@ -280,17 +280,17 @@ $(function() {
RoleTemplate = function(id,namePrefix,delimiter,description,resource,roles){ RoleTemplate = function(id,namePrefix,delimiter,description,resource,roles){
//private String id; //private String id;
this.id = id; this.id = ko.observable(id);
//private String namePrefix; //private String namePrefix;
this.namePrefix = namePrefix; this.namePrefix = ko.observable(namePrefix);
//private String delimiter = " - "; //private String delimiter = " - ";
this.delimiter = delimiter; this.delimiter = ko.observable(delimiter);
//private String description; //private String description;
this.description = description; this.description = description? ko.observable(description):"";
//private String resource; //private String resource;
this.resource = resource; this.resource = ko.observable(resource);
//private List<String> roles; //private List<String> roles;
this.roles = roles; this.roles = ko.observableArray(roles);
} }
mapRoleTemplate = function(data){ mapRoleTemplate = function(data){

View File

@ -84,16 +84,38 @@
</div> </div>
</script> </script>
<script id="user_edit_roles_tmpl" type="text/x-jquery-tmpl"> <script id="user_view_roles_list_tmpl" type="text/x-jquery-tmpl">
<div class="page-header"> <div class="page-header">
<h3>${$.i18n.prop('effective.roles')}</h3> <h3>${$.i18n.prop('effective.roles')}</h3>
</div> </div>
<div> <div>
<ul> <ul>
{{each $data.user.assignedRoles}} {{each $data.user.assignedRoles}}
<li>${$value.name}</li> <li>${$value}</li>
{{/each}} {{/each}}
</ul> </ul>
</div> </div>
</script> </script>
<script id="user_edit_roles_tmpl" type="text/x-jquery-tmpl">
<div>
{{each $data.applicationRoles}}
<div class="page-header">
<h3>${$value.name}</h3>
</div>
<blockquote>
<p>${$value.description}</p>
</blockquote>
<ul>
{{each $value.globalRoles}}
<li><div><input type="checkbox" value="${$value}" data-bind="checked: user.assignedRoles" />&nbsp;${$value}</div></li>
{{/each}}
</ul>
{{/each}}
<button class="btn" data-bind="click:updateUserRoles">${$.i18n.prop('update')}</button>
</div>
</script>

View File

@ -118,9 +118,7 @@ $(function() {
window.redbackModel.createUser=false; window.redbackModel.createUser=false;
clearUserMessages(); clearUserMessages();
activateUsersEditTab(); activateUsersEditTab();
// if already created before $("#main-content #createUserForm").html(smallSpinnerImg());
//$("#main-content #createUserForm").accordion("destroy");
$("#main-content #createUserForm").html("");
$("#main-content #createUserForm").attr("data-bind",'template: {name:"redback/user-edit-tmpl",data: user}'); $("#main-content #createUserForm").attr("data-bind",'template: {name:"redback/user-edit-tmpl",data: user}');
var viewModel = new UserViewModel(user); var viewModel = new UserViewModel(user);
@ -160,13 +158,11 @@ $(function() {
dataType: 'json', dataType: 'json',
success: function(data) { success: function(data) {
var mappedRoles = $.map(data.role, function(item) { var mappedRoles = $.map(data.role, function(item) {
var r = mapRole(item); return item.name;
viewModel.user.assignedRoles.push(r);
return r;
}); });
viewModel.roles=mappedRoles; user.assignedRoles = ko.observableArray(mappedRoles);
$("#main-content #user-edit-roles-view").attr("data-bind",'template: {name:"user_edit_roles_tmpl"}'); $("#main-content #user-edit-roles-view").attr("data-bind",'template: {name:"user_view_roles_list_tmpl"}');
ko.applyBindings(viewModel,$("#user-edit-roles-view").get(0)); ko.applyBindings(viewModel,$("#user-edit-roles-view").get(0));
$("#main-content #edit_user_details_pills_headers").pills(); $("#main-content #edit_user_details_pills_headers").pills();
@ -186,17 +182,20 @@ $(function() {
} }
editUserRoles=function(user){ editUserRoles=function(user){
$.log("editUserRoles:"+user.username()); var viewModel = new UserViewModel(user);
$("#user-edit-roles-edit").html(smallSpinnerImg()); $("#user-edit-roles-edit").html(smallSpinnerImg());
$.ajax("restServices/redbackServices/roleManagementService/getApplicationRoles/"+encodeURIComponent(user.username()), { $.ajax("restServices/redbackServices/roleManagementService/getApplicationRoles/"+encodeURIComponent(user.username()), {
type: "GET", type: "GET",
dataType: 'json', dataType: 'json',
success: function(data) { success: function(data) {
$("#user-edit-roles-edit").html("loaded");
var mappedApplicationRoles = $.map(data.applicationRole, function(item) { var mappedApplicationRoles = $.map(data.applicationRole, function(item) {
return mapApplicationRoles(item); return mapApplicationRoles(item);
}); });
viewModel.applicationRoles=ko.observableArray(mappedApplicationRoles);
$.log("applicationRoles length:"+mappedApplicationRoles.length); $.log("applicationRoles length:"+mappedApplicationRoles.length);
$("#main-content #user-edit-roles-edit").attr("data-bind",'template: {name:"user_edit_roles_tmpl"}');
ko.applyBindings(viewModel,$("#main-content #user-edit-roles-edit").get(0));
$.log("assignedRoles:"+user.assignedRoles().length);
} }
} }
); );
@ -204,7 +203,13 @@ $(function() {
UserViewModel=function(user) { UserViewModel=function(user) {
this.user=user; this.user=user;
this.roles = ko.observableArray(new Array()); this.applicationRoles = ko.observableArray(new Array());
updateUserRoles=function(){
$.log("updateUserRoles assigned:"+this.user.assignedRoles().length);
}
} }
/** /**