Class: Volt::Tasks

Inherits:
Object show all
Defined in:
lib/volt/page/tasks.rb

Overview

The tasks class provides an interface to call tasks on the backend server.

Instance Method Summary collapse

Constructor Details

#initialize(page) ⇒ Tasks

Returns a new instance of Tasks.



5
6
7
8
9
10
11
12
13
# File 'lib/volt/page/tasks.rb', line 5

def initialize(page)
  @page       = page
  @promise_id = 0
  @promises   = {}

  page.channel.on('message') do |*args|
    received_message(*args)
  end
end

Instance Method Details

#call(class_name, method_name, *args) ⇒ Object



15
16
17
18
19
20
21
22
23
24
25
26
27
28
# File 'lib/volt/page/tasks.rb', line 15

def call(class_name, method_name, *args)
  promise_id            = @promise_id
  @promise_id           += 1

  # Track the callback
  promise               = Promise.new
  @promises[promise_id] = promise

  # TODO: Timeout on these callbacks

  @page.channel.send_message([promise_id, class_name, method_name, *args])

  promise
end

#notify_query(method_name, collection, query, *args) ⇒ Object

Called when the backend sends a notification to change the results of a query.



59
60
61
62
# File 'lib/volt/page/tasks.rb', line 59

def notify_query(method_name, collection, query, *args)
  query_obj = Persistors::ArrayStore.query_pool.lookup(collection, query)
  query_obj.send(method_name, *args)
end

#received_message(name, promise_id, *args) ⇒ Object



30
31
32
33
34
35
36
37
38
39
# File 'lib/volt/page/tasks.rb', line 30

def received_message(name, promise_id, *args)
  case name
    when 'added', 'removed', 'updated', 'changed'
      notify_query(name, *args)
    when 'response'
      response(promise_id, *args)
    when 'reload'
      reload
  end
end

#reloadObject



64
65
66
67
68
69
70
71
72
73
74
75
76
# File 'lib/volt/page/tasks.rb', line 64

def reload
  # Stash the current page value
  value = JSON.dump($page.page.to_h)

  # If this browser supports session storage, store the page, so it will
  # be in the same state when we reload.
  if `sessionStorage`
    `sessionStorage.setItem('___page', value);`
  end

  $page.page._reloading = true
  `window.location.reload(false);`
end

#response(promise_id, result, error) ⇒ Object

When a request is sent to the backend, it can attach a callback, this is called from the backend to pass to the callback.



43
44
45
46
47
48
49
50
51
52
53
54
55
# File 'lib/volt/page/tasks.rb', line 43

def response(promise_id, result, error)
  promise = @promises.delete(promise_id)

  if promise
    if error
      # TODO: full error handling
      puts "Task Response: #{error.inspect}"
      promise.reject(error)
    else
      promise.resolve(result)
    end
  end
end