X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/fad046d56740092b1483cb646d2f7c92c544c165..1e7906c193d37eb40c734b93a8d152d87650562c:/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 cd23556a4a..1fec3dcb95 100644 --- a/apps/workbench/app/assets/javascripts/select_modal.js +++ b/apps/workbench/app/assets/javascripts/select_modal.js @@ -1,14 +1,14 @@ $(document).on('click', '.selectable', function() { var any; var $this = $(this); - if (!$this.hasClass('multiple')) { - $this.closest('.selectable-container'). + var $container = $(this).closest('.selectable-container'); + if (!$container.hasClass('multiple')) { + $container. find('.selectable'). removeClass('active'); } $this.toggleClass('active'); - any = ($this. - closest('.selectable-container'). + any = ($container. find('.selectable.active').length > 0) $this. closest('.modal'). @@ -16,14 +16,19 @@ $(document).on('click', '.selectable', function() { prop('disabled', !any); if ($this.hasClass('active')) { + var no_preview_available = '
(No preview available)
'; + if (!$this.attr('data-preview-href')) { + $(".modal-dialog-preview-pane").html(no_preview_available); + return; + } $(".modal-dialog-preview-pane").html('
'); $.ajax($this.attr('data-preview-href'), {dataType: "html"}). - done(function(data, status, jqxhr) { + done(function(data, status, jqxhr) { $(".modal-dialog-preview-pane").html(data); }). fail(function(data, status, jqxhr) { - $(".modal-dialog-preview-pane").text('Preview load failed.'); + $(".modal-dialog-preview-pane").html(no_preview_available); }); } @@ -65,12 +70,72 @@ $(document).on('click', '.selectable', function() { $(document).trigger(event_name!=null ? event_name : 'page-refresh', [data, status, jqxhr, this.action_data]); }); -}); -$(document).on('page-refresh', function(event, data, status, jqxhr, action_data) { +}).on('click', '.chooser-show-project', function() { + var params = {}; + var project_uuid = $(this).attr('data-project-uuid'); + $(this).attr('href', '#'); // Skip normal click handler + if (project_uuid) { + params = {'filters[]': JSON.stringify(['owner_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'); +}).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(); });