Class: Rack::Tracker::Handler
- Inherits:
-
Object
- Object
- Rack::Tracker::Handler
- Includes:
- JavaScriptHelper
- Defined in:
- lib/rack/tracker/handler.rb
Direct Known Subclasses
Criteo, Facebook, FacebookPixel, GoSquared, GoogleAdwordsConversion, GoogleAnalytics, GoogleTagManager, Hotjar, Vwo, Zanox
Constant Summary
Constants included from JavaScriptHelper
JavaScriptHelper::JS_ESCAPE_MAP
Instance Attribute Summary collapse
-
#env ⇒ Object
Returns the value of attribute env.
-
#options ⇒ Object
Returns the value of attribute options.
Class Method Summary collapse
- .process_track(env, method_name, *args, &block) ⇒ Object
-
.track(name, *event) ⇒ Object
overwrite me in the handler subclass if you need more control over the event.
Instance Method Summary collapse
- #events ⇒ Object
- #handler_name ⇒ Object
-
#initialize(env, options = {}) ⇒ Handler
constructor
A new instance of Handler.
- #inject(response) ⇒ Object
- #render ⇒ Object
- #write_event(event) ⇒ Object
Methods included from JavaScriptHelper
Constructor Details
#initialize(env, options = {}) ⇒ Handler
Returns a new instance of Handler.
22 23 24 25 26 |
# File 'lib/rack/tracker/handler.rb', line 22 def initialize(env, = {}) self.env = env self. = self.position = [:position] if .has_key?(:position) end |
Instance Attribute Details
#env ⇒ Object
Returns the value of attribute env.
17 18 19 |
# File 'lib/rack/tracker/handler.rb', line 17 def env @env end |
#options ⇒ Object
Returns the value of attribute options.
16 17 18 |
# File 'lib/rack/tracker/handler.rb', line 16 def end |
Class Method Details
.process_track(env, method_name, *args, &block) ⇒ Object
3 4 5 |
# File 'lib/rack/tracker/handler.rb', line 3 def process_track(env, method_name, *args, &block) new(env).write_event(track(method_name, *args, &block)) end |
.track(name, *event) ⇒ Object
overwrite me in the handler subclass if you need more control over the event
8 9 10 |
# File 'lib/rack/tracker/handler.rb', line 8 def track(name, *event) { name.to_s => [event.last.merge('class_name' => event.first.to_s.classify)] } end |
Instance Method Details
#events ⇒ Object
28 29 30 31 |
# File 'lib/rack/tracker/handler.rb', line 28 def events events = env.fetch('tracker', {})[handler_name] || [] events.map { |ev| "#{self.class}::#{ev['class_name']}".constantize.new(ev.except('class_name')) } end |
#handler_name ⇒ Object
56 57 58 |
# File 'lib/rack/tracker/handler.rb', line 56 def handler_name self.class.name.demodulize.underscore end |
#inject(response) ⇒ Object
37 38 39 40 41 42 43 44 45 |
# File 'lib/rack/tracker/handler.rb', line 37 def inject(response) # Sub! is enough, in well formed html there's only one head or body tag. # Block syntax need to be used, otherwise backslashes in input will mess the output. # @see http://stackoverflow.com/a/4149087/518204 and https://github.com/railslove/rack-tracker/issues/50 response.sub! %r{</#{self.position}>} do |m| self.render << m.to_s end response end |
#render ⇒ Object
33 34 35 |
# File 'lib/rack/tracker/handler.rb', line 33 def render Tilt.new(File.join(File.dirname(__FILE__), handler_name, 'template', "#{handler_name}.erb") ).render(self) end |
#write_event(event) ⇒ Object
47 48 49 50 51 52 53 54 |
# File 'lib/rack/tracker/handler.rb', line 47 def write_event(event) event.deep_stringify_keys! # for consistent hash access use strings (keys from the session are always strings anyway) if env.key?('tracker') self.env['tracker'].deep_merge!(event) { |key, old, new| Array.wrap(old) + Array.wrap(new) } else self.env['tracker'] = event end end |