diff --git a/app/assets/javascripts/my_modules.js b/app/assets/javascripts/my_modules.js index 99f3c8859..f33e26897 100644 --- a/app/assets/javascripts/my_modules.js +++ b/app/assets/javascripts/my_modules.js @@ -290,8 +290,76 @@ function initTagsSelector() { }).getContainer(myModuleTagsSelector).addClass('my-module-tags-container'); } +function initAssignedUsersSelector() { + var manageUsersModal = null; + var manageUsersModalBody = null; + + // Initialize users editing modal remote loading + function initUsersEditLink() { + $('.task-details .manage-users-link').on('ajax:success', function(e, data) { + manageUsersModal.modal('show'); + manageUsersModal.find('#manage-module-users-modal-module').text(data.my_module.name); + initUsersModalBody(data); + }); + } + + // Initialize reloading manage user modal content after posting new user + function initAddUserForm() { + manageUsersModalBody.find('.add-user-form') + .on('ajax:success', function(e, data) { + initUsersModalBody(data); + }); + } + + // Initialize remove user from my_module links + function initRemoveUserLinks() { + manageUsersModalBody.find('.remove-user-link') + .on('ajax:success', function(e, data) { + initUsersModalBody(data); + }); + } + + // Initialize ajax listeners and elements style on modal body. + // This function must be called when modal body is changed. + function initUsersModalBody(data) { + manageUsersModalBody.html(data.html); + manageUsersModalBody.find('.selectpicker').selectpicker(); + initAddUserForm(); + initRemoveUserLinks(); + } + + manageUsersModal = $('#manage-module-users-modal'); + manageUsersModalBody = manageUsersModal.find('.modal-body'); + + // Reload users HTML element when modal is closed + manageUsersModal.on('hide.bs.modal', function() { + var usersEl = $('.task-assigned-users'); + // Load HTML to refresh users + $.ajax({ + url: usersEl.attr('data-module-users-url'), + type: 'GET', + dataType: 'json', + success: function(data) { + $('.task-assigned-users').replaceWith(data.html); + initUsersEditLink(); + }, + error: function() { + // TODO + } + }); + }); + + // Remove users modal content when modal window is closed. + manageUsersModal.on('hidden.bs.modal', function() { + manageUsersModalBody.html(''); + }); + + initUsersEditLink(); +} + applyTaskCompletedCallBack(); initTagsSelector(); bindEditTagsAjax(); initStartDatePicker(); initDueDatePicker(); +initAssignedUsersSelector(); diff --git a/app/assets/stylesheets/my_modules/protocols/index.scss b/app/assets/stylesheets/my_modules/protocols/index.scss index 3d541443e..4a7080031 100644 --- a/app/assets/stylesheets/my_modules/protocols/index.scss +++ b/app/assets/stylesheets/my_modules/protocols/index.scss @@ -57,7 +57,7 @@ .flex-block { align-items: center; display: flex; - line-height: 32px; + line-height: 34px; .flex-block-label { align-items: center; @@ -248,6 +248,20 @@ box-shadow: none; } } + + .task-assigned-users { + height: 34px; + + &:hover { + text-decoration: none; + } + } + + .assign-new-user { + background-color: $color-concrete; + color: $color-silver-chalice; + text-align: center; + } } .task-notes { diff --git a/app/controllers/user_my_modules_controller.rb b/app/controllers/user_my_modules_controller.rb index 61338902c..b72bdfe5a 100644 --- a/app/controllers/user_my_modules_controller.rb +++ b/app/controllers/user_my_modules_controller.rb @@ -19,6 +19,18 @@ class UserMyModulesController < ApplicationController end end + def index_compact + respond_to do |format| + format.json do + render json: { + html: render_to_string( + partial: 'index_compact.html.erb' + ) + } + end + end + end + def index_edit @user_my_modules = @my_module.user_my_modules @unassigned_users = @my_module.unassigned_users diff --git a/app/views/my_modules/_my_module_details.html.erb b/app/views/my_modules/_my_module_details.html.erb index 1639aac5d..47dfb22d1 100644 --- a/app/views/my_modules/_my_module_details.html.erb +++ b/app/views/my_modules/_my_module_details.html.erb @@ -27,6 +27,14 @@ +