X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/3f9aa0401350fc8a41a2dce81151da4aa050e771..b1d1c5acf6f237d5e2a02414dd59e92cdb862237:/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 a22b990e30..ba106d1110 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,11 +16,20 @@ $(document).on('click', '.selectable', function() { prop('disabled', !any); if ($this.hasClass('active')) { - $(".modal-dialog-preview-pane").html(''); - $.ajax($(this).attr('data-preview-href'), - {dataType: "html"}).done(function(data, status, jqxhr) { - $(".modal-dialog-preview-pane").html(data); - }); + 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) { + $(".modal-dialog-preview-pane").html(data); + }). + fail(function(data, status, jqxhr) { + $(".modal-dialog-preview-pane").html(no_preview_available); + }); } }).on('click', '.modal button[data-action-href]', function() { @@ -28,20 +37,28 @@ $(document).on('click', '.selectable', function() { var data = []; var $modal = $(this).closest('.modal'); var action_data = $(this).data('action-data'); + var action_data_from_params = $(this).data('action-data-from-params'); var selection_param = action_data.selection_param; $modal.find('.modal-error').removeClass('hide').hide(); $modal.find('.selectable.active[data-object-uuid]').each(function() { var val = $(this).attr('data-object-uuid'); data.push({name: selection_param, value: val}); }); - $.each(action_data, function(key, value) { - data.push({name: key, value: value}); - }); + $.each($.extend({}, action_data, action_data_from_params), + function(key, value) { + if (value instanceof Array && key[-1] != ']') { + for (var i in value) { + data.push({name: key + '[]', value: value[i]}); + } + } else { + data.push({name: key, value: value}); + } + }); $.ajax($(this).attr('data-action-href'), {dataType: 'json', type: $(this).attr('data-method'), data: data, - traditional: true, + traditional: false, context: {modal: $modal, action_data: action_data}}). fail(function(jqxhr, status, error) { if (jqxhr.readyState == 0 || jqxhr.status == 0) { @@ -61,9 +78,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': [['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-from-project-dropdown', 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(); });