add comments

This commit is contained in:
simon lehericey 2024-10-09 09:21:44 +02:00
parent 450420aa81
commit 14809b35af
No known key found for this signature in database
GPG key ID: CDE670D827C7B3C5
2 changed files with 9 additions and 0 deletions

View file

@ -18,8 +18,13 @@ class Column
@displayable = displayable @displayable = displayable
end end
# the id is a String to be used in forms
def id = h_id.to_json def id = h_id.to_json
# the h_id is a Hash and hold enough information to find the column
# in the ColumnType class, aka be able to do the h_id -> column conversion
def h_id = { procedure_id: @procedure_id, column_id: "#{table}/#{column}" } def h_id = { procedure_id: @procedure_id, column_id: "#{table}/#{column}" }
def ==(other) = h_id == other.h_id # using h_id instead of id to avoid inversion of keys def ==(other) = h_id == other.h_id # using h_id instead of id to avoid inversion of keys
def to_json def to_json

View file

@ -4,6 +4,10 @@ module ColumnsConcern
extend ActiveSupport::Concern extend ActiveSupport::Concern
included do included do
# we cannot use column.id ( == { procedure_id, column_id }.to_json)
# as the order of the keys is not guaranteed
# instead, we are using h_id == { procedure_id:, column_id: }
# another way to find a column is to look for its label
def find_column(h_id: nil, label: nil) def find_column(h_id: nil, label: nil)
return columns.find { _1.h_id == h_id } if h_id.present? return columns.find { _1.h_id == h_id } if h_id.present?
return columns.find { _1.label == label } if label.present? return columns.find { _1.label == label } if label.present?