Sha256: db76867a08daf3fdb28a45debdb02b890092b632330a4d78f4628e43d2630c83
Contents?: true
Size: 1.79 KB
Versions: 5
Compression:
Stored size: 1.79 KB
Contents
require_relative 'live_query/data_store' require_relative 'live_query/live_query_pool' class QueryTasks < TaskHandler @@live_query_pool = LiveQueryPool.new(DataStore.new) @@channel_live_queries = {} def self.live_query_pool @@live_query_pool end # The dispatcher passes its self in def initialize(channel, dispatcher=nil) @channel = channel @dispatcher = dispatcher end def add_listener(collection, query) live_query = @@live_query_pool.lookup(collection, query) track_channel_in_live_query(live_query) # puts "Load data on #{collection.inspect} - #{query.inspect}" live_query.add_channel(@channel) errors = {} begin # Get the initial data initial_data = live_query.initial_data rescue => exception # Capture and pass up any exceptions error = {:error => exception.message} end return [initial_data, error] end def initial_data data = live_query.initial_data data[:_id] = data[:_id].to_s return data end # Remove a listening channel, the LiveQuery will automatically remove # itsself from the pool when there are no channels. def remove_listener(collection, query) live_query = @@live_query_pool.lookup(collection, query) live_query.remove_channel(@channel) end # Removes a channel from all associated live queries def close! live_queries = @@channel_live_queries[@channel] if live_queries live_queries.each do |live_query| live_query.remove_channel(@channel) end end @@channel_live_queries.delete(@channel) end private # Tracks that this channel will be notified from the live query. def track_channel_in_live_query(live_query) @@channel_live_queries[@channel] ||= [] @@channel_live_queries[@channel] << live_query end end
Version data entries
5 entries across 5 versions & 1 rubygems