class ProtocolLinkedChildrenDatatable < CustomDatatable def_delegator :@view, :link_to def_delegator :@view, :protocols_my_module_path def initialize(view, protocol, user, controller) super(view) @protocol = protocol @user = user @controller = controller end def sortable_columns @sortable_columns ||= [ 'Protocol.id' ] end def sortable_displayed_columns @sortable_displayed_columns ||= [ '0' ] end def searchable_columns @searchable_columns ||= [] end private # Returns json of current linked children (already paginated) def data records.map do |record| { 'DT_RowId' => record.id, 'version' => record.parent.version_number, '1' => record_html(record) } end end # Query database for records (this will be later paginated and filtered) # after that "data" function will return json def get_raw_records linked_protocols = Protocol .joins(my_module: { experiment: :project }) .includes(my_module: { experiment: :project }) .references(my_module: { experiment: :project }) .where(protocol_type: Protocol.protocol_types[:linked]) records = linked_protocols .where(parent: @protocol) .or( linked_protocols.where(parent: Protocol.where(parent: @protocol)) ) records.distinct end # Helper methods def record_html(record) res = '' res += "
' res end end