X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/83561af02e156758b09ea771510ad4f9ee506b06..e824ef364a6efd3c02bce159973f4098d794865c:/apps/workbench/app/assets/javascripts/select_modal.js diff --git a/apps/workbench/app/assets/javascripts/select_modal.js b/apps/workbench/app/assets/javascripts/select_modal.js index 7c723236a0..1fec3dcb95 100644 --- a/apps/workbench/app/assets/javascripts/select_modal.js +++ b/apps/workbench/app/assets/javascripts/select_modal.js @@ -72,21 +72,70 @@ $(document).on('click', '.selectable', function() { }); }).on('click', '.chooser-show-project', function() { var params = {}; + var project_uuid = $(this).attr('data-project-uuid'); $(this).attr('href', '#'); // Skip normal click handler - if ($(this).attr('data-project-uuid')) { + if (project_uuid) { params = {'filters[]': JSON.stringify(['owner_uuid', '=', - $(this).attr('data-project-uuid')])}; + project_uuid]), + project_uuid: project_uuid + }; } + // Use current selection as dropdown button label + $(this). + closest('.dropdown-menu'). + prev('button'). + html($(this).text() + ' '); + // Set (or unset) filter params and refresh filterable rows $($(this).closest('[data-filterable-target]').attr('data-filterable-target')). data('infinite-content-params', params). trigger('refresh-content'); -}); -$(document).on('page-refresh', function(event, data, status, jqxhr, action_data) { +}).on('ready', function() { + $('form[data-search-modal] a').on('click', function() { + $(this).closest('form').submit(); + return false; + }); + $('form[data-search-modal]').on('submit', function() { + // Ask the server for a Search modal. When it arrives, copy + // the search string from the top nav input into the modal's + // search query field. + var $form = $(this); + var searchq = $form.find('input').val(); + var is_a_uuid = /^([0-9a-f]{32}(\+\S+)?|[0-9a-z]{5}-[0-9a-z]{5}-[0-9a-z]{15})$/; + if (searchq.trim().match(is_a_uuid)) { + window.location = '/actions?uuid=' + encodeURIComponent(searchq.trim()); + // Show the "loading" indicator. TODO: better page transition hook + $(document).trigger('ajax:send'); + return false; + } + if ($form.find('a[data-remote]').length > 0) { + // A search dialog is already loading. + return false; + } + $(''). + attr('href', $form.attr('data-search-modal')). + attr('data-remote', 'true'). + attr('data-method', 'GET'). + hide(). + appendTo($form). + on('ajax:success', function(data, status, xhr) { + $('body > .modal-container input[type=text]'). + val($form.find('input').val()). + focus(); + $form.find('input').val(''); + }).on('ajax:complete', function() { + $(this).detach(); + }). + click(); + return false; + }); +}).on('page-refresh', function(event, data, status, jqxhr, action_data) { window.location.reload(); }).on('tab-refresh', function(event, data, status, jqxhr, action_data) { $(document).trigger('arv:pane:reload:all'); $('body > .modal-container .modal').modal('hide'); }).on('redirect-to-created-object', function(event, data, status, jqxhr, action_data) { window.location.href = data.href.replace(/^[^\/]*\/\/[^\/]*/, ''); +}).on('shown.bs.modal', 'body > .modal-container .modal', function() { + $('.focus-on-display', this).focus(); });