X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/b1f65fcd4fa5fca5400f63fa25823fef6229a158..13ac0cadc7b65d2ab5ba3b3919dc55d06b85c3d5:/apps/workbench/app/assets/javascripts/filterable.js diff --git a/apps/workbench/app/assets/javascripts/filterable.js b/apps/workbench/app/assets/javascripts/filterable.js index cd01f64a74..bf859c350a 100644 --- a/apps/workbench/app/assets/javascripts/filterable.js +++ b/apps/workbench/app/assets/javascripts/filterable.js @@ -1,3 +1,7 @@ +// Copyright (C) The Arvados Authors. All rights reserved. +// +// SPDX-License-Identifier: AGPL-3.0 + // filterable.js shows/hides content when the user operates // search/select widgets. For "infinite scroll" content, it passes the // filters to the server and retrieves new content. For other content, @@ -37,6 +41,11 @@ // data-example-attr="foo" are shown, and all others are hidden. When // the user selects the "Show all" option, all rows are shown. // +// +// +// Merges on- or off-value with other params in query. Only works with +// infinite-scroll. +// // Notes: // // When multiple filterable-control widgets operate on the same @@ -52,7 +61,8 @@ function updateFilterableQueryNow($target) { var newquery = $target.data('filterable-query-new'); var params = $target.data('infinite-content-params-filterable') || {}; - params.filters = [['any', 'ilike', '%' + newquery + '%']]; + params.filters = ilike_filters(newquery); + $(".modal-dialog-preview-pane").html(""); $target.data('infinite-content-params-filterable', params); $target.data('filterable-query', newquery); } @@ -82,7 +92,23 @@ $(document). updateFilterableQueryNow($(this)); }); }). + on('change', 'input[type=checkbox].filterable-control', function(e) { + if (this != e.target) return; + var $target = $($(this).attr('data-filterable-target')); + var currentquery = $target.data('filterable-query'); + if (currentquery === undefined) currentquery = ''; + if ($target.is('[data-infinite-scroller]')) { + var datakey = 'infiniteContentParamsFrom'+this.id; + var whichvalue = $(this).is(':checked') ? 'on-value' : 'off-value'; + if (JSON.stringify($target.data(datakey)) == JSON.stringify($(this).data(whichvalue))) + return; + $target.data(datakey, $(this).data(whichvalue)); + updateFilterableQueryNow($target); + $target.trigger('refresh-content'); + } + }). on('paste keyup input', 'input[type=text].filterable-control', function(e) { + var regexp; if (this != e.target) return; var $target = $($(this).attr('data-filterable-target')); var currentquery = $target.data('filterable-query'); @@ -113,9 +139,20 @@ $(document). } else { // Target does not have infinite-scroll capability. Just // filter the rows in the browser using a RegExp. + regexp = undefined; + try { + regexp = new RegExp($(this).val(), 'i'); + } catch(e) { + if (e instanceof SyntaxError) { + // Invalid/partial regexp. See 'has-error' below. + } else { + throw e; + } + } $target. + toggleClass('has-error', regexp === undefined). addClass('filterable-container'). - data('q', new RegExp($(this).val(), 'i')). + data('q', regexp). trigger('refresh'); } }).on('refresh', '.filterable-container', function() {