2023-02-05 16:18:18 +02:00
|
|
|
require "opal"
|
2023-02-05 17:47:51 +02:00
|
|
|
require "native"
|
|
|
|
require 'promise'
|
|
|
|
require 'browser/setup/mini'
|
|
|
|
|
|
|
|
class Kanta
|
|
|
|
def initialize(hash)
|
|
|
|
hash.each do |k,v|
|
2023-02-06 19:34:06 +02:00
|
|
|
wrap_attr(k,v)
|
2023-02-05 17:47:51 +02:00
|
|
|
end
|
2023-02-06 19:34:06 +02:00
|
|
|
@effect = nil
|
|
|
|
@subscribers = {}
|
|
|
|
end
|
|
|
|
|
|
|
|
def track( target , key )
|
|
|
|
return unless @effect
|
|
|
|
subs = get_subscribers_for(key)
|
|
|
|
subs << @effect
|
|
|
|
end
|
|
|
|
|
|
|
|
def trigger(key)
|
|
|
|
effects = get_subscribers_for(key)
|
|
|
|
effects.each {|effect| effect() }
|
|
|
|
end
|
|
|
|
|
|
|
|
def get_subscribers_for(key)
|
|
|
|
unless @subscribers.has_key?(key)
|
|
|
|
@subscribers[key] = []
|
|
|
|
end
|
|
|
|
@subscribers[key]
|
|
|
|
end
|
|
|
|
|
|
|
|
def mount(on_class)
|
|
|
|
puts $document[on_class].inner_html
|
|
|
|
end
|
2023-02-05 17:47:51 +02:00
|
|
|
|
2023-02-06 19:34:06 +02:00
|
|
|
def wrap_attr(k,v)
|
|
|
|
instance_variable_set "@#{k}" , v
|
|
|
|
define_getter(k)
|
|
|
|
define_setter(k)
|
|
|
|
end
|
|
|
|
|
|
|
|
def define_getter(k)
|
|
|
|
self.class.define_method k.to_sym do
|
|
|
|
track(key)
|
|
|
|
instance_variable_get "@#{k}".to_sym
|
|
|
|
end
|
|
|
|
end
|
|
|
|
def define_setter(k)
|
|
|
|
self.class.define_method "#{k}=".to_sym do |new_v|
|
|
|
|
instance_variable_set "@#{k}" , new_v
|
|
|
|
trigger(key)
|
2023-02-05 17:47:51 +02:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|