diff --git a/fec/fec/static/js/modules/typeahead.js b/fec/fec/static/js/modules/typeahead.js index 1dc2e3f5c..135bd5687 100644 --- a/fec/fec/static/js/modules/typeahead.js +++ b/fec/fec/static/js/modules/typeahead.js @@ -76,11 +76,18 @@ function getUrl_names(resource) { } function getUrl_legal(resource) { + // Which parameters do we know we're going to query? + const queryParams = { + api_key: window.API_KEY_PUBLIC + }; + + // If there's a doc_type, let's add that to the query + const docTypeInput = document.querySelector('input[name="doc_type"]'); + if (docTypeInput && docTypeInput.value != '') queryParams.doc_type = docTypeInput.value; + return URI(window.API_LOCATION) .path([window.API_VERSION, 'legal', resource, encodeURIComponent('%QUERY')].join('/')) - .query({ - api_key: window.API_KEY_PUBLIC - }) + .query(queryParams) .readable(); } @@ -342,6 +349,42 @@ const aoStatutoryCitationDataset = { } }; +const caseRegulatoryCitationDataset = { + name: 'caseRegulatoryCitation', + display: 'name', + limit: 10, + source: citationRegulationEngine, + templates: { + header: 'Select a citation:', + pending: + 'Loading citations…', + notFound: compileHBS(''), // This has to be empty to not show anything + suggestion: function(datum) { + return ( + '' + datum.name + '' + ); + } + } +}; + +const caseStatutoryCitationDataset = { + name: 'caseStatutoryCitation', + display: 'name', + limit: 10, + source: citationStatuteEngine, + templates: { + header: 'Select a citation:', + pending: + 'Loading citations…', + notFound: compileHBS(''), // This has to be empty to not show anything + suggestion: function(datum) { + return ( + '' + datum.name + '' + ); + } + } +}; + export const datasets = { candidates: candidateDataset, committees: committeeDataset, @@ -350,6 +393,8 @@ export const datasets = { regulations: regulationDataset, aoRegulatoryCitations: aoRegulatoryCitationDataset, aoStatutoryCitations: aoStatutoryCitationDataset, + caseRegulatoryCitations: caseRegulatoryCitationDataset, + caseStatutoryCitations: caseStatutoryCitationDataset, allData: [candidateDataset, committeeDataset], all: [candidateDataset, committeeDataset, individualDataset, siteDataset, legalDataset] }; diff --git a/fec/legal/templates/layouts/legal-doc-search-results.jinja b/fec/legal/templates/layouts/legal-doc-search-results.jinja index 9e315f138..1ea8e6c00 100644 --- a/fec/legal/templates/layouts/legal-doc-search-results.jinja +++ b/fec/legal/templates/layouts/legal-doc-search-results.jinja @@ -100,7 +100,8 @@ const tag = this.getAttribute('data-tag'); const url = new URL(window.location); - // Remove tags logic + // "Remove tags" logic + // Assigns a URL to each remove/"⤫" button that removes its own value from the URL if (tag === 'query') { url.searchParams.delete('search'); url.searchParams.delete('search_exclude'); @@ -135,6 +136,32 @@ } else if (tag && tag == 'secondary_subject_id') { // Check if tag is not null or undefined // Remove 'secondary_subject_id' from the URL url.searchParams.delete('secondary_subject_id'); + } else if (tag && tag == 'case_citation_require_all') { + url.searchParams.delete('case_citation_require_all'); + } else if (tag && tag.startsWith('case_regulatory_citation')) { + // Get the 0-indexed position of this item + const index = tag.split('_').at(-1); + // Hold all the case_regulatory_citation from the URL + const citations = url.searchParams.getAll('case_regulatory_citation'); + // Remove all of the case_regulatory_citation from the URL + url.searchParams.delete('case_regulatory_citation'); + // For all of the held citations, + citations.forEach((cite, i) => { + // Add all but this element back to the URL + if (i != index) url.searchParams.append('case_regulatory_citation', cite); + }); + } else if (tag && tag.startsWith('case_statutory_citation')) { + // Get the 0-indexed position of this item + const index = tag.split('_').at(-1); + // Hold all the case_statutory_citation from the URL + const citations = url.searchParams.getAll('case_statutory_citation'); + // Remove all of the case_statutory_citation from the URL + url.searchParams.delete('case_statutory_citation'); + // For all of the held citations, + citations.forEach((cite, i) => { + // Add all but this element back to the URL + if (i != index) url.searchParams.append('case_statutory_citation', cite); + }); } else { url.searchParams.delete(tag); } diff --git a/fec/legal/templates/legal-search-results-advisory_opinions.jinja b/fec/legal/templates/legal-search-results-advisory_opinions.jinja index e5d446b59..a800cc473 100644 --- a/fec/legal/templates/legal-search-results-advisory_opinions.jinja +++ b/fec/legal/templates/legal-search-results-advisory_opinions.jinja @@ -49,10 +49,10 @@
- - - - + + + + {{ typeahead.field('ao_regulatory_citation', 'Regulatory citation', False, dataset='aoRegulatoryCitations', allow_text=False) }} {{ typeahead.field('ao_statutory_citation', 'Statutory citation', False, dataset='aoStatutoryCitations', allow_text=False) }}
diff --git a/fec/legal/templates/legal-search-results-murs.jinja b/fec/legal/templates/legal-search-results-murs.jinja index 3cdb89742..c13c6bc71 100644 --- a/fec/legal/templates/legal-search-results-murs.jinja +++ b/fec/legal/templates/legal-search-results-murs.jinja @@ -2,6 +2,7 @@ {% import 'macros/legal.jinja' as legal %} {% import 'macros/filters/checkbox.jinja' as checkbox %} {% import 'macros/filters/dropdown-json.jinja' as dropdown %} +{% import 'macros/filters/typeahead-filter.jinja' as typeahead %} {% set document_type_display_name = 'Closed Matters Under Review' %} {% block header %} @@ -12,8 +13,9 @@ {% block filters %} +
- {{ legal.keyword_search(result_type, query) }} +
@@ -22,61 +24,50 @@
-
+
+ +
+ + +
+ {{ legal.keyword_search(result_type, query) }} + +
Document Type {% for category_id, category_label in mur_document_categories.items() %}
- - + +
{% endfor %} -
-
- Document date range -
-
- - -
-
-
-
- - -
-
-
-
- Case open date range -
-
- - -
-
-
-
- - -
-
-
- Case close date range -
-
- - +
+ +
+ +
+

Document date range does not search archived cases

+
-
-
-
- - +
+
+ + +
+
-
+
+ + +
-
-
+ {#
#} + {#
#} +
+ {{ checkbox.checkbox_dropdown_multiple( 'mur_disposition_category_id', 'Final disposition', @@ -86,25 +77,20 @@ prefix='mur_disposition_category_id', show_tooltip_text='Final disposition does not search archived cases' ) }} + {{ dropdown.select_json( + 'primary_subject_id', + 'Case subject', + options=constants.primary_subject_ids, + default="", + show_tooltip_text='Case subject does not search archived cases' + ) }} + {{ dropdown.select_json_indentation( + 'secondary_subject_id', + 'Secondary case subject', + options=constants.secondary_subject_placeholder, + default="" + ) }} - {{ - dropdown.select_json( - 'primary_subject_id', - 'Case subject', - options=constants.primary_subject_ids, - default="", - show_tooltip_text='Case subject does not search archived cases' - - ) - }} - {{ - dropdown.select_json_indentation( - 'secondary_subject_id', - 'Secondary case subject', - options=constants.secondary_subject_placeholder, - default="" - ) - }}
Penalty amount by respondent
@@ -119,12 +105,56 @@
+ +
+ Case open date range +
+
+ + +
+
-
+
+ + +
+
+
+ +
+ Case close date range +
+
+ + +
+
-
+
+ + +
+
+
+
+ + {#
#} + {#
#} + + +
+ + + + + + {{ typeahead.field('case_regulatory_citation', 'Regulatory citation', False, dataset='caseRegulatoryCitations', allow_text=False) }} + {{ typeahead.field('case_statutory_citation', 'Statutory citation', False, dataset='caseStatutoryCitations', allow_text=False) }} +
- {% endblock %} {% block message %} @@ -216,6 +246,25 @@ {% endif %} {% endif %} + {% if case_citation_require_all %} +
  • +
    Cases with all citations
    +
  • + {% endif %} + {% if case_regulatory_citation %} +
  • + {% for case_reg_citation in case_regulatory_citation %} +
    {{ case_reg_citation }}
    + {% endfor %} +
  • + {% endif %} + {% if case_statutory_citation %} +
  • + {% for case_stat_citation in case_statutory_citation %} +
    {{ case_stat_citation }}
    + {% endfor %} +
  • + {% endif %}
    diff --git a/fec/legal/templates/partials/legal-pagination.jinja b/fec/legal/templates/partials/legal-pagination.jinja index c81efdab4..445d52d99 100644 --- a/fec/legal/templates/partials/legal-pagination.jinja +++ b/fec/legal/templates/partials/legal-pagination.jinja @@ -30,8 +30,39 @@ {% set start_page = 1 %} {% endif %} + {#- Previous page button -#} {% if result_type != 'advisory_opinions' and current_page > 1 %} - + {% elif result_type == 'advisory_opinions' and current_page > 1 %} {{ page }} + {{ page }} {% elif result_type == 'advisory_opinions' %} Next + {% elif result_type == 'advisory_opinions' and offset + limit < total_all %} diff --git a/fec/legal/templates/partials/legal-search-results-advisory-opinion.jinja b/fec/legal/templates/partials/legal-search-results-advisory-opinion.jinja index f55cbd280..bef149c2a 100644 --- a/fec/legal/templates/partials/legal-search-results-advisory-opinion.jinja +++ b/fec/legal/templates/partials/legal-search-results-advisory-opinion.jinja @@ -15,7 +15,7 @@
    - AO {{ advisory_opinion.ao_no }}
    {{ advisory_opinion.name }}
    + AO {{ advisory_opinion.ao_no }}
    {{ advisory_opinion.name }}
    {% if advisory_opinion.status == 'Pending' %}
    diff --git a/fec/legal/templates/partials/legal-search-results-afs.jinja b/fec/legal/templates/partials/legal-search-results-afs.jinja index 16e2ae960..d29bd0685 100644 --- a/fec/legal/templates/partials/legal-search-results-afs.jinja +++ b/fec/legal/templates/partials/legal-search-results-afs.jinja @@ -15,7 +15,7 @@
    - AF #{{ admin_fine.no }}
    + AF #{{ admin_fine.no }}
    {{ admin_fine.name.upper() }} {% if admin_fine.highlights %}
    Keyword match:
    diff --git a/fec/legal/templates/partials/legal-search-results-mur.jinja b/fec/legal/templates/partials/legal-search-results-mur.jinja index 770f3a09c..b39606dfb 100644 --- a/fec/legal/templates/partials/legal-search-results-mur.jinja +++ b/fec/legal/templates/partials/legal-search-results-mur.jinja @@ -20,14 +20,14 @@
    {% if mur.mur_type == 'current' %} - + {{ mur.name|upper }} {% elif mur.no == ARCHIVED_MUR_EXCEPTION and mur.mur_type == 'archived'%} - + {{ mur.mur_name|upper }} {% else %} - + {{ mur.mur_name|upper }} {% endif %} diff --git a/fec/legal/views.py b/fec/legal/views.py index 36af38b80..bd7706fd3 100644 --- a/fec/legal/views.py +++ b/fec/legal/views.py @@ -272,6 +272,8 @@ def legal_doc_search_ao(request): ao_doc_category_ids = request.GET.getlist('ao_doc_category_id', []) ao_requestor_type_ids = request.GET.getlist('ao_requestor_type', []) ao_regulatory_citation = request.GET.get('ao_regulatory_citation', '') + ao_statutory_citation = request.GET.get('ao_statutory_citation', '') + ao_citation_require_all = request.GET.get('ao_citation_require_all', '') query, query_exclude = parse_query(original_query) @@ -293,6 +295,8 @@ def legal_doc_search_ao(request): ao_entity_name=ao_entity_name, ao_doc_category_id=ao_doc_category_ids, ao_regulatory_citation=ao_regulatory_citation, + ao_statutory_citation=ao_statutory_citation, + ao_citation_require_all=ao_citation_require_all, ) # Define AO document categories dictionary @@ -349,6 +353,8 @@ def legal_doc_search_ao(request): 'ao_entity_name': ao_entity_name, 'query': query, 'ao_regulatory_citation': ao_regulatory_citation, + 'ao_statutory_citation': ao_statutory_citation, + 'ao_citation_require_all': ao_citation_require_all, 'category_order': get_legal_category_order(results, 'advisory_opinions'), 'social_image_identifier': 'legal', 'selected_ao_doc_category_ids': ao_doc_category_ids, @@ -376,6 +382,9 @@ def legal_doc_search_mur(request): case_max_close_date = request.GET.get('case_max_close_date', '') case_doc_category_ids = request.GET.getlist('case_doc_category_id', []) mur_disposition_category_ids = request.GET.getlist('mur_disposition_category_id', []) + case_citation_require_all = request.GET.get('case_citation_require_all', '') + case_regulatory_citation = request.GET.getlist('case_regulatory_citation', []) + case_statutory_citation = request.GET.getlist('case_statutory_citation', []) primary_subject_id = request.GET.get('primary_subject_id', '') secondary_subject_id = request.GET.get('secondary_subject_id', '') @@ -396,16 +405,19 @@ def legal_doc_search_mur(request): limit=limit, case_no=case_no, sort=sort, - case_respondents=case_respondents, - case_min_penalty_amount=case_min_penalty_amount, - case_max_penalty_amount=case_max_penalty_amount, - case_min_document_date=case_min_document_date, + case_citation_require_all=case_citation_require_all, + case_doc_category_id=case_doc_category_ids, + case_max_close_date=case_max_close_date, case_max_document_date=case_max_document_date, - case_min_open_date=case_min_open_date, case_max_open_date=case_max_open_date, + case_max_penalty_amount=case_max_penalty_amount, case_min_close_date=case_min_close_date, - case_max_close_date=case_max_close_date, - case_doc_category_id=case_doc_category_ids, + case_min_document_date=case_min_document_date, + case_min_open_date=case_min_open_date, + case_min_penalty_amount=case_min_penalty_amount, + case_regulatory_citation=case_regulatory_citation, + case_respondents=case_respondents, + case_statutory_citation=case_statutory_citation, mur_disposition_category_id=mur_disposition_category_ids, primary_subject_id=primary_subject_id, secondary_subject_id=secondary_subject_id, @@ -499,7 +511,10 @@ def get_secondary_subject_name(id): 'primary_subject_id_name': primary_subject_id_name, 'secondary_subject_id_name': secondary_subject_id_name, 'is_loading': True, # Indicate that the page is loading initially - "context_vars": context_vars, + 'context_vars': context_vars, + 'case_citation_require_all': case_citation_require_all, + 'case_regulatory_citation': case_regulatory_citation, + 'case_statutory_citation': case_statutory_citation, })