Module: FastComments::Jekyll::SelectorWidget

Defined in:
lib/fastcomments/jekyll/selector_widget.rb

Overview

Renders a selector widget that attaches to an existing element via a CSS selector (collab chat, image chat). Port of renderSelectorWidget.

Class Method Summary collapse

Class Method Details

.render(spec, config) ⇒ Object



8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
# File 'lib/fastcomments/jekyll/selector_widget.rb', line 8

def render(spec, config)
  clean = Util.sanitize_config(config)
  target = clean["target"]

  unless target.is_a?(String) && !target.empty?
    raise Liquid::SyntaxError,
          "#{spec[:shortcode_name]} tag requires a \"target\" option (CSS selector for the target element)."
  end

  clean = clean.reject { |key, _| key == "target" }
  region = clean["region"]
  script_src = "#{Util.get_cdn_base(region)}#{spec[:script_path]}"

  global_name = spec[:global_name]
  slow_warn = "FastComments #{spec[:shortcode_name]} script did not load within 5s; continuing to retry every 1s."

  "<script>" \
    "(function(){" \
    "var target=#{Util.json_for_script(target)};" \
    "var config=#{Util.json_for_script(clean)};" \
    "var scriptSrc=#{Util.json_for_script(script_src)};" \
    "var marker=#{Util.json_for_script(spec[:script_marker_attr])};" \
    "var startedAt=Date.now();" \
    "var warned=false;" \
    "function schedule(){var elapsed=Date.now()-startedAt;" \
    "if(elapsed>=5000&&!warned){warned=true;console.warn(#{Util.json_for_script(slow_warn)});}" \
    "setTimeout(init,elapsed<5000?50:1000);}" \
    "function init(){if(window.#{global_name}){var el=document.querySelector(target);" \
    "if(el){window.#{global_name}(el,config);}}else{schedule();}}" \
    "if(!document.querySelector('script['+marker+']')){" \
    "var s=document.createElement('script');" \
    "s.src=scriptSrc;" \
    "s.setAttribute(marker,'');" \
    "document.head.appendChild(s);" \
    "}" \
    "init();" \
    "})();" \
    "</script>"
end