diff --git a/cdmm/app/helpers/cdmm_helper.rb b/cdmm/app/helpers/cdmm_helper.rb index ded1ee6..4a36f5a 100644 --- a/cdmm/app/helpers/cdmm_helper.rb +++ b/cdmm/app/helpers/cdmm_helper.rb @@ -9,6 +9,16 @@ def get_data_at(table, row_index, col_index) end end + def cell_key(table, row_index, col_index) + "cell_#{row_index}_#{col_index}" + end + + def all_checked?(table, row_index, col_index) + data = get_data_at(table, row_index, col_index) + unselected_caps = data.select { |cap| cap[:value] == "unchecked" } + unselected_caps.count == 0 + end + def label_to_key(label) label.gsub(/::/, '__') .gsub(/([A-Z]+)([A-Z][a-z])/, '\1_\2') diff --git a/cdmm/app/javascript/controllers/checklist_ui_controller.js b/cdmm/app/javascript/controllers/checklist_ui_controller.js new file mode 100644 index 0000000..1e8b7fb --- /dev/null +++ b/cdmm/app/javascript/controllers/checklist_ui_controller.js @@ -0,0 +1,19 @@ +import { Controller } from "@hotwired/stimulus" + +// Connects to data-controller="checklist-ui" +export default class extends Controller { + static values = { itemCount: Number, completeClasses: String } + + connect() { + } + + refresh(event) { + const uncheckedChecklists = this.element.querySelectorAll("input[type='hidden'][value='unchecked']"); + if (uncheckedChecklists.length === 0) { + this.element.classList.add(this.completeClassesValue); + } else { + this.element.classList.remove(this.completeClassesValue); + } + } + +} diff --git a/cdmm/app/views/cdmm/_capability_list.html.erb b/cdmm/app/views/cdmm/_capability_list.html.erb new file mode 100644 index 0000000..95ad1ac --- /dev/null +++ b/cdmm/app/views/cdmm/_capability_list.html.erb @@ -0,0 +1,7 @@ +