Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Feature: Associate categories inputs with their parents in selecting/deselecting #773

Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
16 commits
Select commit Hold shift + click to select a range
b55e1b3
update categories selector in admin page to allow multiple parentCate…
Bilelkihal Oct 10, 2024
81b2aee
handle category multiple parents in category page
Bilelkihal Oct 10, 2024
af2dc96
add null safety in nest categories children function
Bilelkihal Oct 10, 2024
f9c72a8
check children inputs of a category when we check it
Bilelkihal Oct 10, 2024
e156108
deselect children of category when we delect it in browse page
Bilelkihal Oct 10, 2024
0fab19b
make the click categories action works only with categories input chi…
Bilelkihal Oct 10, 2024
1f95275
fix check method in categories controller to select parents of a chil…
Bilelkihal Oct 11, 2024
9dc4bb9
Merge branch 'development' into feature/select-children-of-category-w…
syphax-bouazzouni Oct 11, 2024
eead0c1
change the name of categories stimulus controller to parent categorie…
Bilelkihal Nov 7, 2024
b93cee0
associate categories with their parents in upload ontology form chips
Bilelkihal Nov 7, 2024
69fb797
Merge branch 'development' into feature/select-children-of-category-w…
Bilelkihal Nov 7, 2024
39a645d
update the logic of associating parent categories with their children…
Bilelkihal Jan 2, 2025
18d87b7
refactor parent categories selector controller code
Bilelkihal Jan 2, 2025
7081622
move categories with children logic from stimulus controller to ruby …
Bilelkihal Jan 3, 2025
4627639
Merge branch 'development' into feature/select-children-of-category-w…
Bilelkihal Jan 3, 2025
aa41602
remove duplicated id_to_acronym method
Bilelkihal Jan 3, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 17 additions & 0 deletions app/helpers/application_helper.rb
Original file line number Diff line number Diff line change
Expand Up @@ -460,4 +460,21 @@ def category_is_parent?(parents_list, category)
[is_parent,parent_error_message]
end

def categories_with_children(categories)
parent_to_children = Hash.new { |hash, key| hash[key] = [] }
categories.each do |category|
next unless category.parentCategory
category.parentCategory.each do |parent_id|
parent_acronym = id_to_acronym(parent_id)
child_acronym = id_to_acronym(category.id)
parent_to_children[parent_acronym] << child_acronym
end
end
parent_to_children
end

def id_to_acronym(id)
Bilelkihal marked this conversation as resolved.
Show resolved Hide resolved
id.split('/').last
end

end
13 changes: 5 additions & 8 deletions app/helpers/ontologies_helper.rb
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
require 'iso-639'
module OntologiesHelper

include ApplicationHelper
REST_URI = $REST_URL
API_KEY = $API_KEY
LANGUAGE_FILTERABLE_SECTIONS = %w[classes schemes collections instances properties].freeze
Expand Down Expand Up @@ -801,10 +801,6 @@ def submission_languages(submission = @submission)
Array(submission&.naturalLanguage).map { |natural_language| natural_language["iso639"] && natural_language.split('/').last }.compact
end

def id_to_acronym(id)
id.split('/').last
end

def browse_taxonomy_tooltip(taxonomy_type)
return nil unless taxonomy_type.eql?("categories") || taxonomy_type.eql?("groups")

Expand All @@ -817,9 +813,10 @@ def browse_taxonomy_tooltip(taxonomy_type)
def browse_chip_filter(key:, object:, values:, countable: true, count: nil)
title = (key.to_s.eql?("categories") || key.to_s.eql?("groups")) ? nil : ''
checked = values.any? { |obj| [link_last_part(object["id"]), link_last_part(object["value"])].include?(obj) }

group_chip_component(name: key, object: object, checked: checked, title: title) do |c|
c.count { browse_chip_count_badge(key: key, id: object["id"], count: count) } if countable
content_tag(:div, (key.to_s.eql?("categories") ? { 'data-action' => 'click->parent-categories-selector#check' } : {})) do
group_chip_component(name: key, object: object, checked: checked, title: title) do |c|
c.count { browse_chip_count_badge(key: key, id: object["id"], count: count) } if countable
end
end
end

Expand Down
9 changes: 6 additions & 3 deletions app/helpers/submission_inputs_helper.rb
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
module SubmissionInputsHelper

class SubmissionMetadataInput
include MetadataHelper
include MetadataHelper, ApplicationHelper

def initialize(attribute_key:, attr_metadata:, submission: nil, label: nil)
@attribute_key = attribute_key
Expand Down Expand Up @@ -128,14 +128,17 @@ def ontology_administered_by_input(ontology = @ontology, users_list = @user_sele

def ontology_categories_input(ontology = @ontology, categories = @categories)
categories ||= LinkedData::Client::Models::Category.all(display_links: false, display_context: false)
categories_children = categories_with_children(categories)

render Input::InputFieldComponent.new(name: '', label: 'Categories') do
content_tag(:div, class: 'upload-ontology-chips-container') do
content_tag(:div, class: 'upload-ontology-chips-container', 'data-controller': 'parent-categories-selector', 'data-parent-categories-selector-categories-children-value': "#{categories_children.to_json}", 'data-parent-categories-selector-target': "chips") do
syphax-bouazzouni marked this conversation as resolved.
Show resolved Hide resolved
hidden_field_tag('ontology[hasDomain][]') +
categories.map do |category|
categories.map do |category|
content_tag(:div, 'data-action': 'click->parent-categories-selector#check') do
category_chip_component(id: category[:acronym], name: "ontology[hasDomain][]",
object: category, value: category[:id],
checked: ontology.hasDomain&.any? { |x| x.eql?(category[:id]) })
end
end.join.html_safe
end
end
Expand Down
3 changes: 3 additions & 0 deletions app/javascript/controllers/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -100,3 +100,6 @@ application.register('mappings', MappingsController)

import ConceptsJsonButtonController from "./concepts_json_button_controller.js"
application.register('concepts-json', ConceptsJsonButtonController)

import ParentCategoriesSelectorController from "./parent_categories_selector_controller.js"
application.register('parent-categories-selector', ParentCategoriesSelectorController)
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
import { Controller } from "@hotwired/stimulus"

// Connects to data-controller="parent-categories-selector"
export default class extends Controller {
static targets = ['chips']
static values = { categoriesChildren: Object}

check(event){
const input = event.currentTarget.querySelector('input')
const allInputs = this.chipsTarget.querySelectorAll('input')
const parents = this.categoriesChildrenValue
if(this.#id_to_acronym(input.value) in parents){
const parentChildren = parents[this.#id_to_acronym(input.value)]
allInputs.forEach(i => {
if(parentChildren.includes(this.#id_to_acronym(i.value))){
if(input.checked){
i.checked = true;
i.dispatchEvent(new Event('change', { bubbles: true }));
} else {
i.checked = false;
i.dispatchEvent(new Event('change', { bubbles: true }));
}
}
});
}
}

#id_to_acronym(id){
return id.split('/').pop();
}
}
20 changes: 11 additions & 9 deletions app/views/ontologies/browser/browse.html.haml
Original file line number Diff line number Diff line change
Expand Up @@ -44,15 +44,16 @@
%div.browse-filter
= switch_input(id:'filter-views', name:'views', checked: @show_views, label: t("ontologies.browser.show_ontology_views"))
= switch_input(id:'filter-retired', name:'retired',checked: @show_retired , label: t("ontologies.browser.show_retired_ontologies"))

- @filters.each do |key, values|
%div{ id: "#{key}_filter_container", data:{controller: "browse_filters show-filter-count",
action: "change->show-filter-count#updateCount
change->browse-filters#dispatchFilterEvent"}}
- objects, checked_values, count = values
= dropdown_component(id: "browse-#{key}-filter", is_open: count.positive?) do |d|
- d.title { browse_filter_section_header(key: key, count: count)}
= browse_filter_section_body(key: key, checked_values: checked_values, objects: objects)
%div{'data-controller': 'parent-categories-selector', 'data-parent-categories-selector-categories-children-value': "#{categories_with_children(@categories).to_json}"}
- @filters.each do |key, values|
%div{ id: "#{key}_filter_container", data:{controller: "browse_filters show-filter-count",
action: "change->show-filter-count#updateCount
change->browse-filters#dispatchFilterEvent"}}
%div{key.eql?(:categories) ? {'data-parent-categories-selector-target': "chips"} : {}}
- objects, checked_values, count = values
= dropdown_component(id: "browse-#{key}-filter", is_open: count.positive?) do |d|
- d.title { browse_filter_section_header(key: key, count: count)}
= browse_filter_section_body(key: key, checked_values: checked_values, objects: objects)

- if federation_enabled?
%div{ data:{action: "change->browse-filters#federationChange"}}
Expand All @@ -61,6 +62,7 @@
.px-1.browse-federation-input-chips
= federation_input_chips(name: "portals")


.browse-second-row
.browse-search-bar
.browse-search-container
Expand Down
Loading