summaryrefslogtreecommitdiffstats
path: root/auth/src/main/webapp/user/js/createUser.js
diff options
context:
space:
mode:
authorsukesh a c <sukeshac@huawei.com>2017-02-06 07:19:11 +0000
committersukesh a c <sukeshac@huawei.com>2017-02-06 07:20:21 +0000
commite87ba54b24808449fa43760cf57093c50a984bab (patch)
tree4d882eea414567d7dab868896adcb9693b868600 /auth/src/main/webapp/user/js/createUser.js
parenta0e2ca4635e0b97dd3d45dead14e7912576b2a24 (diff)
role UI changes
issue-id: OCS-188 Change-Id: I84a3bd6c7098ce927ae7f01324d43688594ec4f0 Signed-off-by: sukesh a c <sukeshac@huawei.com>
Diffstat (limited to 'auth/src/main/webapp/user/js/createUser.js')
-rw-r--r--auth/src/main/webapp/user/js/createUser.js123
1 files changed, 122 insertions, 1 deletions
diff --git a/auth/src/main/webapp/user/js/createUser.js b/auth/src/main/webapp/user/js/createUser.js
index 726d5993..71a8d566 100644
--- a/auth/src/main/webapp/user/js/createUser.js
+++ b/auth/src/main/webapp/user/js/createUser.js
@@ -16,12 +16,14 @@
$(document).ready(function() {
var USER_SERVICE = "/openoapi/auth/v1/users";
+ var ROLE_SERVICE = "/openoapi/auth/v1/roles";
var $userName = $("#userName");
var $password = $("#password");
var $cfPsdError = $("#cfPsdError");
var $userNameError = $("#userNameError");
var $passwordError = $("#passwordError");
-
+ var $rolesError = $("#rolesError");
+ var roleMap=[];
function initialPage() {
/*initial the event*/
$("#confirm").click(function(e) {
@@ -36,6 +38,110 @@ $(document).ready(function() {
$("#cancel").click(function(e) {
window.document.location = "/openoui/user/user.html";
})
+ //get and initialize roles
+ getRolesList().done(function(data) {
+ var data = formatRoles(data);
+ for (var i = 0; i < data.length; i++) {
+ var html = '<li><input type="checkbox" value="' + data[i].name + '"/>' + data[i].name + '</li>';
+ $('.mutliSelect ul').append(html);
+ }
+ })
+
+ //init listener
+ $(".dropdown dt a").on('click', function() {
+ $(".dropdown dd ul").slideToggle('fast');
+ });
+
+ $(".dropdown dd ul li a").on('click', function() {
+ $(".dropdown dd ul").hide();
+ });
+
+ function getSelectedValue(id) {
+ return $("#" + id).find("dt a span.value").html();
+ }
+
+ $(document).bind('click', function(e) {
+ var $clicked = $(e.target);
+ if (!$clicked.parents().hasClass("dropdown")) $(".dropdown dd ul").hide();
+ });
+
+ $('.mutliSelect input[type="checkbox"]').on('click', function() {
+ if($('.hida')[0].innerHTML=='Please select roles')
+ {
+ $('.hida')[0].innerHTML='';
+ }
+
+ var title;
+ if($('.multiSel').text() ==='')
+ {
+ title = $(this).closest('.mutliSelect').find('input[type="checkbox"]').val(),
+ title = $(this).val();
+ }
+ else
+ {
+ title = $(this).closest('.mutliSelect').find('input[type="checkbox"]').val(),
+ title ="," + $(this).val();
+
+ }
+ var oldText=$('.hida')[0].innerHTML;
+ if ($(this).is(':checked')) {
+ if(oldText.length>0)
+ {
+ $('.hida')[0].innerHTML=oldText+','+title;
+ }
+ else
+ {
+ $('.hida')[0].innerHTML=title;
+ }
+
+ } else {
+
+ var rolesData = oldText.split(',');
+ var rolesList='';
+ for (var i = 0; i < rolesData.length ; i++) {
+ if(title!=rolesData[i])
+ {
+ if(i==0 || rolesList.length==0 )
+ {
+ rolesList=rolesData[i];
+ }
+ else
+ {
+ rolesList=rolesList+','+rolesData[i];
+ }
+ }
+ }
+ if(rolesList.length ==0)
+ {
+ rolesList='Please select roles';
+ }
+ $('.hida')[0].innerHTML=rolesList;
+
+ }
+ });
+
+ }
+
+ function getRolesList() {
+ return Rest.http({
+ url: ROLE_SERVICE + "?=" + new Date().getTime(),
+ type: "GET",
+ async: false,
+ contentType: 'application/json',
+ dataType: "json"
+ })
+ }
+
+ function formatRoles(data) {
+ var rolesData = [];
+ for (var i = 0; i < data.roles.length; i++) {
+ var temp = {};
+ temp.roleid = data.roles[i].id;
+ temp.name = data.roles[i].name;
+ rolesData.push(temp);
+ roleMap[temp.name]=temp.roleid;
+ }
+ return rolesData;
}
function getCreateUser() {
@@ -44,6 +150,16 @@ $(document).ready(function() {
data.password = $password.val();
data.description = $("#description").val();
data.email = "xxxx@xxxx.com";
+ //get roles
+ var roles=[];
+ var rolesData = $('.hida').text().split(',');
+ for (var i = 0; i < rolesData.length ; i++) {
+ var temp = {};
+ temp.name=rolesData[i];
+ temp.id=roleMap[rolesData[i]];
+ roles.push(temp);
+ }
+ data.roles=roles;
return data;
}
@@ -87,6 +203,11 @@ $(document).ready(function() {
showError($passwordError, "Mandatory.");
return false;
}
+ if($('.hida')[0].innerHTML=='Please select roles')
+ {
+ showError($rolesError, "Mandatory.");
+ return false;
+ }
return true;
}