Class: Glimmer::DataBinding::TableItemsBinding
- Inherits:
-
Object
- Object
- Glimmer::DataBinding::TableItemsBinding
- Includes:
- DataBinding::Observable, DataBinding::Observer
- Defined in:
- lib/glimmer/data_binding/table_items_binding.rb
Instance Method Summary collapse
- #call(new_model_collection = nil) ⇒ Object
-
#initialize(parent, model_binding, column_properties = nil) ⇒ TableItemsBinding
constructor
A new instance of TableItemsBinding.
- #populate_table(model_collection, parent, column_properties) ⇒ Object
- #sort_table(model_collection, parent, column_properties) ⇒ Object
Constructor Details
#initialize(parent, model_binding, column_properties = nil) ⇒ TableItemsBinding
Returns a new instance of TableItemsBinding.
14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
# File 'lib/glimmer/data_binding/table_items_binding.rb', line 14 def initialize(parent, model_binding, column_properties = nil) @last_populated_model_collection = nil @table = parent @model_binding = model_binding @column_properties = model_binding.[:column_attributes] || model_binding.[:column_properties] || column_properties # TODO @table.editable = false if model_binding.[:read_only] @table.data = @model_binding ##@table.on_widget_disposed do |dispose_event| # doesn't seem needed within Opal ## unregister_all_observables ##end if @table.respond_to?(:column_properties=) @table.column_properties = @column_properties else # assume custom widget @table.body_root.column_properties = @column_properties end @table_observer_registration = observe(model_binding) call end |
Instance Method Details
#call(new_model_collection = nil) ⇒ Object
33 34 35 36 37 38 39 40 41 42 43 44 45 46 |
# File 'lib/glimmer/data_binding/table_items_binding.rb', line 33 def call(new_model_collection=nil) new_model_collection = @model_binding.evaluate_property # this ensures applying converters (e.g. :on_read) table_cells = @table.items.map {|item| @table.column_properties.size.times.map {|i| item.get_text(i)} } model_cells = new_model_collection.to_a.map {|m| @table.cells_for(m)} return if table_cells == model_cells if new_model_collection and new_model_collection.is_a?(Array) @table_items_observer_registration&.unobserve @table_items_observer_registration = observe(new_model_collection, @column_properties) add_dependent(@table_observer_registration => @table_items_observer_registration) @model_collection = new_model_collection end populate_table(@model_collection, @table, @column_properties) sort_table(@model_collection, @table, @column_properties) end |
#populate_table(model_collection, parent, column_properties) ⇒ Object
48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 |
# File 'lib/glimmer/data_binding/table_items_binding.rb', line 48 def populate_table(model_collection, parent, column_properties) @skip_populate_table = model_collection&.sort_by(&:hash).map {|m| @table.column_properties.map {|p| m.send(p)}} == @last_populated_model_collection_properties return if @skip_populate_table @last_populated_model_collection = model_collection @last_populated_model_collection_properties = model_collection&.sort_by(&:hash).map {|m| @table.column_properties.map {|p| m.send(p)}} # TODO improve performance selected_table_item_models = parent.selection.map(&:get_data) old_items = parent.items old_item_ids_per_model = old_items.reduce({}) {|hash, item| hash.merge(item.get_data.hash => item.id) } parent.remove_all model_collection.each do |model| table_item = Glimmer::SWT::TableItemProxy.new(parent, [], nil) for index in 0..(column_properties.size-1) table_item.set_text(index, model.send(column_properties[index]).to_s) end table_item.set_data(model) table_item.id = old_item_ids_per_model[model.hash] if old_item_ids_per_model[model.hash] end parent.selection = parent.search {|item| selected_table_item_models.include?(item.get_data) } parent.redraw end |
#sort_table(model_collection, parent, column_properties) ⇒ Object
70 71 72 73 74 75 76 77 78 79 80 81 |
# File 'lib/glimmer/data_binding/table_items_binding.rb', line 70 def sort_table(model_collection, parent, column_properties) return if model_collection == @last_sorted_model_collection if model_collection == @last_populated_model_collection # Reapply the last table sort. The model collection has just been populated since it diverged from what it was before # TODO optimize in the future by sorting elements in DOM directly parent.sort! else # The model collection was sorted by the model, but beyond sorting, it did not change from the last populated model collection. parent.items = parent.items.sort_by { |item| model_collection.index(item.get_data) } @last_sorted_model_collection = @last_populated_model_collection = model_collection end end |