2025-02-11 17:24:34
function _toConsumableArray(a) {
  if (Array.isArray(a)) {
    for (var b = 0, c = Array(a.length); b < a.length; b++) c[b] = a[b];
    return c
  }
  return Array.from(a)
}
function _classCallCheck(a, b) {
  if (!(a instanceof b)) throw new TypeError('Cannot call a class as a function')
}
function _classCallCheck(a, b) {
  if (!(a instanceof b)) throw new TypeError('Cannot call a class as a function')
}
function _toConsumableArray(a) {
  if (Array.isArray(a)) {
    for (var b = 0, c = Array(a.length); b < a.length; b++) c[b] = a[b];
    return c
  }
  return Array.from(a)
}
function _objectWithoutProperties(a, b) {
  var c = {
  };
  for (var d in a) b.indexOf(d) >= 0 || Object.prototype.hasOwnProperty.call(a, d) && (c[d] = a[d]);
  return c
}
define('core/utils/getEmbeddedData', [
], function () {
  'use strict';
  return function (a) {
    var b = window.document.getElementById('disqus-' + a);
    try {
      return b && JSON.parse(b.textContent || b.innerHTML)
    } catch (c) {
      return null
    }
  }
}),
define('core/utils/cookies', [
], function () {
  'use strict';
  var a = {
    _doc: window.document,
    create: function (b, c, d) {
      d || (d = {
      });
      var e = b + '=' + c + '; path=' + (d.path || '/'),
      f = d.domain,
      g = d.expiresIn;
      if (f && (e += '; domain=.' + f), '[object Number]' === Object.prototype.toString.call(g)) {
        var h = new Date((new Date).getTime() + g);
        e += '; expires=' + h.toGMTString()
      }
      'https:' === a._doc.location.protocol && (e += '; secure'),
      e += '; SameSite=None',
      a._doc.cookie = e
    },
    read: function (b) {
      for (var c, d = b + '=', e = a._doc.cookie.split(';'), f = 0; f < e.length; f++) if (c = e[f].replace(/^\s+/, ''), 0 === c.indexOf(d)) return c.substring(d.length);
      return null
    },
    erase: function (b, c) {
      var d = {
      };
      for (var e in c) c.hasOwnProperty(e) && (d[e] = c[e]);
      return d.expiresIn = - 1,
      a.create(b, '', d)
    },
    supported: function () {
      return a.create('cookie_support', '1'),
      '1' === a.read('cookie_support') && (a.erase('cookie_support'), !0)
    }
  };
  return a
}),
define('core/utils/fingerprint', [
], function () {
  'use strict';
  function a(a) {
    a = a || {
    };
    var b = a.Math || window.Math,
    c = a.Date || window.Date;
    try {
      var d = (new c).getTimezoneOffset(),
      e = 1,
      f = window.screen;
      f && f.availWidth ? e = f.availWidth * f.availHeight + f.colorDepth : f && f.width && (e = f.width * f.height);
      var g = window.document.documentElement,
      h = g.clientWidth * g.clientHeight;
      return b.abs(17 * d + 25 * e - h)
    } catch (i) {
      return 1
    }
  }
  return {
    get: a
  }
}),
define('core/utils/guid', [
  'core/utils/fingerprint'
], function (a) {
  'use strict';
  function b(a) {
    a = a || {
    };
    var b = a.Uint32Array || window.Uint32Array,
    c = a.crypto || window.crypto,
    d = a.Math || window.Math;
    try {
      var e = new b(1);
      return c.getRandomValues(e),
      e[0]
    } catch (f) {
      return d.floor(1000000000 * d.random())
    }
  }
  function c() {
    var a = window.performance,
    b = a && a.timing;
    if (!b) return 100000;
    var c = b.domainLookupEnd - b.domainLookupStart,
    d = b.connectEnd - b.connectStart,
    e = b.responseStart - b.navigationStart;
    return 11 * c + 13 * d + 17 * e
  }
  function d(d) {
    d = d || {
    };
    var e = d.Math || window.Math,
    f = Number((new Date).getTime().toString().substring(3)),
    g = e.abs(f + c() - a.get()).toString(32);
    return g += b(d).toString(32)
  }
  return {
    generate: d
  }
}),
define('core/utils/hash', [
], function () {
  'use strict';
  var a = function (a) {
    var b,
    c,
    d,
    e = 0;
    if (0 === a.length) return e;
    for (b = 0, c = a.length; b < c; b++) d = a.charCodeAt(b),
    e = (e << 5) - e + d,
    e |= 0;
    return e
  };
  return {
    calculate: a
  }
}),
define('core/analytics/identity', [
  'exports',
  'core/utils/cookies',
  'core/utils/guid',
  'core/utils/hash',
  'core/utils/fingerprint'
], function (a, b, c, d, e) {
  'use strict';
  a.SSP_USER_ID_COOKIE_NAME = 'zeta-ssp-user-id';
  var f = !1,
  g = a.ImpressionManager = function () {
    this.isPrivate = !0,
    this.impId = c.generate()
  };
  g.prototype.COOKIE_NAME = '__jid',
  g.prototype.TTL = 1800000,
  g.prototype.init = function (a) {
    this.isPrivate = a && a.isPrivate,
    this.isPrivate || (this.prevImp = b.read(this.COOKIE_NAME)),
    this.persist()
  },
  g.prototype.setImpressionId = function (a) {
    this.impId = a,
    this.persist()
  },
  g.prototype.persist = function () {
    return this.isPrivate ? void b.erase(this.COOKIE_NAME) : void b.create(this.COOKIE_NAME, this.impId, {
      expiresIn: this.TTL
    })
  };
  var h = a.UniqueManager = function () {
    this.isPrivate = !0
  };
  h.prototype.COOKIE_NAME = 'disqus_unique',
  h.prototype.TTL = 31536000000,
  h.prototype.init = function (a) {
    return this.isPrivate = a && a.isPrivate,
    this.isPrivate ? void b.erase(this.COOKIE_NAME, {
      domain: window.location.host.split(':') [0]
    }) : (this.value = b.read(this.COOKIE_NAME) || c.generate(), void b.create(this.COOKIE_NAME, this.value, {
      domain: window.location.host.split(':') [0],
      expiresIn: this.TTL
    }))
  },
  h.prototype.isPersistent = function () {
    return !this.isPrivate && b.read(this.COOKIE_NAME) === this.value
  },
  a.init = function (b, c) {
    f && !c || (a.impression.init(b), a.unique.init(b), f = !0)
  },
  a.reset = function () {
    f = !1,
    a.impression = new g,
    a.unique = new h
  },
  a.reset(),
  a.clientId = function () {
    var b,
    c = a.unique;
    return c.isPersistent() && (b = c.value),
    b || e.get().toString()
  },
  a.getPercentBucketForString = function (a, b) {
    var c = 100,
    e = Math.abs(d.calculate(a));
    if (b) {
      var f = Math.pow(10, b);
      return e % (c * f) / f
    }
    return e % c
  },
  a.clientPercent = function () {
    return a.getPercentBucketForString(a.clientId())
  }
}),
define('core/config/urls', [
  'common/urls'
], function (a) {
  'use strict';
  return a
}),
define('core/analytics/jester', [
  'jquery',
  'underscore',
  'backbone',
  'core/analytics/identity',
  'core/config/urls'
], function (a, b, c, d, e) {
  'use strict';
  var f = c.Model.extend({
    url: e.jester + '/event.js',
    defaults: {
      experiment: 'default',
      variant: 'control'
    },
    setHostReferrer: function (a) {
      a ? a.indexOf('http') === - 1 || this.set('page_referrer', a) : this.set('page_referrer', 'direct')
    },
    decoratePayload: function (c) {
      c.event || (c.event = 'activity'),
      c = b.extend(this.toJSON(), c),
      b.extend(c, {
        imp: d.impression.impId,
        prev_imp: d.impression.prevImp
      }),
      c.section || (c.section = 'default'),
      c.area || (c.area = 'n/a');
      var e = a.param(c).length;
      if (e > 2048 && this.has('page_referrer')) {
        var f = window.document.createElement('a');
        f.href = this.get('page_referrer');
        var g = f.hostname;
        g && (c.page_referrer_domain = g),
        delete c.page_referrer
      }
      return c
    },
    emit: function (c) {
      return a.ajax({
        url: b.result(this, 'url'),
        data: this.decoratePayload(c),
        dataType: 'script',
        cache: !0
      })
    }
  }),
  g = function (b) {
    var c = new window.Image;
    return c.src = e.jester + '/stat.gif?' + a.param({
      event: b
    }),
    c
  },
  h = function (c, d) {
    if (!b.any(d, function (a) {
      return a < 0
    })) {
      b.each(d, function (a, b) {
        d[b] = Math.round(a)
      });
      var f = new window.Image;
      return f.src = e.jester + '/telemetry/' + c + '.gif?' + a.param(d),
      f
    }
  },
  i = new f;
  return i.setHostReferrer(window.document.referrer),
  {
    ActivityClient: f,
    client: i,
    logStat: g,
    telemetry: h
  }
}),
define('core/utils/urls', [
], function () {
  'use strict';
  var a = {
  },
  b = window.document.createElement('a');
  return a.getOrigin = function (a) {
    b.href = a;
    var c = b.href.split('/');
    return c[0] + '//' + c[2]
  },
  a.getHostName = function (a) {
    return b.href = a,
    b.hostname
  },
  a.getDomainPart = function (b, c) {
    'undefined' == typeof c && (c = 0);
    var d = a.getHostName(b),
    e = d.split('.').reverse();
    return e[c]
  },
  a.getQuery = function (a) {
    return b.href = a,
    b.search
  },
  a.getPathname = function (a) {
    return b.href = a,
    b.pathname
  },
  a
}),
define('core/frameBus', [
  'jquery',
  'underscore',
  'backbone',
  'core/utils/urls'
], function (a, b, c, d) {
  'use strict';
  var e = window.opener || window.parent,
  f = window.name,
  g = window.document.referrer,
  h = {
  };
  h.client = d.getOrigin(window.document.location.href),
  h.secureClient = h.client.replace(/^\w+:\/\//, 'https://'),
  h.host = g ? d.getOrigin(g) : h.client;
  var i = {
    origins: h,
    messageHandler: function (a) {
      a = a.originalEvent;
      var b;
      try {
        b = JSON.parse(a.data)
      } catch (c) {
        return
      }
      b.name && '!' === b.name[0] && a.origin !== h.client && a.origin !== h.secureClient || 'client' === b.scope && i.trigger(b.name, b.data)
    },
    postMessage: function (a) {
      a = JSON.stringify(a),
      e.postMessage(a, '*')
    },
    sendHostMessage: function (a, b) {
      b = b || [
      ],
      i.postMessage({
        scope: 'host',
        sender: f,
        name: a,
        data: b
      })
    }
  };
  return b.extend(i, c.Events),
  a(window).on('message', i.messageHandler),
  a(window).on('unload', function () {
    i.sendHostMessage('die')
  }),
  window.DISQUS = window.DISQUS || {
  },
  window.DISQUS.Bus = i,
  i
}),
define('core/bus', [
  'backbone',
  'underscore',
  'core/frameBus'
], function (a, b, c) {
  'use strict';
  var d = b.extend({
  }, a.Events);
  return d.frame = c,
  d
}),
define('core/utils/storage', [
], function () {
  'use strict';
  var a = function (a) {
    var b = '_dsqstorage_';
    try {
      return a.localStorage.setItem(b, b),
      a.localStorage.getItem(b),
      a.localStorage.removeItem(b),
      !0
    } catch (c) {
      return !1
    }
  }(window),
  b = function () {
    var a = {
    };
    return {
      getItem: function (b) {
        return a.hasOwnProperty(b) ? a[b] : null
      },
      setItem: function (b, c) {
        a[b] = String(c)
      },
      removeItem: function (b) {
        delete a[b]
      },
      clear: function () {
        a = {
        }
      }
    }
  }();
  return {
    get: function (a) {
      var b = null;
      try {
        return b = this.backend.getItem(a),
        JSON.parse(b)
      } catch (c) {
        return b
      }
    },
    set: function (a, b) {
      try {
        this.backend.setItem(a, JSON.stringify(b))
      } catch (c) {
      }
    },
    remove: function (a) {
      try {
        this.backend.removeItem(a)
      } catch (b) {
      }
    },
    clear: function () {
      try {
        this.backend.clear()
      } catch (a) {
      }
    },
    backend: a ? window.localStorage : b,
    isPersistent: a
  }
}),
define('core/utils/auth', [
  'core/utils/cookies'
], function (a) {
  'use strict';
  var b = {
  },
  c = 'disqusauth';
  return b.getFromCookie = function () {
    var b = (a.read(c) || '').replace(/"/g, '').split('|');
    !b || b[1] && b[6] || (b = [
    ], a.erase(c, {
    }));
    var d = parseInt(b[6] || '0', 10);
    return {
      avatarUrl: b[7] ? decodeURIComponent(b[7]) : void 0,
      datetimeFormatting: parseInt(b[4], 10) ? 'absolute' : 'relative',
      id: d,
      isModerator: parseInt(b[8], 10) > 0,
      staff: Boolean(parseInt(b[2], 10)),
      tzOffset: b[5],
      username: b[1],
      isAuthenticated: Boolean(d && '0' !== d)
    }
  },
  b
}),
define('core/switches', [
  'underscore',
  'remote/config',
  'core/analytics/identity',
  'core/utils/storage',
  'core/utils/auth'
], function (a, b, c, d, e) {
  'use strict';
  var f = 'switch:',
  g = {
  },
  h = {
  };
  return h._getKey = function (a) {
    return f + a
  },
  h.disableFeature = function (a) {
    g[a] = !1
  },
  h.resetFeature = function (a) {
    g[a] = null
  },
  h.forceFeature = function (a) {
    g[a] = !0
  },
  h.getSwitchContext = function (a) {
    var c = d.get(this._getKey(a));
    if (null !== c) return c;
    var e = g[a];
    return null != e ? e : (b.lounge && b.lounge.switches || {
    }) [a]
  },
  h.isFeatureActive = function (b, d) {
    var f = h.getSwitchContext(b);
    if (a.isBoolean(f)) return f;
    if (!f) return !1;
    var g = e.getFromCookie(),
    i = {
      percent: c.clientPercent(),
      user_id: g.id,
      username: g.username,
      is_staff: g.staff,
      is_moderator: g.isModerator
    },
    j = a.defaults(d || {
    }, i);
    return a.any(f, function (b, d) {
      var e = j[d];
      if (/percent$/.test(d) && a.isNumber(b)) {
        if (a.isNumber(e)) return b > e;
        if (a.isString(e)) {
          var f = 0;
          return b !== Math.round(b) && (f = b.toString().split('.').pop().length),
          b > c.getPercentBucketForString(e, f)
        }
        return !1
      }
      return a.isArray(b) ? a.contains(b, e) : b === e
    })
  },
  h
}),
define('core/utils/url/serializeArgs', [
  'require',
  'exports',
  'module',
  'core/utils/collection/each'
], function (a, b, c) {
  'use strict';
  var d = a('core/utils/collection/each');
  c.exports = function (a) {
    var b = [
    ];
    return d(a, function (a, c) {
      void 0 !== a && b.push(encodeURIComponent(c) + (null === a ? '' : '=' + encodeURIComponent(a)))
    }),
    b.join('&')
  }
}),
define('core/utils/url/serialize', [
  'require',
  'exports',
  'module',
  'core/utils/url/serializeArgs'
], function (a, b, c) {
  'use strict';
  var d = a('core/utils/url/serializeArgs');
  c.exports = function e(a, b, c) {
    if (b && (a.indexOf('?') === - 1 ? a += '?' : '&' !== a.charAt(a.length - 1) && (a += '&'), a += d(b)), c) {
      var f = {
      };
      return f[(new Date).getTime()] = null,
      e(a, f)
    }
    var g = a.length;
    return '&' === a.charAt(g - 1) ? a.slice(0, g - 1) : a
  }
}),
define('core/utils/isAdBlockEnabled', [
], function () {
  'use strict';
  function a() {
    var a = d.createElement('div');
    return a.setAttribute('class', 'pub_300x250 pub_300x250m pub_728x90 text-ad textAd text_ad text_ads text-ads text-ad-links ad-text adSense adBlock adContent adBanner'),
    a.setAttribute('style', 'width: 1px !important; height: 1px !important; position: absolute !important; left: -10000px !important; top: -1000px !important;'),
    a
  }
  function b(a) {
    if (null === a.offsetParent || 0 === a.offsetHeight || 0 === a.offsetLeft || 0 === a.offsetTop || 0 === a.offsetWidth || 0 === a.clientHeight || 0 === a.clientWidth) return !0;
    if (void 0 !== window.getComputedStyle) {
      var b = window.getComputedStyle(a, null);
      if (b && ('none' === b.getPropertyValue('display') || 'hidden' === b.getPropertyValue('visibility'))) return !0
    }
    return !1
  }
  var c = 100,
  d = window.document;
  return function (e) {
    var f = a();
    d.body.appendChild(f),
    setTimeout(function () {
      var a = b(f);
      d.body.removeChild(f),
      e(a)
    }, c)
  }
}),
define('core/utils/html/toRGBColorString', [
], function () {
  'use strict';
  var a = 'Color components should be numbers.';
  return function (b) {
    var c = Number(b.red),
    d = Number(b.green),
    e = Number(b.blue);
    if (isNaN(c) || isNaN(d) || isNaN(e)) throw new Error(a);
    var f = 'rgb',
    g = [
      c,
      d,
      e
    ],
    h = b.alpha;
    if (h) {
      if (h = Number(h), isNaN(h)) throw new Error(a);
      f += 'a',
      g.push(h)
    }
    return f + '(' + g + ')'
  }
}),
define('core/utils/lang/isString', [
], function () {
  'use strict';
  return function (a) {
    return '[object String]' === Object.prototype.toString.call(a)
  }
}),
define('core/utils/html/setInlineStyle', [
  'require',
  'core/utils/collection/each',
  'core/utils/lang/isString',
  'core/utils/object/extend'
], function (a) {
  'use strict';
  function b(a) {
    return a.replace(/\s+/g, '').toLowerCase()
  }
  var c = a('core/utils/collection/each'),
  d = a('core/utils/lang/isString'),
  e = a('core/utils/object/extend');
  return function (a, f, g) {
    var h = {
    };
    d(f) ? h[f] = g : h = f;
    var i = e({
    }, h);
    c(i, function (a, c) {
      var d = b(c);
      d !== c && (delete i[c], i[d] = a),
      null === a && (i[d] = ''),
      void 0 === a && delete i[d]
    });
    var j = a.style;
    c(i, function (a, b) {
      j.setProperty(b, String(a), 'important')
    })
  }
}),
define('core/utils/html/parseColor', [
  'require',
  'core/utils/html/setInlineStyle'
], function (a) {
  'use strict';
  function b(a) {
    return a.replace(/\s+/g, '').toLowerCase()
  }
  function c(a) {
    return a = a.replace(/^#([a-f0-9])([a-f0-9])([a-f0-9])$/, '#$1$1$2$2$3$3'),
    a = a.slice(1),
    {
      red: parseInt(a.slice(0, 2), 16),
      green: parseInt(a.slice(2, 4), 16),
      blue: parseInt(a.slice(4, 6), 16)
    }
  }
  function d(a) {
    var b = a.match(/^rgb\((\d+),(\d+),(\d+)\)$/);
    return {
      red: parseInt(b[1], 10),
      green: parseInt(b[2], 10),
      blue: parseInt(b[3], 10)
    }
  }
  function e(a) {
    var b = a.match(/^rgba\((\d+),(\d+),(\d+),([\d.]+)\)$/);
    return {
      red: parseInt(b[1], 10),
      green: parseInt(b[2], 10),
      blue: parseInt(b[3], 10),
      alpha: parseFloat(b[4])
    }
  }
  function f(a, b, c, d) {
    return b = window.document.createElement(b),
    h(b, {
      visibility: 'hidden',
      color: c
    }),
    a.appendChild(b),
    c = d(b),
    a.removeChild(b),
    c
  }
  function g(a, c) {
    c = c || {
    };
    var e = c.container || window.document.body;
    return window.getComputedStyle ? (a = f(e, 'span', a, function (a) {
      return window.getComputedStyle(a, null).getPropertyValue('color')
    }), d(b(a))) : (a = f(e, 'textarea', a, function (a) {
      return a.createTextRange().queryCommandValue('ForeColor')
    }), {
      red: 255 & a,
      blue: a >>> 16,
      green: (65280 & a) >>> 8
    })
  }
  var h = a('core/utils/html/setInlineStyle');
  return function (a, f) {
    a = b(a);
    var h;
    if ('transparent' === a) return {
      red: 0,
      green: 0,
      blue: 0,
      alpha: 0
    };
    if ('#' === a.charAt(0)) h = c;
     else if ('rgba(' === a.slice(0, 5)) h = e;
     else if ('rgb(' === a.slice(0, 4)) h = d;
     else {
      if (!/^[a-z]+$/.test(a)) throw new Error('parseColor received unparseable color: ' + a);
      h = g
    }
    return h(a, f)
  }
}),
define('core/host/globalFromSandbox', [
  'require'
], function (a) {
  'use strict';
  var b = window.document,
  c = b.createElement('iframe');
  return c.style.display = 'none',
  function (a, d) {
    var e = d && d[a] || null;
    try {
      return c.parentNode !== b.body && b.body.appendChild(c),
      c.contentWindow[a] || e
    } catch (f) {
      return e
    }
  }
}),
define('core/host/utils', [
  'require',
  'core/utils/browser',
  'core/utils/lang/isString',
  'core/utils/html/getCurrentStyle',
  'core/utils/html/parseColor',
  'core/host/globalFromSandbox'
], function (a) {
  'use strict';
  function b(a) {
    for (var b = [
      /(https?:)?\/\/(www\.)?disqus\.com\/forums\/([\w_-]+)/i,
      /(https?:)?\/\/(www\.)?([\w_-]+)\.disqus\.com/i,
      /(https?:)?\/\/(www\.)?dev\.disqus\.org\/forums\/([\w_-]+)/i,
      /(https?:)?\/\/(www\.)?([\w_-]+)\.dev\.disqus\.org/i
    ], c = 0; c < b.length; c++) {
      var d = a.match(b[c]);
      if (d && d.length && 4 === d.length) return d[3]
    }
    return null
  }
  function c(a, c, d) {
    var e = a.querySelector('script[src*="disqus"][src$="' + c + '"]');
    if (e) {
      var f = e.getAttribute ? e.getAttribute('src') : e.src;
      d = d || b;
      var g = d(f);
      return g ? g.toLowerCase() : null
    }
    return null
  }
  function d(a, b) {
    var c,
    d,
    e = 0,
    f = new Array(a.length);
    for (c = 0; c <= a.length; c++) for (f[c] = new Array(b.length), d = 0; d <= b.length; d++) f[c][d] = 0;
    for (c = 0; c < a.length; c++) for (d = 0; d < b.length; d++) a[c] === b[d] && (f[c + 1][d + 1] = f[c][d] + 1, f[c + 1][d + 1] > e && (e = f[c + 1][d + 1]));
    return e
  }
  function e() {
    for (var a = t.getElementsByTagName('h1'), b = t.title, c = b.length, e = b, f = 0.6, g = function (a) {
      var g,
      h = a.textContent || a.innerText;
      null !== h && void 0 !== h && (g = d(b, h) / c, g > f && (f = g, e = h))
    }, h = 0; h < a.length; h++) g(a[h]);
    return e
  }
  function f(a) {
    return a.toLowerCase().replace(/^\s+|\s+$/g, '').replace(/['"]/g, '')
  }
  function g(a) {
    var b = 0,
    c = 1,
    d = 2;
    if (!s('atob') || !s('requestAnimationFrame')) return c;
    try {
      a.postMessage('ping', '*')
    } catch (e) {
      return d
    }
    return b
  }
  function h(a, b, c) {
    c = c || b;
    var d = q(a, b, c);
    return !d || /color/i.test(b) && 0 === r(d).alpha ? a && h(a.parentNode, b, c) || d : d || null
  }
  function i(a, b, c, d) {
    p(b) && (b = t.createElement(b));
    var e = null;
    return b.style.visibility = 'hidden',
    a.appendChild(b),
    e = h(b, c, d),
    a.removeChild(b),
    e
  }
  function j(a) {
    for (var b, c = i(a, 'span', 'font-family', 'fontFamily'), d = c.split(','), e = {
      courier: 1,
      times: 1,
      'times new roman': 1,
      georgia: 1,
      palatino: 1,
      serif: 1
    }, g = 0; g < d.length; g++) if (b = f(d[g]), e.hasOwnProperty(b)) return !0;
    return !1
  }
  function k(a) {
    var b = t.createElement('a');
    return b.href = Number(new Date),
    r(i(a, b, 'color'), {
      container: a
    })
  }
  function l(a) {
    var b = a.red,
    c = a.green,
    d = a.blue;
    if (a.hasOwnProperty('alpha')) {
      var e = a.alpha,
      f = function (a) {
        return Math.round(a * e + 255 * (1 - e))
      };
      b = f(b),
      c = f(c),
      d = f(d)
    }
    return (299 * b + 587 * c + 114 * d) / 1000
  }
  function m(a) {
    var b = i(a, 'span', 'background-color', 'backgroundColor'),
    c = r(b, {
      container: a
    });
    return 0 === c.alpha ? 'light' : l(c) < 128 ? 'dark' : 'light'
  }
  function n(a) {
    var b = k(a);
    return 0 === b.alpha ? 'light' : l(b) < 128 ? 'dark' : 'light'
  }
  var o = a('core/utils/browser'),
  p = a('core/utils/lang/isString'),
  q = a('core/utils/html/getCurrentStyle'),
  r = a('core/utils/html/parseColor'),
  s = a('core/host/globalFromSandbox'),
  t = window.document,
  u = function () {
    var a,
    b,
    c = function () {
      return !1
    };
    if ('hidden' in t) a = 'hidden',
    b = 'visibilitychange';
     else {
      if (!('webkitHidden' in t)) return {
        isHidden: c,
        listen: c,
        stopListening: c
      };
      a = 'webkitHidden',
      b = 'webkitvisibilitychange'
    }
    return {
      isHidden: function () {
        return t[a]
      },
      listen: function (a) {
        return t.addEventListener(b, a)
      },
      stopListening: function (a) {
        return t.removeEventListener(b, a)
      }
    }
  }(),
  v = function () {
    var a = t.createElement('div');
    a.style.visibility = 'hidden',
    a.style.width = '100px',
    a.style.msOverflowStyle = 'scrollbar',
    t.body.appendChild(a);
    var b = a.offsetWidth;
    a.style.overflow = 'scroll';
    var c = t.createElement('div');
    c.style.width = '100%',
    a.appendChild(c);
    var d = c.offsetWidth;
    return a.parentNode.removeChild(a),
    b - d
  },
  w = {
    getItem: function (a) {
      try {
        return window.localStorage.getItem(a)
      } catch (b) {
      }
    },
    setItem: function (a, b) {
      try {
        return window.localStorage.setItem(a, b)
      } catch (c) {
      }
    }
  },
  x = 1,
  y = function (a) {
    if (a.nodeType === x) {
      var b = q(a, 'max-height', 'maxHeight'),
      c = q(a, 'overflow-y', 'overflowY');
      return b && 'none' !== b && c && 'visible' !== c
    }
  },
  z = 4,
  A = function (a) {
    if (a.nodeType === x) return a.scrollHeight - a.clientHeight > z
  },
  B = function () {
    if (t.querySelector) {
      var a = t.querySelector('link[rel=canonical]');
      if (a) return a.href
    }
  };
  return {
    MAX_Z_INDEX: 2147483647,
    getShortnameFromUrl: b,
    getForum: c,
    guessThreadTitle: e,
    getContrastYIQ: l,
    getColorScheme: m,
    getElementStyle: i,
    getAnchorColor: k,
    getAnchorColorScheme: n,
    normalizeFontValue: f,
    isSerif: j,
    getBrowserSupport: g,
    pageVisibility: u,
    getScrollbarWidth: v,
    browser: o,
    storage: w,
    appearsToHideContent: y,
    hasOverflow: A,
    getCanonicalUrl: B
  }
}),
define('common/utils', [
  'jquery',
  'underscore',
  'loglevel',
  'common/main',
  'common/urls',
  'core/host/utils',
  'core/utils/cookies',
  'core/utils/html/parseColor'
], function (a, b, c, d, e, f, g, h) {
  'use strict';
  var i = window.document,
  j = {
  };
  j.globalUniqueId = function (a) {
    return b.uniqueId(a) + '_' + Number(new Date)
  },
  j.setPublisherColor = function (a) {
    i.documentElement.style.setProperty('--publisher-color', a);
    var b = f.getContrastYIQ(h(a));
    b > 5 && b < 250 && i.documentElement.style.setProperty('--publisher-color-safe', a)
  },
  j.addStylesheetRules = function (a) {
    function c() {
      var e = b.find(i.styleSheets, function (a) {
        var b = a.ownerNode || a.owningElement;
        return b.id === d
      });
      if (!e) return void setTimeout(c, 50);
      for (var f = 0, g = a.length; f < g; f++) {
        var h = 1,
        j = a[f],
        k = j[0],
        l = '';
        '[object Array]' === Object.prototype.toString.call(j[1][0]) && (j = j[1], h = 0);
        for (var m = j.length; h < m; h++) {
          var n = j[h];
          l += n[0] + ':' + n[1] + (n[2] ? ' !important' : '') + ';\n'
        }
        e.insertRule ? e.insertRule(k + '{' + l + '}', e.cssRules.length) : e.addRule(k, l, - 1)
      }
    }
    var d = 'css_' + (new Date).getTime(),
    e = i.createElement('style');
    e.id = d,
    i.getElementsByTagName('head') [0].appendChild(e),
    window.createPopup || e.appendChild(i.createTextNode('')),
    c()
  };
  var k = j.CORS = {
    handler: function (a, b, c) {
      a && c >= 200 && c < 300 ? a() : b && (c < 200 || c >= 300) && b()
    },
    XHR2: function (a, b, c, d) {
      var e = k.handler,
      f = new window.XMLHttpRequest;
      return f.open(a, b, !0),
      f.onreadystatechange = function () {
        f.readyState === window.XMLHttpRequest.DONE && e(c, d, f.status)
      },
      f
    }
  };
  k.request = function () {
    return 'withCredentials' in new window.XMLHttpRequest ? k.XHR2 : function () {
      return null
    }
  }(),
  j.isWindowClosed = function (a) {
    if (!a) return !0;
    try {
      return a.closed || void 0 === a.closed
    } catch (b) {
      return !0
    }
  },
  j.truncate = function (a, b, c) {
    return c = c || '...',
    a.length > b ? a.slice(0, b) + c : a
  },
  j.extractDomainForCookies = function (a) {
    return a.split('/') [2].replace(/:[0-9]+/, '')
  },
  j.cookies = {
    domain: j.extractDomainForCookies(e.root),
    create: function (a, b) {
      var c = 31536000000;
      g.create(a, b, {
        domain: j.cookies.domain,
        expiresIn: c
      })
    },
    read: g.read,
    erase: function (a) {
      g.erase(a, {
        domain: j.cookies.domain
      })
    }
  },
  j.updateURL = function (a, c) {
    var d,
    e = i.createElement('a');
    return c = c || {
    },
    e.href = a,
    c.hostname && c.hostname.match(/\.$/) && (c.hostname += e.hostname),
    d = b.extend({
      protocol: e.protocol,
      hostname: e.hostname,
      pathname: e.pathname,
      search: e.search
    }, c),
    d.pathname.match(/^\//) || (d.pathname = '/' + d.pathname),
    d.protocol + '//' + d.hostname + d.pathname + d.search
  },
  j.injectBaseElement = function (a, b) {
    b = b || i;
    var c = b.getElementsByTagName('base') [0] || b.createElement('base');
    c.target = '_parent',
    a ? c.href = a : c.removeAttribute('href'),
    c.parentNode || (b.head || b.getElementsByTagName('head') [0]).appendChild(c)
  },
  j.syntaxHighlighter = function () {
    var c = 1,
    e = 2,
    f = null,
    g = null,
    h = [
    ],
    i = {
      highlight: function (a) {
        null === g && i._load(),
        h.push(a),
        g === e && i.scheduleHighlight()
      },
      _highlight: function (b) {
        var c = a(b).html();
        a(b).html(c.replace(/^<br>/, '')),
        f.highlightBlock(b),
        i.scheduleHighlight()
      },
      scheduleHighlight: function () {
        var a = h.shift();
        a && window.requestAnimationFrame(b.bind(i._highlight, i, a))
      },
      _load: function () {
        g = c,
        d.loadCss('https://c.disquscdn.com/next/embed/styles/highlight.3128dd90ecaebd8542ac3442033f3f00.css'),
        require(['common/vendor_extensions/highlight'], function (a) {
          g = e,
          f = a,
          i.scheduleHighlight()
        })
      }
    };
    return i
  }();
  var l = a('html');
  j.getPageHeight = function () {
    var b = a('#tos__message'),
    c = b.outerHeight();
    return c && (c += b.offset().top),
    Math.max(c, l.height())
  },
  j.calculatePositionFullscreen = function () {
    return {
      pageOffset: a(window).scrollTop(),
      height: i.documentElement.clientHeight,
      frameOffset: {
        left: 0,
        top: 0
      }
    }
  },
  j.triggerClick = function (a, b) {
    var c,
    d,
    e = a[0],
    f = {
      altKey: !1,
      button: 0,
      ctrlKey: !1,
      metaKey: !1,
      shiftKey: !1
    };
    if (i.createEvent) {
      if (c = i.createEvent('MouseEvents'), b) for (d in f) f.hasOwnProperty(d) && b.hasOwnProperty(d) && (f[d] = b[d]);
      c.initMouseEvent('click', !0, !0, window, 0, 0, 0, 0, 0, f.ctrlKey, f.altKey, f.shiftKey, f.metaKey, 0, null),
      e.dispatchEvent && e.dispatchEvent(c)
    } else if (i.createEventObject) {
      if (c = i.createEventObject(), c.eventType = 'click', b) for (d in f) f.hasOwnProperty(d) && b.hasOwnProperty(d) && (c[d] = b[d]);
      e.fireEvent('onclick', c)
    }
  },
  j.delayLinkClick = function (a, c) {
    a.preventDefault(),
    b.delay(b.bind(j.triggerClick, this, c, a.originalEvent), 100)
  },
  j.mixin = function (a, c, d) {
    var e = a.prototype,
    f = b.extend({
    }, c, d);
    if (b.defaults(e, f), b.defaults(e.events, f.events), void 0 !== e.initialize && void 0 !== f.initialize) {
      var g = e.initialize;
      e.initialize = function () {
        var a = g.apply(this, arguments);
        return f.initialize.apply(this, arguments),
        a
      }
    }
    return a
  },
  j.extractService = function (b, c) {
    var d = '[data-action^=' + c + ']',
    e = a(b);
    e = e.is(d) && e || e.closest(d);
    var f = e.attr('data-action') || ':',
    g = f.split(':') [1];
    return g
  },
  j.getConfigFromHash = function (a) {
    var d,
    e = a.location.hash;
    try {
      d = JSON.parse(decodeURIComponent(String(e).substr(1)))
    } catch (f) {
      c.debug('Failed to parse config from URL hash', f)
    }
    return b.isObject(d) ? d : {
    }
  };
  var m = /[<>]|:\/\//;
  return j.isPlainText = function (a) {
    return !a.match(m)
  },
  j.isDNTEnabled = function (a) {
    return a || (a = window),
    '1' === a.navigator.doNotTrack || 'yes' === a.navigator.doNotTrack || '1' === a.navigator.msDoNotTrack
  },
  j.shouldSample = function (a) {
    var b = parseInt(a, 10);
    return !!b && (!(b > 100) && Math.random() < b / 100)
  },
  j.decorate = function () {
    var a,
    c = b.toArray(arguments),
    d = c.pop();
    return b.isFunction(d) || (a = d, d = c.pop()),
    b.reduceRight(c, function (b, c) {
      return c.call(a || this, b)
    }, function () {
      return d.apply(a || this, arguments)
    })
  },
  j
}),
define('lounge/common', [
], function () {
  'use strict';
  var a,
  b = function (b) {
    a = b
  },
  c = function () {
    return a
  };
  return {
    setLounge: b,
    getLounge: c
  }
});
var _extends = Object.assign || function (a) {
  for (var b = 1; b < arguments.length; b++) {
    var c = arguments[b];
    for (var d in c) Object.prototype.hasOwnProperty.call(c, d) && (a[d] = c[d])
  }
  return a
};
define('lounge/tracking', [
  'jquery',
  'underscore',
  'raven',
  'core/analytics/identity',
  'core/analytics/jester',
  'core/bus',
  'common/urls',
  'core/switches',
  'core/utils',
  'core/utils/hash',
  'core/utils/url/serialize',
  'core/utils/isAdBlockEnabled',
  'core/utils/html/toRGBColorString',
  'remote/config',
  'common/utils',
  'common/main',
  'lounge/common'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q) {
  'use strict';
  function r(n, q) {
    function r(a, c, f) {
      var i = {
        abe: f ? '1' : '0',
        embed_hidden: q.config.isBehindClick ? '1' : '0',
        integration: q.config.integration,
        load_time: Number(new Date) - p.timings.initStart - (p.timings.renderStart && p.timings.bootstrapStart ? p.timings.renderStart - p.timings.bootstrapStart : 0)
      };
      if (h.isFeatureActive('init_embed_activity')) b.extend(i, {
        verb: 'load',
        object_type: 'product',
        object_id: 'embed'
      }),
      e.client.emit(i);
       else {
        var j = a.user.id,
        l = o.isDNTEnabled();
        b.extend(i, {
          event: 'init_embed',
          thread: C,
          forum: z,
          forum_id: A,
          imp: d.impression.impId,
          prev_imp: d.impression.prevImp,
          thread_slug: B.get('slug'),
          user_type: a.user.get('user_type') || 'anon',
          referrer: n.document.referrer,
          theme: 'next',
          dnt: l ? '1' : '0',
          tracking_enabled: c ? '1' : '0'
        }, q.config.experiment),
        j && '0' !== j && (i.user_id = j);
        var m = y.get('settings');
        m && b.has(m, 'adsProductLinksEnabled') && b.extend(i, {
          promoted_enabled: m.adsProductLinksEnabled,
          max_enabled: m.adsPositionTopEnabled
        }),
        (new n.Image).src = k(g.jester + '/event.gif', i, !1)
      }
      if (B.isModerator(a.user)) {
        var r = n.document.createElement('iframe');
        r.src = 'https://disqusads.com/enable-logging',
        r.style.display = 'none',
        n.document.body.appendChild(r)
      }
    }
    function t(a) {
      w = !0,
      x = a,
      s.shouldTrack(y, q.session.user) && (d.init({
      }, !0), s.load3rdParties(B, q))
    }
    var y = q.forum,
    z = y.id,
    A = y.get('pk'),
    B = q.thread,
    C = B.id;
    q.session.on('change:id', function (a) {
      e.client.set('user_id', a.id)
    }),
    q.session.once('change:id', function () {
      var b = this,
      c = s.shouldTrack(y, this.user),
      e = y.get('settings').adsEnabled && s.shouldTrack(y, this.user, !0),
      j = s.shouldLoadLc(y, this.user);
      if (q.config.isPrivate && this.user && this.user.get('hasAcceptedGdprTerms') && d.init({
        isPrivate: !1
      }, !0), c && s.load3rdParties(B, q), !v && h.isFeatureActive('zyncOnly') && e) {
        var k = (new Date).getTime();
        a('body').append(a('<img>').hide().attr('src', g.zyncPixelImage + '&cid=c' + d.unique.value + '&cache_buster=' + k)),
        v = !0
      }
      l(function (a) {
        r(b, c, a)
      }),
      f.frame.sendHostMessage('tracking:init', {
        shouldTrack: c,
        isMobile: i.isMobileUserAgent(n),
        hostIdentityActive: h.isFeatureActive('hostIdentityActive', {
          forum: y.id,
          forum_percent: y.id
        }),
        liveConnectActive: j && h.isFeatureActive('liveConnectActive', {
          forum: y.id,
          forum_percent: y.id
        }),
        unique: d.unique.value,
        sspId: o.cookies.read(d.SSP_USER_ID_COOKIE_NAME)
      })
    }),
    e.client.set({
      product: 'embed',
      thread: C,
      thread_id: C,
      forum: z,
      forum_id: A,
      zone: 'thread',
      version: p.version
    }),
    q.once('bootstrap:complete', function () {
      e.client.set({
        page_url: q.config.referrer
      });
      var a = q.config.experiment;
      a && e.client.set({
        experiment: a.experiment,
        variant: a.variant,
        service: a.service
      }),
      e.client.setHostReferrer(q.config.hostReferrer)
    });
    var D = {
      inViewport: function () {
        var c = q.config,
        d = {
          color_scheme: c.colorScheme,
          anchor_color: m(c.anchorColor),
          typeface: c.typeface,
          width: a(n.document).width()
        },
        f = {
          gpc: window.navigator.globalPrivacyControl ? 1 : 0
        };
        q.meta.topics && (f.topics = q.meta.topics.map(function (a) {
          return a.topic.toString()
        }).join(',')),
        d = b.pick(d, function (a, c) {
          switch (c) {
            case 'width':
              return b.isNumber(a);
            default:
              return b.isString(a) && '' !== a
          }
        }),
        e.client.emit({
          verb: 'view',
          object_type: 'product',
          object_id: 'embed',
          extra_data: JSON.stringify(_extends({
          }, d, f))
        }),
        q.off('inViewport')
      },
      'uiCallback:postCreated': function (a, c) {
        c = c || {
        },
        b.extend(c, {
          object_type: 'post',
          object_id: a.id,
          verb: 'post'
        }),
        a.has('parent') && (c.target_type = 'post', c.target_id = a.get('parent')),
        e.client.emit(c)
      },
      'uiCallback:postUpdated': function (a, c) {
        c = c || {
        },
        b.extend(c, {
          object_type: 'post',
          object_id: a.id,
          verb: 'update'
        }),
        e.client.emit(c)
      },
      'uiAction:postStartUpdate': function (a, c) {
        c = c || {
        },
        b.extend(c, {
          verb: 'click',
          adjective: 'edit',
          object_type: 'link',
          object_id: a.id
        }),
        e.client.emit(c)
      },
      'uiAction:seeMore': function (a) {
        e.client.emit({
          verb: 'open',
          object_type: 'section',
          object_id: 'thread/page-' + a
        })
      },
      'uiAction:seeMoreChildren': function (a) {
        e.client.emit({
          verb: 'click',
          object_type: 'link',
          object_id: 'show_more_comments',
          area: s.getEventTrackingArea(a)
        })
      },
      'uiAction:postUpvote': function (a, b) {
        e.client.emit({
          verb: 'like',
          object_type: 'post',
          object_id: a.id,
          area: s.getEventTrackingArea(b)
        })
      },
      'uiAction:postUnvote': function (a, b) {
        e.client.emit({
          verb: 'unlike',
          object_type: 'post',
          object_id: a.id,
          area: s.getEventTrackingArea(b)
        })
      },
      'uiAction:postDownvote': function (a, b) {
        e.client.emit({
          verb: 'dislike',
          object_type: 'post',
          object_id: a.id,
          area: s.getEventTrackingArea(b)
        })
      },
      'uiAction:threadUnlike': function () {
        e.client.emit({
          verb: 'unlike',
          object_type: 'thread',
          zone: 'thread'
        })
      },
      'uiAction:threadLike': function () {
        e.client.emit({
          verb: 'like',
          object_type: 'thread'
        })
      },
      'uiAction:postShare': function (a, b) {
        e.client.emit({
          verb: 'share',
          object_type: 'post',
          object_id: a.id,
          target_type: 'service',
          target_id: b
        })
      },
      'uiAction:threadShare': function (a) {
        e.client.emit({
          verb: 'share',
          object_type: 'thread',
          target_type: 'service',
          target_id: a
        })
      },
      'uiAction:clickLink': function (a, b) {
        e.client.emit({
          verb: 'click',
          object_type: 'link',
          object_id: a[0].href,
          area: s.getEventTrackingArea(b)
        })
      },
      'uiAction:followUser': function (a) {
        e.client.emit({
          verb: 'follow',
          object_type: 'user',
          object_id: a.id
        })
      },
      'uiAction:unfollowUser': function (a) {
        e.client.emit({
          verb: 'stop-following',
          object_type: 'user',
          object_id: a.id
        })
      },
      'uiAction:openLogin': function (a) {
        e.client.emit({
          verb: 'open',
          object_type: 'login',
          object_id: a
        })
      },
      'uiAction:onboardAlertShow': function () {
        e.client.emit({
          verb: 'view',
          object_type: 'area',
          object_id: 'onboard_alert'
        })
      },
      'uiAction:onboardAlertDismiss': function () {
        e.client.emit({
          verb: 'close',
          object_type: 'area',
          object_id: 'onboard_alert'
        })
      },
      'uiAction:openHome': function (a, b) {
        e.client.emit({
          verb: 'open',
          object_type: 'product',
          object_id: b ? 'bridge' : 'home',
          section: a
        })
      },
      'uiAction:viewBanUser': function () {
        e.client.emit({
          verb: 'view',
          object_type: 'area',
          object_id: 'ban_user'
        })
      },
      'uiAction:clickBanUser': function (a) {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          object_id: 'ban_user',
          extra_data: a
        })
      },
      'uiAction:viewFlagPost': function () {
        e.client.emit({
          verb: 'view',
          object_type: 'area',
          object_id: 'flag_post'
        })
      },
      'uiAction:clickFlagPost': function () {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          object_id: 'flag_post'
        })
      },
      'uiAction:viewBlockUser': function () {
        e.client.emit({
          verb: 'view',
          object_type: 'area',
          object_id: 'block_user'
        })
      },
      'uiAction:clickBlockUser': function () {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          object_id: 'block_user'
        })
      },
      'uiAction:viewUpgradeCard': function () {
        e.client.emit({
          verb: 'hover',
          object_type: 'icon',
          object_id: 'disqus_pro',
          organization_id: y.get('organizationId')
        })
      },
      'uiAction:clickUpgrade': function () {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          object_id: 'subscriptions',
          organization_id: y.get('organizationId')
        })
      },
      'uiAction:clickCommentPolicy': function (a) {
        e.client.emit({
          verb: 'click',
          object_type: 'link',
          section: 'comment_policy',
          object_id: a
        })
      },
      'uiAction:clickThreadPremoderate': function () {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          object_id: 'premoderate_thread'
        })
      },
      viewActivity: function (a, b) {
        var c = {
          verb: 'view',
          object_type: a,
          object_id: b
        };
        e.client.emit(c)
      },
      'uiAction:loadEmailSubscriptionPrompt': function (a) {
        e.client.emit({
          verb: 'load',
          object_type: 'section',
          object_id: 'email_subscriptions',
          section: 'email_subscriptions',
          extra_data: JSON.stringify({
            user_verified: Boolean(q.session.user && q.session.user.get('isVerified')),
            email_subscription_prompt: a
          })
        })
      },
      'uiAction:viewEmailSubscriptionPrompt': function (a) {
        e.client.emit({
          verb: 'view',
          object_type: 'section',
          object_id: 'email_subscriptions',
          section: 'email_subscriptions',
          extra_data: JSON.stringify({
            user_verified: Boolean(q.session.user && q.session.user.get('isVerified')),
            email_subscription_prompt: a
          })
        })
      },
      'uiAction:clickEmailSubscriptionPromptSubscribe': function (a) {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          object_id: 'subscribe',
          section: 'email_subscriptions',
          extra_data: JSON.stringify({
            user_verified: Boolean(q.session.user && q.session.user.get('isVerified')),
            email_subscription_prompt: a
          })
        })
      },
      'uiAction:clickEmailSubscriptionPromptDismiss': function (a) {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          object_id: 'hide_this_message',
          section: 'email_subscriptions',
          extra_data: JSON.stringify({
            user_verified: Boolean(q.session.user && q.session.user.get('isVerified')),
            email_subscription_prompt: a
          })
        })
      },
      'uiAction:viewReactionsPromotion': function () {
        e.client.emit({
          verb: 'view',
          object_type: 'section',
          object_id: 'reactions_onboarding',
          zone: 'thread',
          section: 'reactions_onboarding'
        })
      },
      'uiAction:reactionsEnable': function () {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          object_id: 'enable_reactions',
          zone: 'thread',
          section: 'reactions_onboarding'
        })
      },
      'uiAction:reactionsDefer': function () {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          object_id: 'maybe_later',
          zone: 'thread',
          section: 'reactions_onboarding'
        })
      },
      'uiAction:reactionsVote': function (a) {
        e.client.emit({
          verb: 'vote',
          object_type: 'thread',
          adjective: a.get('text'),
          zone: 'thread',
          section: 'reactions',
          extra_data: JSON.stringify({
            reaction_id: a.id
          })
        })
      },
      'uiAction:gifsClickButton': function () {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          adjective: 'gif_picker',
          object_id: 'thread',
          zone: 'thread'
        })
      },
      'uiAction:gifsScrollToBottom': function () {
        e.client.emit({
          verb: 'view',
          adverb: 'results',
          object_type: 'zone',
          adjective: 'end',
          object_id: 'thread',
          zone: 'thread'
        })
      },
      'uiAction:loadLiveComments': function () {
        e.client.emit({
          verb: 'click',
          adverb: 'comments',
          object_type: 'notification',
          adjective: 'realtime',
          object_id: 'thread',
          zone: 'thread'
        })
      },
      'uiAction:loadLiveReplies': function () {
        e.client.emit({
          verb: 'click',
          adverb: 'replies',
          object_type: 'notification',
          adjective: 'realtime',
          object_id: 'thread',
          zone: 'thread'
        })
      },
      'uiAction:clickBadge': function (a, b) {
        e.client.emit({
          verb: 'click',
          object_type: 'badge',
          object_id: b,
          section: 'profile/badges',
          zone: 'thread',
          area: s.getEventTrackingArea(a)
        })
      },
      'uiAction:viewBadgeModal': function () {
        e.client.emit({
          verb: 'view',
          object_type: 'modal',
          object_id: 'badge',
          section: 'manage_badges',
          zone: 'thread'
        })
      },
      'uiAction:awardBadge': function (a) {
        e.client.emit({
          verb: 'award',
          object_type: 'badge',
          object_id: a,
          section: 'manage_badges',
          zone: 'thread'
        })
      },
      'uiAction:removeBadge': function (a) {
        e.client.emit({
          verb: 'remove',
          object_type: 'badge',
          object_id: a,
          section: 'manage_badges',
          zone: 'thread'
        })
      },
      'uiAction:behindClickButton': function () {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          adjective: 'behind_click',
          object_id: 'thread',
          zone: 'thread'
        })
      },
      'uiAction:toggleClassicDisqus': function (a) {
        e.client.emit({
          verb: 'click',
          object_type: 'button',
          adjective: a,
          object_id: 'toggle_classic_disqus',
          zone: 'thread'
        })
      }
    };
    q.on(D),
    f.on(D),
    f.frame.once('cmp.consent', t),
    f.frame.once('tracking.hostIdentity', function (b) {
      if (!u) {
        var e = [
          j.calculate(b.domain),
          b.id,
          d.unique.value
        ],
        f = a('body'),
        h = g.logger + '/1/' + n.btoa(JSON.stringify(e));
        try {
          f.append(a('<img>').hide().attr('src', h))
        } catch (i) {
          c.captureException(i)
        }
        u = !0
      }
    })
  }
  var s = {
  },
  t = !1,
  u = !1,
  v = !1,
  w = !1,
  x = {
  };
  return s.init = function (a) {
    r(window, a)
  },
  s.getEventTrackingArea = function (b) {
    return a(b.currentTarget).closest('[data-tracking-area]').attr('data-tracking-area')
  },
  s.load3rdParties = function (d, f) {
    if (g.glitter && !t) {
      var h = n.lounge.tracking || {
      },
      i = h.iframe_limit || 0,
      j = {
        postCount: d.get('posts') || 0,
        likeCount: d.get('likes') || 0,
        postVoteCount: b.reduce(d.posts.pluck('likes'), function (a, b) {
          return a + b
        }, 0),
        referrer: encodeURIComponent(f.config.referrer),
        tcString: x.tcString || ''
      };
      a.ajax({
        dataType: 'jsonp',
        cache: !0,
        url: g.glitter,
        data: {
          forum_shortname: d.forum.id,
          thread_id: d.id,
          referer: f.config.hostReferrer,
          tc: x.tcString || ''
        },
        jsonpCallback: 'dsqGlitterResponseHandler',
        success: function (d) {
          var f = a('body');
          b.each(d, function (d) {
            if (!('img' !== d.type && 'iframe' !== d.type || 'iframe' === d.type && (i -= 1, i < 0))) {
              var g;
              try {
                g = d.url.replace(/\{\{(.+?)\}\}/g, function (a, c) {
                  var d = c.trim();
                  if (!j.hasOwnProperty(d)) throw new Error('Unknown template variable in tracker URL: ' + d);
                  return b.escape(j[d])
                });
                var h = a('<' + d.type + '>').hide().attr('src', g);
                d.logging && h.on('load', function () {
                  e.logStat('glitter.loaded.' + d.logging)
                }),
                f.append(h)
              } catch (k) {
                c.captureException(k)
              }
            }
          })
        },
        error: function () {
          e.logStat('glitter.error')
        }
      }),
      t = !0
    }
  },
  s.shouldTrack = function (a, b) {
    var c = arguments.length > 2 && void 0 !== arguments[2] && arguments[2];
    return !(Boolean(a && a.get('settings').disable3rdPartyTrackers ^ c) || s.shouldNotTrackUser(b))
  },
  s.shouldNotTrackUser = function (a) {
    return a && a.get('disable3rdPartyTrackers') || '1' === o.cookies.read('disqus_tracking_optout') || o.isDNTEnabled() || s.isPrivate(a)
  },
  s.shouldLoadLc = function (a, b) {
    return (a.get('settings').adsEnabled || !a.get('settings').disable3rdPartyTrackers) && !s.shouldNotTrackUser(b)
  },
  s.isPrivate = function (a) {
    return q.getLounge().config.isPrivate && (!a || !a.get('hasAcceptedGdprTerms')) && !w
  },
  s.reset = function () {
    t = !1,
    u = !1,
    v = !1,
    w = !1,
    x = {
    }
  },
  s
}),
define('common/jsxUtils', [
  'underscore'
], function (a) {
  'use strict';
  return {
    append: function (b, c) {
      var d = function e(c) {
        if (null !== c) return a.isArray(c) ? void c.forEach(e) : a.isElement(c) || c && c.nodeType === window.Node.DOCUMENT_FRAGMENT_NODE ? void b.appendChild(c) : void b.appendChild(window.document.createTextNode(c))
      };
      d(c)
    }
  }
});
var _extends = Object.assign || function (a) {
  for (var b = 1; b < arguments.length; b++) {
    var c = arguments[b];
    for (var d in c) Object.prototype.hasOwnProperty.call(c, d) && (a[d] = c[d])
  }
  return a
};
define('react', [
  'jquery',
  'underscore',
  'common/jsxUtils'
], function (a, b, c) {
  'use strict';
  var d = window.document;
  return {
    createElement: function (e, f) {
      for (var g = arguments.length, h = Array(g > 2 ? g - 2 : 0), i = 2; i < g; i++) h[i - 2] = arguments[i];
      if ('function' == typeof e) {
        h.length > 0 && (f = _extends({
          children: 1 === h.length ? h[0] : h
        }, f));
        var j = e(f);
        if (b.isArray(j)) {
          var k = d.createDocumentFragment();
          return c.append(k, j),
          k
        }
        return j
      }
      if ('string' != typeof e) throw new Error('Unknown type');
      var l = d.createElement(e),
      m = !1;
      return f && Object.keys(f).forEach(function (b) {
        var c = f[b];
        if (/^(?:data-|aria-|role$)/.test(b)) null !== c && l.setAttribute(b, c);
         else if ('dangerouslySetInnerHTML' === b) m = !0,
        l.innerHTML = c && c.__html || '';
         else if ('style' === b) Object.keys(c).forEach(function (a) {
          l.style[a] = c[a]
        });
         else if (/^on[A-Z]/.test(b)) c && a(l).on(b.slice(2).toLowerCase(), c);
         else if ('key' === b);
         else try {
          l[b] = c
        } catch (d) {
        }
      }),
      m || c.append(l, h),
      l
    }
  }
}),
define('react-dom', [
  'common/jsxUtils'
], function (a) {
  'use strict';
  return {
    render: function (b, c, d) {
      return c && (c.innerHTML = '', a.append(c, b)),
      d && d(),
      null
    }
  }
}),
define('core/shared/urls', [
  'require',
  'core/utils/object/extend',
  'core/utils/url/serialize',
  'core/utils/url/serializeArgs'
], function (a) {
  'use strict';
  var b = a('core/utils/object/extend'),
  c = a('core/utils/url/serialize'),
  d = a('core/utils/url/serializeArgs'),
  e = 'default',
  f = {
    lounge: 'http://disqus.com/embed/comments/',
    home: 'https://disqus.com/home/'.replace('home/', ''),
    recommendations: 'http://disqus.com/recommendations/'
  },
  g = function (a) {
    return 'https://' + a.replace(/^\s*(\w+:)?\/\//, '')
  },
  h = function (a, h, i, j) {
    var k = f[a];
    if (!k) throw new Error('Unknown app: ' + a);
    'preview' === e && j && (e += '-' + j);
    var l = g(k),
    m = b({
      base: e
    }, h || {
    }),
    n = i ? '#' + d(i) : '';
    return c(l, m) + n
  };
  return {
    BASE: e,
    apps: f,
    get: h,
    ensureHTTPSProtocol: g
  }
}),
define('core/apps/BaseApp', [
  'require',
  'core/Events',
  'core/utils/object/extend',
  'core/utils/object/has',
  'core/utils/uniqueId'
], function (a) {
  'use strict';
  var b = a('core/Events'),
  c = a('core/utils/object/extend'),
  d = a('core/utils/object/has'),
  e = a('core/utils/uniqueId'),
  f = function (a) {
    this.uid = e('dsq-app'),
    this.settings = a || {
    };
    var b = [
    ],
    c = this.constructor.prototype;
    do b.unshift(c),
    c = c.constructor.__super__;
    while (c);
    for (var f = 0, g = b.length; f < g; f++) c = b[f],
    d(c, 'events') && this.on(c.events, this),
    d(c, 'onceEvents') && this.once(c.onceEvents, this)
  };
  return c(f.prototype, b),
  f.prototype.destroy = function () {
    this.off(),
    this.stopListening()
  },
  f.extend = function (a, b) {
    var e,
    f = this;
    e = a && d(a, 'constructor') ? a.constructor : function () {
      return f.apply(this, arguments)
    },
    c(e, f, b);
    var g = function () {
      this.constructor = e
    };
    return g.prototype = f.prototype,
    e.prototype = new g,
    a && c(e.prototype, a),
    e.__super__ = f.prototype,
    e
  },
  f
}),
define('core/common/kernel/utils', [
  'require'
], function (a) {
  'use strict';
  function b(a) {
    return e.getElementById(a) || e.body || e.documentElement
  }
  function c(a) {
    return f.href = a,
    f.hostname
  }
  function d(a, b) {
    b = b || e.documentElement;
    for (var c = a, d = 0, f = 0; c && c !== b; ) d += c.offsetLeft,
    f += c.offsetTop,
    c = c.offsetParent;
    return {
      top: f,
      left: d,
      height: a.offsetHeight,
      width: a.offsetWidth
    }
  }
  var e = window.document,
  f = e.createElement('a');
  return {
    getContainer: b,
    getHost: c,
    getOffset: d
  }
}),
define('core/host/json', [
  'require',
  'core/host/globalFromSandbox'
], function (a) {
  'use strict';
  var b,
  c = window,
  d = a('core/host/globalFromSandbox');
  return b = '[object JSON]' === c.Object.prototype.toString.call(c.JSON) ? c.JSON : d('JSON', c),
  b ? b : {
  }
}),
define('core/common/kernel/WindowBase', [
  'require',
  'core/Events',
  'core/utils/object/extend',
  'core/utils/uniqueId',
  'core/common/kernel/utils',
  'core/host/json'
], function (a) {
  'use strict';
  var b = a('core/Events'),
  c = a('core/utils/object/extend'),
  d = a('core/utils/uniqueId'),
  e = a('core/common/kernel/utils'),
  f = a('core/host/json'),
  g = function (a) {
    a = a || {
    },
    this.state = g.INIT,
    this.uid = a.uid || d('dsq-frame'),
    this.origin = a.origin,
    a.useSourcelessFrame ? this.host = e.getHost(window.location.href) : this.host = e.getHost(this.origin),
    this.target = a.target,
    this.sandbox = a.sandbox,
    this.window = null,
    g.windows[this.uid] = this,
    this.on('ready', function () {
      this.state = g.READY
    }, this),
    this.on('die', function () {
      this.state = g.KILLED
    }, this)
  };
  return c(g, {
    INIT: 0,
    READY: 1,
    KILLED: 2,
    windows: {
    },
    postMessage: function (a, b, c) {
      return a.postMessage(b, c)
    }
  }),
  c(g.prototype, b),
  g.prototype.requiresWindow = function (a) {
    var b = this;
    return function () {
      var c = Array.prototype.slice.call(arguments),
      d = function () {
        var e = b.window;
        e ? a.apply(b, c) : setTimeout(d, 500)
      };
      b.isReady() ? d() : b.on('ready', d)
    }
  },
  g.prototype.sendMessage = function (a, b) {
    var c = f.stringify({
      scope: 'client',
      name: a,
      data: b
    });
    this.requiresWindow(function (a) {
      g.postMessage(this.window, a, this.origin)
    }) (c)
  },
  g.prototype.hide = function () {
  },
  g.prototype.show = function () {
  },
  g.prototype.url = function () {
    return this.target
  },
  g.prototype.destroy = function () {
    this.state = g.KILLED,
    this.off()
  },
  g.prototype.isReady = function () {
    return this.state === g.READY
  },
  g.prototype.isKilled = function () {
    return this.state === g.KILLED
  },
  g
}),
define('core/common/kernel/Iframe', [
  'require',
  'core/utils/html/setInlineStyle',
  'core/utils/object/extend',
  'core/common/kernel/WindowBase',
  'core/common/kernel/utils'
], function (a) {
  'use strict';
  var b = a('core/utils/html/setInlineStyle'),
  c = a('core/utils/object/extend'),
  d = a('core/common/kernel/WindowBase'),
  e = a('core/common/kernel/utils'),
  f = window.document,
  g = function (a) {
    d.call(this, a),
    this.styles = a.styles || {
    },
    this.tabIndex = a.tabIndex || 0,
    this.title = a.title || 'Disqus',
    this.sandbox = a.sandbox,
    this.container = a.container,
    this.elem = null
  };
  return c(g.prototype, d.prototype),
  g.prototype.load = function () {
    var a = this.elem = f.createElement('iframe');
    a.setAttribute('id', this.uid),
    a.setAttribute('name', this.uid),
    a.setAttribute('allowTransparency', 'true'),
    a.setAttribute('frameBorder', '0'),
    a.setAttribute('scrolling', 'no'),
    this.role && a.setAttribute('role', this.role),
    a.setAttribute('tabindex', this.tabIndex),
    a.setAttribute('title', this.title),
    'string' == typeof this.sandbox && a.setAttribute('sandbox', this.sandbox),
    this.setInlineStyle(this.styles)
  },
  g.prototype.getOffset = function (a) {
    return e.getOffset(this.elem, a)
  },
  g.prototype.setInlineStyle = function (a, c) {
    return b(this.elem, a, c)
  },
  g.prototype.removeInlineStyle = function (a) {
    var b = this.elem.style;
    return 'removeProperty' in b ? void b.removeProperty(a) : void (b[a] = '')
  },
  g.prototype.hide = function () {
    this.setInlineStyle('display', 'none')
  },
  g.prototype.show = function () {
    this.removeInlineStyle('display')
  },
  g.prototype.destroy = function () {
    return this.elem && this.elem.parentNode && (this.elem.parentNode.removeChild(this.elem), this.elem = null),
    d.prototype.destroy.call(this)
  },
  g
}),
define('core/host/kernel', [
  'require',
  'exports',
  'module',
  'core/Events',
  'core/utils/lang/isString',
  'core/utils/object/has',
  'core/utils/object/extend',
  'core/common/kernel/Iframe',
  'core/common/kernel/utils',
  'core/common/kernel/WindowBase',
  'core/host/json',
  'core/utils/function/throttle'
], function (a, b) {
  'use strict';
  var c = a('core/Events'),
  d = a('core/utils/lang/isString'),
  e = a('core/utils/object/has'),
  f = a('core/utils/object/extend'),
  g = a('core/common/kernel/Iframe'),
  h = a('core/common/kernel/utils'),
  i = a('core/common/kernel/WindowBase'),
  j = a('core/host/json'),
  k = window.document;
  b.throttle = a('core/utils/function/throttle'),
  window.addEventListener('message', function (a) {
    var c;
    try {
      c = j.parse(a.data)
    } catch (d) {
      return
    }
    var f = c.sender,
    g = e(i.windows, f) && i.windows[f];
    g && h.getHost(a.origin) === g.host && (a.origin !== g.origin && (g.origin = a.origin), 'host' === c.scope && g.trigger(c.name, c.data), 'error' === c.name && b.trigger('error', c.data))
  }),
  window.addEventListener('hashchange', function () {
    b.trigger('window.hashchange', {
      hash: window.location.hash
    })
  }),
  window.addEventListener('resize', b.throttle(function () {
    b.trigger('window.resize')
  }, 250, 50)),
  k.addEventListener('mousemove', b.throttle(function () {
    b.trigger('window.mousemove')
  }, 250, 50));
  var l = function () {
    b.trigger('window.scroll')
  };
  window.addEventListener('scroll', b.throttle(l, 250, 50), !1),
  k.addEventListener('click', function () {
    b.trigger('window.click')
  });
  var m = b.Popup = function (a) {
    a.uid = a.windowName,
    i.call(this, a)
  };
  f(m.prototype, i.prototype),
  m.prototype.load = function () {
    var a = this.window = window.open('', this.uid || '_blank');
    a.location = this.url()
  },
  m.prototype.isKilled = function () {
    return i.prototype.isKilled() || this.window.closed
  };
  var n = b.Channel = function (a) {
    var b = this;
    b.window = null,
    g.call(b, a),
    this.insertBeforeEl = a.insertBeforeEl,
    this.insertAfterEl = a.insertAfterEl,
    b.useSourcelessFrame = a.useSourcelessFrame,
    b.styles = f({
      width: '1px',
      'min-width': '100%',
      border: 'none',
      overflow: 'hidden',
      height: '0'
    }, a.styles || {
    })
  };
  f(n.prototype, g.prototype),
  n.prototype.load = function (a) {
    var b = this;
    g.prototype.load.call(b);
    var c = b.elem;
    if (c.setAttribute('width', '100%'), b.useSourcelessFrame) {
      var e = function () {
        var a = new window.XMLHttpRequest;
        a.open('GET', b.url()),
        a.onreadystatechange = function () {
          c.contentWindow && a.readyState === c.contentWindow.XMLHttpRequest.DONE && 200 === a.status && (c.contentWindow.document.open(), c.contentWindow.document.write(a.responseText), c.contentWindow.document.close())
        },
        a.send()
      };
      b.on('redirect', function (a) {
        b.target = a,
        e()
      }),
      e()
    } else c.setAttribute('src', b.url());
    c.addEventListener('load', function () {
      b.window = c.contentWindow,
      a && a()
    });
    var f = d(b.container) ? h.getContainer(b.container) : b.container,
    i = (b.insertAfterEl ? b.insertAfterEl.nextSibling : b.insertBeforeEl) || null;
    f.insertBefore(c, i)
  },
  n.prototype.destroy = function () {
    return this.window = null,
    g.prototype.destroy.call(this)
  },
  b.on = c.on,
  b.off = c.off,
  b.trigger = c.trigger
}),
define('core/apps/WindowedApp', [
  'require',
  'core/utils/object/extend',
  'core/shared/urls',
  'core/apps/BaseApp',
  'core/host/kernel'
], function (a) {
  'use strict';
  var b = a('core/utils/object/extend'),
  c = a('core/shared/urls'),
  d = a('core/apps/BaseApp'),
  e = a('core/host/kernel'),
  f = window.document,
  g = d.extend({
    name: null,
    loaderVersion: null,
    frame: null,
    origin: c.ensureHTTPSProtocol('https://disqus.com'),
    state: null,
    getUrl: function (a, d) {
      return this.loaderVersion && (d = b({
        version: this.loaderVersion
      }, d)),
      c.ensureHTTPSProtocol(c.get(this.name, a, d, this.settings.previewVersion))
    },
    getFrameSettings: function () {
      var a = {
        target: this.getUrl(),
        origin: this.origin,
        uid: this.uid,
        sandbox: this.sandbox
      },
      b = this.settings;
      return b.windowName ? a.windowName = b.windowName : a.container = b.container || f.body,
      b.styles && (a.styles = b.styles),
      a.useSourcelessFrame = b.useSourcelessFrame,
      a
    },
    getFrame: function () {
      var a = this.getFrameSettings(),
      b = a.windowName ? e.Popup : e.Channel;
      return new b(a)
    },
    setState: function (a) {
      var b = this.constructor;
      return a in b.states && (this.state = b.states[a], void this.trigger('state:' + a))
    },
    init: function () {
      var a,
      b = this;
      b.frame = a = this.getFrame(),
      b.listenTo(a, 'all', function (c, d) {
        b.trigger('frame:' + c, d, a)
      }),
      b.listenTo(a, 'resize', function (a) {
        b.lastResizedHeight = a.height
      }),
      b.trigger('change:frame', a),
      b.frame.load(function () {
        b.setState('LOADED')
      }),
      b.setState('INIT')
    },
    destroy: function () {
      var a = this.frame;
      a && (this.stopListening(a), a.destroy()),
      this.setState('KILLED'),
      this.frame = null,
      d.prototype.destroy.call(this)
    },
    events: {
      'frame:ready': function () {
        this.setState('READY')
      }
    }
  }, {
    states: {
      INIT: 0,
      LOADED: 1,
      READY: 2,
      RUNNING: 3,
      KILLED: 4
    }
  });
  return g
}),
define('core/utils/OnceTimer', [
  'require',
  'exports',
  'module'
], function (a, b, c) {
  'use strict';
  c.exports = function (a, b) {
    var c = null,
    d = !1;
    this.start = function () {
      d || (c = setTimeout(function () {
        d = !0,
        a()
      }, b))
    },
    this.clear = function () {
      clearTimeout(c)
    }
  }
}),
define('core/utils/html/toHexColorString', [
], function () {
  'use strict';
  function a(a) {
    if (a = Number(a), isNaN(a) || a > 255) throw new Error('Color components should be numbers less than 256');
    return a = a.toString(16),
    1 === a.length ? '0' + a : String(a)
  }
  return function (b) {
    return '#' + a(b.red) + a(b.green) + a(b.blue)
  }
}),
define('core/utils/sandbox', [
], function () {
  'use strict';
  var a = [
    'allow-forms',
    'allow-pointer-lock',
    'allow-popups',
    'allow-same-origin',
    'allow-scripts',
    'allow-top-navigation'
  ],
  b = function (b) {
    return b ? a.reduce(function (a, c) {
      return b[c] && (a += c + ' '),
      a
    }, '').trim() : ''
  };
  return {
    getAttribute: b
  }
}),
define('core/utils/url/parseQueryString', [
  'core/utils/collection/each'
], function (a) {
  'use strict';
  return function (b) {
    'undefined' == typeof b && (b = window.location.search);
    var c = {
    };
    return a(b.substr(1).split('&'), function (a) {
      var b = a.split('=').map(function (a) {
        return decodeURIComponent(a.replace(/\+/g, '%20'))
      });
      b[0] && (c[b[0]] = b[1])
    }),
    c
  }
}),
define('core/analytics/reporting', [
  'require',
  'core/utils/collection/each',
  'core/utils/url/serialize',
  'core/config/urls'
], function (a) {
  'use strict';
  function b(a) {
    var b = a.split('.'),
    c = b.length > 2 ? b[b.length - 2] : '';
    return c.match(/^[0-9a-f]{32}$/i) && c
  }
  function c(a) {
    (new window.Image).src = g(i + '/stat.gif', {
      event: a
    })
  }
  function d(a) {
    (new window.Image).src = g(i + '/event.gif', a)
  }
  function e(a) {
    var b = new window.URLSearchParams;
    f(a, function (a, c) {
      void 0 !== a && b.append(c, a)
    });
    var c = new window.XMLHttpRequest;
    c.open('POST', i + '/event.json', !0),
    c.withCredentials = !0,
    c.send(b)
  }
  var f = a('core/utils/collection/each'),
  g = a('core/utils/url/serialize'),
  h = a('core/config/urls'),
  i = h.jester;
  return {
    getLoaderVersionFromUrl: b,
    logStat: c,
    reportJester: d,
    reportJesterPOST: e
  }
}),
define('core/ads/safeFrameUtils', [
], function () {
  'use strict';
  var a = function (a) {
    return null !== a && !isNaN(Number(a)) && isFinite(a)
  },
  b = function (a) {
    return Math.min.apply(Math, _toConsumableArray(a)) || 0
  },
  c = function (a) {
    return Math.max.apply(Math, _toConsumableArray(a)) || 0
  };
  return {
    min: b,
    max: c,
    isNumeric: a
  }
});
var _createClass = function () {
  function a(a, b) {
    for (var c = 0; c < b.length; c++) {
      var d = b[c];
      d.enumerable = d.enumerable || !1,
      d.configurable = !0,
      'value' in d && (d.writable = !0),
      Object.defineProperty(a, d.key, d)
    }
  }
  return function (b, c, d) {
    return c && a(b.prototype, c),
    d && a(b, d),
    b
  }
}();
define('core/ads/NodeRect', [
  'core/ads/safeFrameUtils'
], function (a) {
  'use strict';
  var b = function () {
    function b() {
      return _classCallCheck(this, b),
      1 !== arguments.length || a.isNumeric(arguments[0]) ? void this.fromArray(arguments) : Array.isArray(arguments[0]) ? this.fromArray(arguments[0]) : this.fromObject(arguments[0])
    }
    return _createClass(b, [
      {
        key: 'fromArray',
        value: function (a) {
          this.reset(),
          a.length >= 6 ? (this.top = a[0], this.right = a[1], this.bottom = a[2], this.left = a[3], this.width = a[4], this.height = a[5]) : a.length >= 4 ? (this.top = a[0], this.right = a[1], this.bottom = a[2], this.left = a[3]) : 3 === a.length ? (this.top = a[0], this.right = a[1], this.bottom = a[2], this.left = 0) : 2 === a.length ? (this.top = a[0], this.right = a[1], this.bottom = a[0], this.left = a[1]) : (this.top = a[0], this.right = a[0], this.bottom = a[0], this.left = a[0]),
          this.update()
        }
      },
      {
        key: 'fromObject',
        value: function (a) {
          return this.fromArray([a.top,
          a.right,
          a.bottom,
          a.left,
          a.width,
          a.height])
        }
      },
      {
        key: 'update',
        value: function () {
          this.width || (this.width = this.right - this.left),
          this.height || (this.height = this.bottom - this.top)
        }
      },
      {
        key: 'reset',
        value: function (a) {
          a = a || 0,
          this.top = a,
          this.right = a,
          this.bottom = a,
          this.left = a,
          this.width = a,
          this.height = a
        }
      },
      {
        key: 'getArea',
        value: function () {
          return (this.right - this.left) * (this.bottom - this.top)
        }
      }
    ]),
    b
  }();
  return b.getOverlapRect = function (c, d) {
    var e = a.max([c.left,
    d.left]),
    f = a.min([c.left + c.width,
    d.left + d.width]),
    g = a.max([c.top,
    d.top]),
    h = a.min([c.top + c.height,
    d.top + d.height]);
    return f >= e && h >= g && new b(g, f, h, e, f - e, h - g)
  },
  b.getOverlapArea = function (b, c) {
    var d = a.max([0,
    a.min([b.right,
    c.right]) - a.max([b.left,
    c.left])]),
    e = a.max([0,
    a.min([b.bottom,
    c.bottom]) - a.max([b.top,
    c.top])]);
    return d * e
  },
  b
}),
define('core/ads/domUtils', [
  'core/ads/NodeRect'
], function (a) {
  'use strict';
  var b = 9,
  c = function (a) {
    return a && a.parentNode
  },
  d = function (a, b) {
    if (!a) return null;
    var c = window.document.defaultView.getComputedStyle(a);
    return b && c.hasOwnProperty(b) ? c[b] : c
  },
  e = function () {
    return {
      x: window.pageXOffset,
      y: window.pageYOffset
    }
  },
  f = function (b) {
    var c = void 0;
    if (b && b.style) {
      var d = b.style.display;
      b.style.display = 'block',
      c = b.getBoundingClientRect(),
      b.style.display = d,
      c = new a(c);
      var f = e();
      c.left += f.x,
      c.right += f.x,
      c.top += f.y,
      c.bottom += f.y
    } else c = new a(0);
    return c
  },
  g = function (a, b) {
    var c = f(a);
    if (b) {
      var d = f(b);
      c.top = d.top - d.top + b.scrollTop,
      c.bottom = c.top + c.height + b.scrollTop,
      c.left = c.left - d.left + b.scrollLeft,
      c.right = c.left + c.width + b.scrollLeft
    }
    return c
  },
  h = function () {
    var b = e(),
    c = b.y,
    d = b.x + window.innerWidth,
    f = b.y + window.innerHeight,
    g = b.x,
    h = window.innerWidth,
    i = window.innerHeight;
    return new a(c, d, f, g, h, i)
  },
  i = function (a) {
    try {
      return a.nodeType === b ? a : a.ownerDocument
    } catch (c) {
      return null
    }
  },
  j = function (a) {
    var b = i(a),
    c = void 0;
    try {
      b && (c = b.parentWindow || b.defaultView || window)
    } catch (d) {
      c = window
    }
    return c
  },
  k = function (b) {
    var c = j(b),
    d = new a(0, c.innerWidth, c.innerHeight, 0, c.innerWidth, c.innerHeight),
    f = e();
    return d.left += f.x,
    d.right += f.x,
    d.top += f.y,
    d.bottom += f.y,
    d
  },
  l = function (a) {
    var b = i(a);
    if (b) return b.documentElement || b.body
  },
  m = function (b) {
    var c = l(b) || {
    },
    d = new a;
    return d.right = d.width = c.scrollWidth || 0,
    d.bottom = d.height = c.scrollHeight || 0,
    d
  },
  n = function (a, b) {
    for (; b; ) {
      if (b === a) return !0;
      b = b.parentNode
    }
    return !1
  },
  o = function (a) {
    var b = d(a);
    return 'inline-block' === b.display || 'none' !== b['float'] || 'absolute' === b.position || 'fixed' === b.position || 'auto' !== b.width || 'auto' !== b.height
  },
  p = function (a) {
    var b = d(a),
    c = {
    };
    return 'scroll' === b.overflowX || 'auto' === b.overflowX ? c.xscroll = a.offsetWidth - a.clientWidth : c.xscroll = 0,
    'scroll' === b.overflowY || 'auto' === b.overflowY ? c.yscroll = a.offsetHeight - a.clientHeight : c.yscroll = 0,
    c.xhidden = 'hidden' === b.overflowX,
    c.yhidden = 'hidden' === b.overflowY,
    c
  },
  q = function (a) {
    var b = d(a);
    return !!(b.clip && 'auto' !== b.clip || b.clipPath && 'none' !== b.clipPath)
  };
  return {
    getParentNode: c,
    getWindow: j,
    getScroll: e,
    getRect: f,
    getRectRelativeTo: g,
    getViewportRect: h,
    getDocument: i,
    getWindowRect: k,
    getRootNode: l,
    getRootRect: m,
    getNodeStyle: d,
    isParentOf: n,
    hasLayout: o,
    getNodeOverflow: p,
    isNodeClipped: q
  }
});
var _createClass = function () {
  function a(a, b) {
    for (var c = 0; c < b.length; c++) {
      var d = b[c];
      d.enumerable = d.enumerable || !1,
      d.configurable = !0,
      'value' in d && (d.writable = !0),
      Object.defineProperty(a, d.key, d)
    }
  }
  return function (b, c, d) {
    return c && a(b.prototype, c),
    d && a(b, d),
    b
  }
}();
define('core/ads/Geom', [
  'core/ads/domUtils',
  'core/ads/safeFrameUtils'
], function (a, b) {
  'use strict';
  var c = 1,
  d = function () {
    function d(b) {
      _classCallCheck(this, d),
      this.node = b,
      this.document = a.getDocument(b),
      this.window = a.getWindow(b),
      this.root = a.getRootNode(b),
      this.ref = this.getRefNode(b.parentNode)
    }
    return _createClass(d, [
      {
        key: 'getRefNode',
        value: function (b) {
          for (; b && b.nodeType === c; ) {
            var d = a.getNodeStyle(b);
            if (a.hasLayout(b) || 'block' === d.display || 'none' !== d.clear) {
              var e = a.getNodeOverflow(b);
              if (e.xscroll || e.yscroll || e.xhidden || e.yhidden) return b;
              if (a.isNodeClipped(b)) return b
            }
            b = b.parentNode
          }
          return this.root
        }
      },
      {
        key: 'getNodesOver',
        value: function (d, e) {
          e = e || 1;
          var f = [
          ],
          g = a.getRect(d),
          h = a.getRect(this.ref),
          i = a.getViewportRect(d);
          if (!window.document.elementFromPoint) return f;
          for (var j = {
            top: b.max([g.top,
            h.top]) - i.top,
            right: b.min([g.right,
            h.right]) - i.left,
            bottom: b.min([g.bottom,
            h.bottom]) - i.top,
            left: b.max([g.left,
            h.left]) - i.left
          }, k = (j.right - j.left) / 10, l = (j.bottom - j.top) / 10, m = j.left; m < j.right; m += k) for (var n = j.top; n < j.bottom; n += l) {
            for (var o = window.document.elementFromPoint(m, n); o && o.nodeType === c; ) {
              var p = a.getNodeStyle(o);
              if (a.hasLayout(o) || 'block' === p.display || 'none' !== p.clear) break;
              o = o.parentNode
            }
            o && o.nodeType === c && o !== this.node && o !== this.root && !a.isParentOf(o, this.node) && (f.push(o), f.length >= e && (m = j.right, n = j.bottom))
          }
          return f
        }
      },
      {
        key: 'getWindowGeom',
        value: function () {
          var a = this.window.innerHeight || 0,
          b = this.window.innerWidth || 0,
          c = this.window.screenY || this.window.screenTop || 0,
          d = c + a,
          e = this.window.screenX || this.window.screenLeft || 0,
          f = e + b;
          return {
            t: c,
            r: f,
            b: d,
            l: e,
            w: b,
            h: a
          }
        }
      },
      {
        key: 'getSelfGeom',
        value: function () {
          var c = a.getRect(this.node),
          d = a.getRect(this.ref),
          e = a.getNodeStyle(this.node),
          f = a.getWindowRect(this.node),
          g = c.width,
          h = c.height;
          this.ref !== this.root && (g = b.max([0,
          b.min([c.right,
          d.right]) - b.max([c.left,
          d.left])]), h = b.max([0,
          b.min([c.bottom,
          d.bottom]) - b.max([c.top,
          d.top])]));
          var i = b.max([0,
          b.min(c.right, f.right) - b.max([c.left,
          f.left])]),
          j = b.max([0,
          b.min([c.bottom,
          f.bottom]) - b.max([c.top,
          f.top])]),
          k = b.min([g,
          i]),
          l = b.min([h,
          j]),
          m = c.width ? k / c.width : 0,
          n = c.height ? l / c.height : 0,
          o = k * l / (c.width * c.height),
          p = 1,
          q = this.getNodesOver(this.node, p);
          if (q.length) {
            var r = a.getRect(q[0]),
            s = b.max([0,
            b.min([r.right,
            c.right]) - b.max([r.left,
            c.left])]),
            t = b.max([0,
            b.min([r.bottom,
            c.bottom]) - b.max([r.top,
            c.top])]);
            o = b.max([0,
            (k * l - s * t) / (c.width * c.height)])
          }
          var u = a.getScroll();
          return {
            t: c.top - u.y,
            r: c.right - u.x,
            b: c.bottom - u.y,
            l: c.left - u.x,
            z: e.zIndex,
            w: c.width,
            h: c.height,
            xiv: 1 === m ? '1' : Number(m).toFixed(2),
            yiv: 1 === n ? '1' : Number(n).toFixed(2),
            iv: 1 === o ? '1' : Number(o).toFixed(2)
          }
        }
      },
      {
        key: 'getExpandGeom',
        value: function () {
          var c = a.getRect(this.ref),
          d = a.getRect(this.node),
          e = a.getWindowRect(this.node),
          f = {
            top: b.max([c.top,
            e.top]),
            right: b.min([c.right,
            e.right]),
            bottom: b.min([c.bottom,
            e.bottom]),
            left: b.max([c.left,
            e.left])
          },
          g = a.getNodeOverflow(this.ref);
          return {
            t: b.max([0,
            d.top - f.top]),
            r: b.max([0,
            f.right - d.right]),
            b: b.max([0,
            f.bottom - d.bottom]),
            l: b.max([0,
            d.left - f.left]),
            xs: Boolean(g.yscroll),
            yx: Boolean(g.xscroll)
          }
        }
      },
      {
        key: 'getGeom',
        value: function () {
          return {
            win: this.getWindowGeom(),
            self: this.getSelfGeom(),
            exp: this.getExpandGeom()
          }
        }
      }
    ]),
    d
  }(),
  e = {
    get: function (a) {
      var b = new d(a);
      return b.getGeom()
    }
  };
  return e
}),
define('core/ads/ads', [
  'require',
  'core/shared/urls',
  'core/apps/WindowedApp',
  'core/host/json',
  'stance/main',
  'stance/utils',
  'core/common/kernel/WindowBase',
  'core/utils/OnceTimer',
  'core/utils/html/toHexColorString',
  'core/utils/object/extend',
  'core/utils/sandbox',
  'core/utils/url/parseQueryString',
  'core/utils/url/serialize',
  'core/utils/urls',
  'core/utils/urls',
  'core/analytics/reporting',
  'core/ads/Geom'
], function (a) {
  'use strict';
  var b = a('core/shared/urls'),
  c = a('core/apps/WindowedApp'),
  d = a('core/host/json'),
  e = a('stance/main'),
  f = a('stance/utils'),
  g = a('core/common/kernel/WindowBase'),
  h = a('core/utils/OnceTimer'),
  i = a('core/utils/html/toHexColorString'),
  j = a('core/utils/object/extend'),
  k = a('core/utils/sandbox'),
  l = a('core/utils/url/parseQueryString'),
  m = a('core/utils/url/serialize'),
  n = a('core/utils/urls').getOrigin,
  o = a('core/utils/urls').getQuery,
  p = a('core/analytics/reporting'),
  q = a('core/ads/Geom'),
  r = c.extend({
    name: 'ads',
    origin: void 0,
    onceEvents: {
      'view:enter': function () {
        this._reportLegacy({
          verb: 'view',
          adverb: '0ms-no50perc'
        })
      },
      'view:iab': function () {
        this._reportLegacy({
          verb: 'view',
          adverb: 'iab-scroll'
        })
      }
    },
    events: {
      'frame:ready': function (a) {
        this.forumId = a.forumId,
        this._reportLegacy({
          verb: 'load',
          extra_data: a.extraData,
          advertisement_id: a.advertisement_id,
          provider: a.provider
        }),
        this.bindViewEvents(),
        this.triggerGeomUpdate()
      },
      'frame:resize': function (a) {
        this.frame.setInlineStyle('height', a.height + 'px'),
        0 === a.height ? this.trigger('ad-placement-empty') : (a.adWidth && this.frame.setInlineStyle('width', a.adWidth + 'px'), this.trigger('ad-placement-filled')),
        this.triggerGeomUpdate()
      },
      'frame:click': function () {
        this._reportOnce({
          verb: 'click'
        }, 'click')
      },
      'frame:hover': function () {
        this._reportOnce({
          verb: 'hover'
        }, 'hover')
      },
      'frame:error-provider-not-ready': function (a) {
        this._reportLegacy({
          verb: 'fail',
          object_type: 'provider',
          object_id: a.provider || this.getProvider(),
          adverb: 'provider_not_ready'
        })
      },
      'frame:error-no-height': function (a) {
        this._reportLegacy({
          verb: 'fail',
          object_type: 'provider',
          object_id: a.provider || this.getProvider(),
          adverb: 'no_height'
        })
      },
      'frame:clearSandbox': function () {
        this.frame.elem.hasAttribute('sandbox') && this.frame.elem.removeAttribute('sandbox')
      },
      'frame:$sf-init': function () {
        this.settings.isOnHostPage && (this.isSafeframe = !0)
      },
      'frame:error': function (a) {
        this.settings.isOnHostPage && this.postMessageDirect({
          event: 'error',
          data: {
            error: a
          }
        })
      }
    },
    constructor: function () {
      c.apply(this, arguments),
      this.origin = n(this.settings.adUrl),
      this._reportOnceHistory = {
      },
      this.settings.isOnHostPage && (this.detectLazyload = this.detectLazyload.bind(this), window.addEventListener('scroll', this.detectLazyload));
      var a = this.settings.adUrl.indexOf('/ads-iframe/taboola/') >= 0;
      this.settings.useSourcelessFrame = this.settings.sourcelessIframe && this.settings.isOnHostPage && (!this.settings.defaultPlacementUrl || !this.settings.adBlockEnabled) && !a
    },
    init: function () {
      if (this.settings.forum = l(o(this.settings.adUrl)).shortname, this.settings.forum) {
        var a = window.navigator && window.navigator.userAgent || window.navigator && window.navigator.vendor || window.opera,
        d = this.settings.disableAdsIos && /iP(hone|od|ad)/.test(a) || this.settings.disableAdsAndroid && /Android/.test(a),
        e = this.settings.disableAds,
        f = this.settings.isInHome || this.settings.isOnHostPage && 0 === window.location.href.indexOf(b.apps.home);
        if (!f && e && this.settings.canDisableAds || d) return void this.trigger('prevented-ad-load');
        this._reportOnce({
          verb: 'call',
          object_type: 'provider',
          object_id: this.getProvider(),
          adjective: 1
        }, 'call'),
        this.settings.sandboxAds && (this.sandbox = k.getAttribute({
          'allow-scripts': !0,
          'allow-same-origin': !0,
          'allow-forms': !0,
          'allow-popups': !0
        })),
        c.prototype.init.call(this)
      }
    },
    detectLazyload: function () {
      if (this.frame && this.settings.isOnHostPage) {
        var a = this.frame.elem.getBoundingClientRect().top,
        b = a - window.innerHeight,
        c = window.innerHeight * this.settings.lazyloadViewports;
        b < c && (this.postMessageDirect({
          event: 'lazyload'
        }), window.removeEventListener('scroll', this.detectLazyload))
      }
    },
    getProvider: function () {
      if (this._provider) return this._provider;
      var a = this.settings.adUrl.match(/provider=(\w+)/);
      return a && (this._provider = a[1]),
      this._provider
    },
    getUrl: function () {
      var a,
      b = this.settings;
      return a = 'inthreaddisqusadstxt' === b.experiment.experiment && 'active' === b.experiment.variant && 'inthread' === b.placement ? window.document.location.href : b.isOnHostPage ? b.url || window.document.location.href : b.url || b.referrer,
      m(b.adUrl, {
        anchorColor: i(b.anchorColor),
        colorScheme: b.colorScheme,
        sourceUrl: a,
        typeface: b.typeface,
        canonicalUrl: b.canonicalUrl,
        disqus_version: b.version,
        deviceWidth: b.deviceWidth,
        maxWidth: b.maxWidth
      })
    },
    triggerGeomUpdate: function () {
      if (this.frame.elem && this.isSafeframe && this.settings.isOnHostPage) {
        var a = q.get(this.frame.elem);
        this.postMessageDirect({
          event: 'geom-update',
          data: {
            geom: a
          }
        })
      }
    },
    bindViewEvents: function () {
      if (!this._viewEventsBound) {
        this._viewEventsBound = !0,
        e.bindWindowEvents(!0);
        var a = this,
        b = function (b, c) {
          a.postMessageDirect({
            event: b,
            percentViewable: c
          })
        },
        c = 1000,
        d = new h(function () {
          a.trigger('view:iab'),
          b('view:iab')
        }, c),
        g = !1;
        this.listenTo(e({
          el: this.frame.elem
        }), {
          enter: function () {
            a.trigger('view:enter'),
            b('view:enter'),
            a.triggerGeomUpdate()
          },
          exit: function () {
            b('view:exit'),
            g && (g = !1, b('view:50out'), d.clear()),
            a.triggerGeomUpdate()
          },
          visible: function (c, e) {
            var h = f.visiblePercent(e, c.offset()),
            i = 50;
            h >= i && !g ? (g = !0, b('view:50in'), d.start()) : h < i && g && (g = !1, b('view:50out'), d.clear()),
            b('view', h),
            a.triggerGeomUpdate()
          }
        })
      }
    },
    postMessageDirect: function (a) {
      this.frame.requiresWindow(function (a) {
        var b = d.stringify(j({
        }, a, {
          space: 'disqus'
        }));
        g.postMessage(this.window, b, this.origin),
        g.postMessage(this.window, 'disqus.' + a.event, this.origin)
      }) (a)
    },
    _report: function (a) {
      var b = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : {
      },
      c = this.settings,
      d = b.provider || this.getProvider();
      a.forum_id = c.forumId || this.forumId;
      var e;
      e = c.placement && c.placement.indexOf('timeline') > - 1 ? 'home' : 'recommendations' === c.placement ? 'recommendations' : 'embed';
      var f = b.usePOST ? 'reportJesterPOST' : 'reportJester';
      p[f](j({
        imp: c.impressionId,
        experiment: c.experiment.experiment,
        variant: c.experiment.variant,
        service: c.experiment.service,
        area: c.placement,
        product: e,
        forum: c.forum,
        zone: 'thread',
        version: c.loaderVersion,
        page_url: c.referrer || window.document.location.href,
        page_referrer: c.hostReferrer || window.document.referrer,
        object_type: 'advertisement',
        provider: d,
        event: 'activity'
      }, a))
    },
    _reportLegacy: function (a) {
      var b = this.settings;
      this._report(j({
        ad_product_name: 'iab_display',
        ad_product_layout: 'iab_display',
        bin: 'embed:promoted_discovery:' + b.experiment.service + ':' + b.experiment.experiment + ':' + b.experiment.variant,
        object_id: a.advertisement_id ? '[' + a.advertisement_id + ']' : '',
        section: 'default'
      }, a))
    },
    _reportOnce: function (a, b) {
      this._reportOnceHistory[b] || (this._reportLegacy(a), this._reportOnceHistory[b] = !0)
    },
    getFrameSettings: function () {
      var a = c.prototype.getFrameSettings.call(this);
      return a.insertBeforeEl = this.settings.insertBeforeEl,
      a.insertAfterEl = this.settings.insertAfterEl,
      a
    }
  }),
  s = function (a) {
    return a = a || {
    },
    a.experiment || (a.experiment = {
      experiment: a.experimentName,
      variant: a.experimentVariant,
      service: a.experimentService
    }),
    new r(a)
  };
  return {
    Ads: s
  }
}),
define('core/api', [
  'jquery',
  'underscore',
  'backbone',
  'core/config',
  'core/utils'
], function (a, b, c, d, e) {
  'use strict';
  function f(a) {
    return l.href = a,
    l.origin || l.protocol + '//' + l.hostname + (l.port ? ':' + l.port : '')
  }
  function g(a) {
    return a.replace(/^(http:)?\/\//, 'https://')
  }
  function h(c) {
    c = b.defaults(c, m),
    c.traditional = !0,
    f(window.location.href) !== f(c.url) && (c.xhrFields = {
      withCredentials: !0
    }),
    c.omitDisqusApiKey || (c.data = c.data || {
    }, window.FormData && c.data instanceof window.FormData ? c.url = e.serialize(c.url, {
      api_key: d.keys.api
    }) : c.data.api_key = d.keys.api);
    var g = c.error;
    return c.error = function (a) {
      n.trigger('error', a),
      b.isFunction(g) && g(a)
    },
    a.ajax(c)
  }
  function i(a) {
    return /(https?:)?\/\//.test(a) ? g(a) : d.urls.api + a
  }
  function j(a, c) {
    return c = c || {
    },
    c.url = i(a),
    c.omitDisqusApiKey || (c.data = b.extend(c.data || {
    }, {
      api_key: d.keys.api
    })),
    n.trigger('call', c),
    h(c).always(b.bind(this.trigger, this, 'complete', c))
  }
  var k = window.document,
  l = k.createElement('a'),
  m = {
  },
  n = {
    ERROR_CODES: {
      OBJ_NOT_FOUND: 8,
      MAX_ITEMS_REACHED: 24
    },
    ajax: h,
    call: j,
    getURL: i,
    defaults: function (a) {
      Object.keys(a).forEach(function (c) {
        var d = a[c],
        e = m[c];
        b.isObject(d) && b.isObject(e) ? b.extend(e, d) : m[c] = d
      })
    },
    headers: function (a) {
      var c = b.extend({
      }, m.headers, a);
      return m.headers = b.pick(c, Boolean),
      m.headers
    },
    makeHttps: g
  };
  return b.extend(n, c.Events),
  n
}),
define('core/mediaConfig', [
  'underscore',
  'backbone'
], function (a, b) {
  'use strict';
  function c() {
    var b = window.document.body.offsetWidth,
    c = d,
    e = c.length;
    return a.find(c, function (a, d) {
      return d + 1 === e || Math.abs(c[d + 1] - b) > Math.abs(c[d] - b)
    })
  }
  var d = [
    320,
    480,
    600,
    800
  ],
  e = new b.Model({
    collapsed: !1,
    defaultIframeHeight: 300,
    mediaPersistedWidths: d,
    loadedThumbnailWidth: c()
  });
  return e.findClosestThumbnailSize = c,
  e
}),
define('core/mixins/appliesPublisherClasses', [
  'jquery',
  'underscore',
  'core/switches',
  'remote/config'
], function (a, b, c, d) {
  'use strict';
  function e() {
    this._getStyleProperty = function (a) {
      var b = this.forum.get(a);
      return this.config.forceAutoStyles || 'auto' === b ? this.config[a] : b
    },
    this.getTypeface = function () {
      return this._getStyleProperty('typeface')
    },
    this.getColorScheme = function () {
      return this._getStyleProperty('colorScheme')
    },
    this.getAnchorColorScheme = function () {
      return this.config.anchorColorScheme
    },
    this.getFont = function () {
      return this.forum.get('customFont')
    },
    this.convertFontToClass = function (a) {
      return a ? a.toLowerCase().replace(/\+/g, '-') : ''
    },
    this.convertFontToStyle = function (a) {
      return a ? a.replace(/\+/g, ' ') : ''
    },
    this.isFontAllowed = function (a) {
      return !(!a || !d.lounge.font_options) && d.lounge.font_options.some(function (b) {
        return a === b.name
      })
    },
    this.downloadFont = function (a) {
      var b = window.document,
      c = b.createElement('style');
      c.type = 'text/css';
      var d = this.convertFontToClass(a.name),
      e = this.convertFontToStyle(a.name),
      f = a.category,
      g = '@import url("https://fonts.googleapis.com/css2?family=' + a.name + ':ital,wght@0,400;0,500;0,600;0,700;1,400;1,700&display=swap"); ',
      h = [
        '',
        'input',
        'select',
        'textarea'
      ].map(function (a) {
        return 'body.' + d + ' ' + a
      }).join(', ');
      g += h + ' { font-family: ' + e + ', ' + f + '; }',
      c.styleSheet ? c.styleSheet.cssText = g : c.appendChild(b.createTextNode(g));
      var i = b.head || b.getElementsByTagName('head') [0] || b.body;
      i.appendChild(c)
    },
    this.applyPublisherClasses = function () {
      var e = a('body'),
      f = this.getFont();
      !f && c.isFeatureActive('embed_refresh', {
        forum: this.forum.id
      }) && 'sans-serif' === this.getTypeface() && (f = 'Roboto');
      var g = f && b.find(d.lounge.font_options, function (a) {
        return a.name === f
      });
      g ? (this.downloadFont(g), e.addClass(this.convertFontToClass(g.name))) : 'serif' === this.getTypeface() ? e.addClass('serif') : e.addClass('sans-serif'),
      'dark' === this.getColorScheme() && e.addClass('dark'),
      c.isFeatureActive('embed_refresh', {
        forum: this.forum.id
      }) && ('dark' === this.getAnchorColorScheme() ? e.addClass('dark-anchor') : e.addClass('light-anchor'))
    }
  }
  return e
}),
define('core/templates/handlebars.partials', [
  'handlebars'
], function (a) {
  a.registerPartial('cardGuestUser', a.template({
    1: function (a, b, c, d, e) {
      var f,
      g = null != b ? b : a.nullContext || {
      },
      h = a.lambda,
      i = a.escapeExpression;
      return '<li class="user ' + (null != (f = c['if'].call(g, null != b ? b.highlight : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(2, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 2,
            column: 16
          },
          end: {
            line: 2,
            column: 49
          }
        }
      })) ? f : '') + '" data-role="guest">\n<span class="avatar ' + (null != (f = c['if'].call(g, null != b ? b.isRefreshEnabled : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(4, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 3,
            column: 20
          },
          end: {
            line: 3,
            column: 66
          }
        }
      })) ? f : '') + '" title="' + i(h(null != b ? b.guestText : b, b)) + '">\n' + (null != (f = c['if'].call(g, null != b ? b.isRefreshEnabled : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(6, e, 0),
        inverse: a.program(8, e, 0),
        data: e,
        loc: {
          start: {
            line: 4,
            column: 0
          },
          end: {
            line: 8,
            column: 7
          }
        }
      })) ? f : '') + '</span>\n<span class="username ' + (null != (f = c['if'].call(g, null != b ? b.isRefreshEnabled : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(10, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 10,
            column: 22
          },
          end: {
            line: 10,
            column: 70
          }
        }
      })) ? f : '') + '" title="' + i(h(null != b ? b.guestText : b, b)) + '">\n' + i(h(null != b ? b.guestText : b, b)) + '\n</span>\n</li>\n'
    },
    2: function (a, b, c, d, e) {
      return 'highlight'
    },
    4: function (a, b, c, d, e) {
      return 'avatar--refresh'
    },
    6: function (a, b, c, d, e) {
      return '<div class="initials initials--small">G</div>\n'
    },
    8: function (a, b, c, d, e) {
      var f = a.escapeExpression;
      return '<img src="' + f(a.lambda(null != b ? b.guestAvatarUrl : b, b)) + '" alt="' + f(c.gettext.call(null != b ? b : a.nullContext || {
      }, 'Avatar', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 7,
            column: 35
          },
          end: {
            line: 7,
            column: 55
          }
        }
      })) + '" />\n'
    },
    10: function (a, b, c, d, e) {
      return 'username--refresh'
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f;
      return null != (f = c['if'].call(null != b ? b : a.nullContext || {
      }, null != b ? b.guestCount : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(1, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 1,
            column: 0
          },
          end: {
            line: 14,
            column: 7
          }
        }
      })) ? f : ''
    },
    useData: !0
  })),
  a.registerPartial('cardGuestVoterText', a.template({
    1: function (a, b, c, d, e) {
      return ' ' + a.escapeExpression(c.gettext.call(null != b ? b : a.nullContext || {
      }, '%(guestCount)s Guest Votes', {
        name: 'gettext',
        hash: {
          guestCount: null != b ? b.guestCount : b
        },
        data: e,
        loc: {
          start: {
            line: 1,
            column: 26
          },
          end: {
            line: 1,
            column: 90
          }
        }
      })) + ' '
    },
    3: function (a, b, c, d, e) {
      return ' ' + a.escapeExpression(c.gettext.call(null != b ? b : a.nullContext || {
      }, '1 Guest Vote', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 1,
            column: 100
          },
          end: {
            line: 1,
            column: 126
          }
        }
      })) + ' '
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f,
      g = null != b ? b : a.nullContext || {
      };
      return (null != (f = c['if'].call(g, c.gt.call(g, null != b ? b.guestCount : b, 1, {
        name: 'gt',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 1,
            column: 6
          },
          end: {
            line: 1,
            column: 23
          }
        }
      }), {
        name: 'if',
        hash: {
        },
        fn: a.program(1, e, 0),
        inverse: a.program(3, e, 0),
        data: e,
        loc: {
          start: {
            line: 1,
            column: 0
          },
          end: {
            line: 1,
            column: 134
          }
        }
      })) ? f : '') + '\n'
    },
    useData: !0
  })),
  a.registerPartial('cardOtherUserText', a.template({
    1: function (a, b, c, d, e) {
      return ' ' + a.escapeExpression(c.gettext.call(null != b ? b : a.nullContext || {
      }, '%(guestCount)s Others', {
        name: 'gettext',
        hash: {
          guestCount: null != b ? b.guestCount : b
        },
        data: e,
        loc: {
          start: {
            line: 1,
            column: 26
          },
          end: {
            line: 1,
            column: 85
          }
        }
      })) + ' '
    },
    3: function (a, b, c, d, e) {
      return ' ' + a.escapeExpression(c.gettext.call(null != b ? b : a.nullContext || {
      }, '1 Other', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 1,
            column: 95
          },
          end: {
            line: 1,
            column: 116
          }
        }
      })) + ' '
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f,
      g = null != b ? b : a.nullContext || {
      };
      return (null != (f = c['if'].call(g, c.gt.call(g, null != b ? b.guestCount : b, 1, {
        name: 'gt',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 1,
            column: 6
          },
          end: {
            line: 1,
            column: 23
          }
        }
      }), {
        name: 'if',
        hash: {
        },
        fn: a.program(1, e, 0),
        inverse: a.program(3, e, 0),
        data: e,
        loc: {
          start: {
            line: 1,
            column: 0
          },
          end: {
            line: 1,
            column: 124
          }
        }
      })) ? f : '') + '\n'
    },
    useData: !0
  })),
  a.registerPartial('cardUser', a.template({
    1: function (a, b, c, d, e) {
      return 'highlight'
    },
    3: function (a, b, c, d, e) {
      return 'data-action="profile"'
    },
    5: function (a, b, c, d, e) {
      var f,
      g = null != b ? b : a.nullContext || {
      };
      return '<span class="avatar ' + (null != (f = c['if'].call(g, null != b ? b.isRefreshEnabled : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(6, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 4,
            column: 20
          },
          end: {
            line: 4,
            column: 66
          }
        }
      })) ? f : '') + '">\n' + (null != (f = c['if'].call(g, null != b ? b.isRefreshEnabled : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(8, e, 0),
        inverse: a.program(9, e, 0),
        data: e,
        loc: {
          start: {
            line: 5,
            column: 0
          },
          end: {
            line: 13,
            column: 7
          }
        }
      })) ? f : '') + '</span>\n<span class="username ' + (null != (f = c['if'].call(g, null != b ? b.isRefreshEnabled : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(13, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 15,
            column: 22
          },
          end: {
            line: 15,
            column: 70
          }
        }
      })) ? f : '') + '">\n' + a.escapeExpression(a.lambda(null != b ? b.name : b, b)) + '\n</span>\n'
    },
    6: function (a, b, c, d, e) {
      return 'avatar--refresh'
    },
    8: function (a, b, c, d, e) {
      var f;
      return null != (f = c['if'].call(null != b ? b : a.nullContext || {
      }, null != (f = null != b ? b.avatar : b) ? f.isCustom : f, {
        name: 'if',
        hash: {
        },
        fn: a.program(9, e, 0),
        inverse: a.program(11, e, 0),
        data: e,
        loc: {
          start: {
            line: 6,
            column: 0
          },
          end: {
            line: 10,
            column: 7
          }
        }
      })) ? f : ''
    },
    9: function (a, b, c, d, e) {
      var f,
      g = a.escapeExpression;
      return '<img src="' + g(a.lambda(null != (f = null != b ? b.avatar : b) ? f.cache : f, b)) + '" alt="' + g(c.gettext.call(null != b ? b : a.nullContext || {
      }, 'Avatar', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 7,
            column: 33
          },
          end: {
            line: 7,
            column: 53
          }
        }
      })) + '" />\n'
    },
    11: function (a, b, c, d, e) {
      return '<div class="initials initials--small">' + a.escapeExpression(a.lambda(null != b ? b.initials : b, b)) + '</div>\n'
    },
    13: function (a, b, c, d, e) {
      return 'username--refresh'
    },
    15: function (a, b, c, d, e) {
      var f,
      g = null != b ? b : a.nullContext || {
      },
      h = a.lambda,
      i = a.escapeExpression;
      return '<a class="avatar ' + (null != (f = c['if'].call(g, null != b ? b.isRefreshEnabled : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(6, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 19,
            column: 17
          },
          end: {
            line: 19,
            column: 63
          }
        }
      })) ? f : '') + '" href="' + i(h(null != b ? b.profileUrl : b, b)) + '" title="' + i(h(null != b ? b.name : b, b)) + '" target="_blank" rel="noopener noreferrer">\n' + (null != (f = c['if'].call(g, null != b ? b.isRefreshEnabled : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(8, e, 0),
        inverse: a.program(9, e, 0),
        data: e,
        loc: {
          start: {
            line: 20,
            column: 0
          },
          end: {
            line: 28,
            column: 7
          }
        }
      })) ? f : '') + '</a>\n<a class="username ' + (null != (f = c['if'].call(g, null != b ? b.isRefreshEnabled : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(13, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 30,
            column: 19
          },
          end: {
            line: 30,
            column: 67
          }
        }
      })) ? f : '') + '" href="' + i(h(null != b ? b.profileUrl : b, b)) + '" title="' + i(h(null != b ? b.name : b, b)) + '" target="_blank" rel="noopener noreferrer">\n' + i(h(null != b ? b.name : b, b)) + '\n</a>\n'
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f,
      g = null != b ? b : a.nullContext || {
      };
      return '<li class="user ' + (null != (f = c['if'].call(g, null != b ? b.highlight : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(1, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 1,
            column: 16
          },
          end: {
            line: 1,
            column: 49
          }
        }
      })) ? f : '') + '" ' + (null != (f = c.unless.call(g, c['switch'].call(g, 'sso_less_branding', {
        name: 'switch',
        hash: {
          forum: null != b ? b.forumId : b
        },
        data: e,
        loc: {
          start: {
            line: 1,
            column: 61
          },
          end: {
            line: 1,
            column: 103
          }
        }
      }), {
        name: 'unless',
        hash: {
        },
        fn: a.program(3, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 1,
            column: 51
          },
          end: {
            line: 1,
            column: 137
          }
        }
      })) ? f : '') + ' data-username="' + a.escapeExpression(a.lambda(null != b ? b.username : b, b)) + '">\n' + (null != (f = c.if_all.call(g, c['switch'].call(g, 'sso_less_branding', {
        name: 'switch',
        hash: {
          forum: null != b ? b.forumId : b
        },
        data: e,
        loc: {
          start: {
            line: 3,
            column: 10
          },
          end: {
            line: 3,
            column: 52
          }
        }
      }), c.ne.call(g, null != b ? b.isSSOProfileUrl : b, !0, {
        name: 'ne',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 3,
            column: 53
          },
          end: {
            line: 3,
            column: 78
          }
        }
      }), {
        name: 'if_all',
        hash: {
        },
        fn: a.program(5, e, 0),
        inverse: a.program(15, e, 0),
        data: e,
        loc: {
          start: {
            line: 3,
            column: 0
          },
          end: {
            line: 33,
            column: 11
          }
        }
      })) ? f : '') + '</li>\n'
    },
    useData: !0
  })),
  a.registerPartial('carouselArrowLeft', a.template({
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      return '<button class="carousel-control carousel-control__previous"><span class="icon icon-right-bracket icon-flipped"></span></button>\n'
    },
    useData: !0
  })),
  a.registerPartial('carouselArrowRight', a.template({
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      return '<button class="carousel-control carousel-control__next"><span class="icon icon-right-bracket"></span></button>\n'
    },
    useData: !0
  })),
  a.registerPartial('channelsHeader', a.template({
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f = null != b ? b : a.nullContext || {
      },
      g = a.escapeExpression;
      return '<div class="channel-homepage-cover">\n<div class="channel-homepage-cover--header">\n<div class="align-inline spacing-top">\n<div class="module-header__icon icon-colorful spacing-right">\n<svg class="icon-discover" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" x="0px" y="0px" viewBox="0 0 18 18" enable-background="new 0 0 18 18" xml:space="preserve" width="26" height="26"><rect x="14" width="4" height="4" class="dot"/><rect x="14" y="7" width="4" height="4" class="dot"/><rect x="14" y="14" width="4" height="4" class="dot"/><rect x="7" width="4" height="4" class="dot"/><rect x="7" y="7" width="4" height="4" class="dot"/><rect x="7" y="14" width="4" height="4" class="dot"/><rect width="4" height="4" class="dot"/><rect y="7" width="4" height="4" class="dot"/><rect y="14" width="4" height="4" class="dot"/></g></svg>\n</div>\n<div class="module-header__title">\n<h1 class="text-larger text-darker">' + g(c.gettext.call(f, 'Channels', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 8,
            column: 36
          },
          end: {
            line: 8,
            column: 58
          }
        }
      })) + '</h1>\n</div>\n</div>\n<p class="text-medium text-gray spacing-bottom-narrow">' + g(c.gettext.call(f, 'Places to start your own discussions.', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 11,
            column: 55
          },
          end: {
            line: 11,
            column: 106
          }
        }
      })) + '</p>\n</div>\n<div class="metadata-hidden visible-lg spacing-left-small">\n<button\nclass="button button-fill--brand"\ntitle=' + g(c.gettext.call(f, 'Info', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 16,
            column: 6
          },
          end: {
            line: 16,
            column: 24
          }
        }
      })) + '\ndata-action="show-metadata">\n' + g(c.gettext.call(f, 'About', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 18,
            column: 0
          },
          end: {
            line: 18,
            column: 19
          }
        }
      })) + '\n</button>\n</div>\n</div>\n<div class="metadata-visible channels-metadata-visible">\n<button\nclass="spacing-top-small link-gray-darker pull-left channels-hide-metadata"\ntitle=' + g(c.gettext.call(f, 'Feed', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 25,
            column: 6
          },
          end: {
            line: 25,
            column: 24
          }
        }
      })) + '\ndata-action="hide-metadata">\n<span class="icon icon-left-bracket text-large icon__position"></span>\n</button>\n<h1 class="text-largest text-center">' + g(c.gettext.call(f, 'About Channels', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 29,
            column: 37
          },
          end: {
            line: 29,
            column: 65
          }
        }
      })) + '</h1>\n</div>\n'
    },
    useData: !0
  })),
  a.registerPartial('genericFollowButton', a.template({
    1: function (a, b, c, d, e) {
      return ' active'
    },
    3: function (a, b, c, d, e) {
      var f;
      return null != (f = c.unless.call(null != b ? b : a.nullContext || {
      }, null != b ? b.isFollowing : b, {
        name: 'unless',
        hash: {
        },
        fn: a.program(4, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 1,
            column: 85
          },
          end: {
            line: 1,
            column: 127
          }
        }
      })) ? f : ''
    },
    4: function (a, b, c, d, e) {
      return 'disabled'
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f,
      g = null != b ? b : a.nullContext || {
      },
      h = a.escapeExpression;
      return '<button class="button btn-follow' + (null != (f = c['if'].call(g, null != b ? b.isFollowing : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(1, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 1,
            column: 32
          },
          end: {
            line: 1,
            column: 65
          }
        }
      })) ? f : '') + '" ' + (null != (f = c['if'].call(g, null != b ? b.isBlocking : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(3, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 1,
            column: 67
          },
          end: {
            line: 1,
            column: 134
          }
        }
      })) ? f : '') + ' data-action="toggle-follow">\n<span class="symbol-default"><span class="icon-plus"></span></span><span class="text-default">' + h(c.gettext.call(g, 'Follow', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 3,
            column: 94
          },
          end: {
            line: 3,
            column: 114
          }
        }
      })) + '</span><span class="symbol-following"><span class="icon-checkmark"></span></span><span class="text-following">' + h(c.gettext.call(g, 'Following', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 3,
            column: 224
          },
          end: {
            line: 3,
            column: 247
          }
        }
      })) + '</span>\n</button>\n'
    },
    useData: !0
  }))
}),
define('core/extensions/helpers/eq', [
], function () {
  'use strict';
  return function (a, b) {
    return a === b
  }
}),
define('core/extensions/helpers/ne', [
], function () {
  'use strict';
  return function (a, b) {
    return a !== b
  }
}),
define('core/extensions/helpers/gt', [
], function () {
  'use strict';
  return function (a, b) {
    return a > b
  }
}),
define('core/extensions/helpers/lt', [
], function () {
  'use strict';
  return function (a, b) {
    return a < b
  }
}),
define('core/extensions/helpers/ge', [
], function () {
  'use strict';
  return function (a, b) {
    return a >= b
  }
}),
define('core/extensions/helpers/le', [
], function () {
  'use strict';
  return function (a, b) {
    return a <= b
  }
}),
define('core/extensions/helpers/typeof', [
], function () {
  'use strict';
  return function (a, b) {
    return typeof a === b
  }
}),
define('core/extensions/helpers/notNull', [
], function () {
  'use strict';
  return function (a) {
    return null !== a
  }
}),
define('core/extensions/helpers/any', [
], function () {
  'use strict';
  return function () {
    for (var a = arguments.length, b = 0; b < a - 1; b++) if (arguments[b]) return arguments[b]
  }
}),
define('core/extensions/helpers/if_any', [
], function () {
  'use strict';
  return function () {
    for (var a = arguments.length, b = arguments[a - 1], c = 0; c < a - 1; c++) if (arguments[c]) return b.fn(this);
    return b.inverse(this)
  }
}),
define('core/extensions/helpers/if_all', [
], function () {
  'use strict';
  return function () {
    for (var a = arguments.length, b = arguments[a - 1], c = 0; c < a - 1; c++) if (!arguments[c]) return b.inverse(this);
    return b.fn(this)
  }
}),
define('core/extensions/helpers/switch', [
  'core/switches',
  'core/utils/object/extend'
], function (a, b) {
  'use strict';
  return function (c, d) {
    return a.isFeatureActive(c, b({
    }, d.hash))
  }
}),
define('core/extensions/helpers/partial', [
  'handlebars'
], function (a) {
  'use strict';
  return function (b, c) {
    a.registerPartial(b, c.fn)
  }
}),
define('core/extensions/helpers/getPartial', [
  'handlebars'
], function (a) {
  'use strict';
  return function (b, c, d) {
    return 'undefined' == typeof d && (d = c, c = this, a.Utils.extend(c, d.hash)),
    new a.SafeString(a.partials[b](c, d))
  }
}),
define('core/extensions/helpers/gettext', [
  'handlebars',
  'core/strings'
], function (a, b) {
  'use strict';
  return function () {
    var c,
    d,
    e,
    f,
    g = arguments.length,
    h = arguments[g - 1],
    i = h.hash,
    j = arguments[0],
    k = a.partials;
    j = a.Utils.escapeExpression(b.get(j));
    for (e in i) i.hasOwnProperty(e) && (d = new RegExp('%\\((' + e + ')\\)s', 'gm'), c = i[e], f = c && c.executePartial, f && (c = k[c.partial].call(this, c.context, h)), void 0 === c || null === c || 'number' == typeof c && isNaN(c) ? c = '' : f || (c = a.Utils.escapeExpression(c)), j = j.replace(d, c.toString()));
    return new a.SafeString(j)
  }
}),
define('core/utils/object/get', [
], function () {
  'use strict';
  return function (a, b, c) {
    for (var d = 0, e = b.length; a && d < e; ) a = a[b[d]],
    d += 1;
    return d < e || void 0 === a ? c : a
  }
}),
define('core/extensions/helpers/urlfor', [
  'core/config/urls',
  'core/utils/object/get'
], function (a, b) {
  'use strict';
  return function (c) {
    return b(a, c.split('.'))
  }
}),
define('core/extensions/helpers/html', [
  'handlebars'
], function (a) {
  'use strict';
  return function (b) {
    return new a.SafeString(b || '')
  }
}),
define('core/extensions/helpers/with', [
], function () {
  'use strict';
  return function () {
    var a = arguments.length,
    b = arguments[a - 1],
    c = arguments[0];
    return 3 === a ? (c = {
    }, c[arguments[0]] = arguments[1]) : '_window_' === c && (c = window),
    b.fn(c)
  }
}),
define('core/extensions/helpers/each', [
  'handlebars'
], function (a) {
  'use strict';
  return function (b, c) {
    var d,
    e,
    f,
    g = c.fn,
    h = c.inverse,
    i = 0,
    j = '';
    if (c.data && (d = a.createFrame(c.data)), b && 'object' == typeof b) if ('[object Array]' === Object.prototype.toString.call(b)) for (f = b.length; i < f; i++) d && (d.index = i, d.length = b.length),
    j += g(b[i], {
      data: d
    });
     else for (e in b) b.hasOwnProperty(e) && (d && (d.key = e), j += g(b[e], {
      data: d
    }), i += 1);
    return 0 === i && (j = h(this)),
    j
  }
}),
define('core/extensions/helpers/log', [
], function () {
  'use strict';
  return function (a) {
    console.log(a, this)
  }
}),
define('core/extensions/helpers/debug', [
], function () {
  'use strict';
  return function () {
  }
}),
define('core/extensions/helpers/geturl', [
], function () {
  'use strict';
  return window.geturl || function (a) {
    return a
  }
}),
define('core/extensions/helpers/tag', [
  'handlebars'
], function (a) {
  'use strict';
  return function (b, c) {
    var d = [
      '<' + b
    ],
    e = c.hash.text;
    delete c.hash.text;
    for (var f in c.hash) c.hash.hasOwnProperty(f) && d.push(' ' + f + '="' + a.escapeExpression(c.hash[f]) + '"');
    return d.push('>' + a.escapeExpression(e) + '</' + b + '>'),
    new a.SafeString(d.join(''))
  }
}),
define('core/extensions/helpers/now', [
  'moment'
], function (a) {
  'use strict';
  return function (b) {
    return a().format(b)
  }
}),
define('core/extensions/helpers/ternary', [
], function () {
  'use strict';
  return function (a, b, c) {
    return a ? b : c
  }
}),
define('core/extensions/handlebars.helpers', [
  'require',
  'handlebars',
  './helpers/eq',
  './helpers/ne',
  './helpers/gt',
  './helpers/lt',
  './helpers/ge',
  './helpers/le',
  './helpers/typeof',
  './helpers/notNull',
  './helpers/any',
  './helpers/if_any',
  './helpers/if_all',
  './helpers/switch',
  './helpers/partial',
  './helpers/getPartial',
  './helpers/gettext',
  './helpers/urlfor',
  './helpers/html',
  './helpers/with',
  './helpers/each',
  './helpers/log',
  './helpers/debug',
  './helpers/geturl',
  './helpers/tag',
  './helpers/now',
  './helpers/ternary'
], function (a) {
  'use strict';
  var b = a('handlebars');
  return b.registerHelper('eq', a('./helpers/eq')),
  b.registerHelper('ne', a('./helpers/ne')),
  b.registerHelper('gt', a('./helpers/gt')),
  b.registerHelper('lt', a('./helpers/lt')),
  b.registerHelper('ge', a('./helpers/ge')),
  b.registerHelper('le', a('./helpers/le')),
  b.registerHelper('typeof', a('./helpers/typeof')),
  b.registerHelper('notNull', a('./helpers/notNull')),
  b.registerHelper('any', a('./helpers/any')),
  b.registerHelper('if_any', a('./helpers/if_any')),
  b.registerHelper('if_all', a('./helpers/if_all')),
  b.registerHelper('switch', a('./helpers/switch')),
  b.registerHelper('partial', a('./helpers/partial')),
  b.registerHelper('getPartial', a('./helpers/getPartial')),
  b.registerHelper('gettext', a('./helpers/gettext')),
  b.registerHelper('urlfor', a('./helpers/urlfor')),
  b.registerHelper('html', a('./helpers/html')),
  b.registerHelper('with', a('./helpers/with')),
  b.registerHelper('each', a('./helpers/each')),
  b.registerHelper('log', a('./helpers/log')),
  b.registerHelper('debug', a('./helpers/debug')),
  b.registerHelper('geturl', a('./helpers/geturl')),
  b.registerHelper('tag', a('./helpers/tag')),
  b.registerHelper('now', a('./helpers/now')),
  b.registerHelper('ternary', a('./helpers/ternary')),
  b
}),
define('core/templates/alert', [
  'handlebars',
  'core/templates/handlebars.partials',
  'core/extensions/handlebars.helpers'
], function (a) {
  return a.template({
    1: function (a, b, c, d, e) {
      return '<span class="icon icon-' + a.escapeExpression(a.lambda(null != b ? b.iconType : b, b)) + '"></span>\n'
    },
    3: function (a, b, c, d, e) {
      var f;
      return (null != (f = a.lambda(null != b ? b.message : b, b)) ? f : '') + '\n'
    },
    5: function (a, b, c, d, e) {
      return a.escapeExpression(a.lambda(null != b ? b.message : b, b)) + '\n'
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f,
      g = null != b ? b : a.nullContext || {
      };
      return '<a class="close" data-action="dismiss" title="' + a.escapeExpression(c.gettext.call(g, 'Dismiss', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 1,
            column: 46
          },
          end: {
            line: 1,
            column: 67
          }
        }
      })) + '">×</a>\n<span>\n' + (null != (f = c['if'].call(g, null != b ? b.icon : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(1, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 3,
            column: 0
          },
          end: {
            line: 5,
            column: 7
          }
        }
      })) ? f : '') + (null != (f = c['if'].call(g, null != b ? b.safe : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(3, e, 0),
        inverse: a.program(5, e, 0),
        data: e,
        loc: {
          start: {
            line: 6,
            column: 0
          },
          end: {
            line: 10,
            column: 7
          }
        }
      })) ? f : '') + '</span>\n'
    },
    useData: !0
  })
}),
define('core/views/AlertView', [
  'backbone',
  'core/templates/alert'
], function (a, b) {
  'use strict';
  var c = a.View.extend({
    defaultClassName: 'alert',
    events: {
      'click [data-action=dismiss]': 'dismiss'
    },
    initialize: function (a) {
      this.options = a,
      this.message = a.message,
      this.safe = a.safe,
      this.type = a.type,
      this.className = a.className || this.defaultClassName
    },
    render: function () {
      var a = this.$el;
      return a.html(b({
        message: this.message,
        safe: this.safe,
        icon: Boolean(this.type),
        iconType: 'error' === this.type || 'warn' === this.type ? 'warning' : this.type
      })),
      a.attr('class', this.className),
      this.type && a.addClass(this.type),
      this
    },
    dismiss: function (a) {
      a && a.preventDefault && a.preventDefault(),
      this.remove(),
      this.trigger('dismiss')
    }
  });
  return c
}),
define('core/mixins/withAlert', [
  'underscore',
  'core/views/AlertView'
], function (a, b) {
  'use strict';
  var c = {
    alert: function (c, d) {
      a.isObject(d) || (d = {
      });
      var e = d.target || this._alertSelector;
      this.dismissAlert();
      var f = this._alert = new b(a.extend({
        message: c
      }, d));
      if (this.listenToOnce(this._alert, 'dismiss', function () {
        this._alert = null
      }), f.render(), e) {
        var g = this.$el.find(e);
        g.length ? g.prepend(f.el) : this.listenToOnce(this, 'threadView:render', function () {
          return this.alert(c, d)
        })
      } else this.el.parentNode && this.el.parentNode.insertBefore(f.el, this.el);
      return f
    },
    dismissAlert: function (a) {
      this._alert && (a && !a(this._alert) || (this.stopListening(this._alert), this._alert.dismiss(), this._alert = null))
    },
    getAlert: function () {
      return this._alert || null
    },
    setAlertSelector: function (a) {
      this._alertSelector = a
    }
  },
  d = function () {
    return a.extend(this, c)
  };
  return d
}),
define('core/models/ThreadVote', [
  'backbone'
], function (a) {
  'use strict';
  var b = a.Model.extend({
    defaults: {
      score: 0
    }
  });
  return b
}),
define('core/models/Vote', [
  'backbone'
], function (a) {
  'use strict';
  var b = a.Model.extend({
    defaults: {
      score: 0
    }
  });
  return b
}),
define('core/constants/voteConstants', [
  'exports'
], function (a) {
  'use strict';
  a.VOTING_TYPES = {
    DETAILED: 0,
    DOWNVOTE_LIMITED: 1,
    DOWNVOTE_DISABLED: 2,
    DISABLED: 3
  },
  a.DEFAULT_VOTING_TYPE = a.VOTING_TYPES.DETAILED
}),
define('core/time', [
], function () {
  'use strict';
  function a(a) {
    return a.indexOf('+') >= 0 ? a : a + '+00:00'
  }
  var b = 'YYYY-MM-DDTHH:mm:ssZ';
  return {
    ISO_8601: b,
    assureTzOffset: a
  }
}),
define('core/models/BaseUser', [
  'backbone',
  'core/config'
], function (a, b) {
  'use strict';
  var c = a.Model.extend({
    defaults: {
      about: null,
      avatar: {
        cache: b.urls.avatar.generic,
        permalink: b.urls.avatar.generic
      },
      connections: {
      },
      badges: [
      ],
      email: null,
      isAnonymous: !0,
      isFollowedBy: null,
      isFollowing: null,
      joinedAt: null,
      name: null,
      profileUrl: null,
      url: null,
      username: null,
      numPosts: null,
      numFollowing: null,
      numForumsFollowing: null,
      numFollowers: null,
      numLikesReceived: null,
      isFlagged: null
    },
    hasValidAvatar: function (a) {
      var b = a ? a.avatar : this.get('avatar');
      return b && b.cache
    },
    isAnonymous: function () {
      return !this.get('id')
    },
    isRegistered: function () {
      return !this.isAnonymous()
    },
    validate: function (a) {
      if (!this.hasValidAvatar(a)) return 'None of the avatar related properties can be null, undefined or empty on User models.'
    },
    toJSON: function () {
      var b = a.Model.prototype.toJSON.apply(this, arguments);
      return b.thread = {
      },
      this.hasValidAvatar() || (b.avatar = this.defaults.avatar),
      b.isRegistered = this.isRegistered(),
      b
    }
  });
  return c
}),
define('core/models/User', [
  'jquery',
  'underscore',
  'moment',
  'core/config',
  'core/time',
  'core/utils',
  'core/strings',
  'core/switches',
  'core/api',
  'core/models/BaseUser'
], function (a, b, c, d, e, f, g, h, i, j) {
  'use strict';
  function k(a, b, c) {
    a[b] = a[b] || [
    ],
    a[b].push(c)
  }
  var l = g.get,
  m = j.extend({
    url: i.getURL('users/details'),
    validate: function (c) {
      var d = {
      };
      if (c.display_name && (c.display_name = a.trim(c.display_name)), c.display_name || k(d, 'display_name', l('Please enter your name.')), c.email || k(d, 'email', l('Please enter your email address.')), f.validateEmail(c.email) || k(d, 'email', l('Invalid email address.')), this.isNew() && (c.password ? c.password.length < m.MIN_PASSWORD_LEN && k(d, 'password', l('Password must have at least 6 characters.')) : k(d, 'password', l('Please enter a password.'))), c.name && (c.name.length < m.MIN_NAME_LEN && k(d, 'name', g.interpolate(l('Name must have at least %(minLength)s characters.'), {
        minLength: m.MIN_NAME_LEN
      })), c.name.length > m.MAX_NAME_LEN && k(d, 'name', g.interpolate(l('Name must have less than %(maxLength)s characters.'), {
        maxLength: m.MAX_NAME_LEN
      }))), c.location && c.location.length > m.MAX_LOCATION_LEN && k(d, 'location', g.interpolate(l('Location must have less than %(maxLength)s characters.'), {
        maxLength: m.MAX_LOCATION_LEN
      })), c.url && (c.url.length > m.MAX_URL_LEN && k(d, 'url', g.interpolate(l('Site must have less than %(maxLength)s characters.'), {
        maxLength: m.MAX_URL_LEN
      })), f.isUrl(c.url) || k(d, 'url', l('Please enter a valid site.'))), !b.isEmpty(d)) return d
    },
    prepareFetchOptions: function (a) {
      a = a ? b.clone(a) : {
      };
      var c = {
      };
      return this.get('id') ? c.user = this.get('id') : this.get('username') && (c.user = 'username:' + this.get('username')),
      b.extend(c, a.data),
      a.data = c,
      a
    },
    fetch: function (a) {
      return a = this.prepareFetchOptions(a),
      j.prototype.fetch.call(this, a)
    },
    parse: function (a) {
      var b = a.response || a;
      return b = this.handleBadgesUpdate(b)
    },
    register: function (a) {
      var c = this;
      return a = a || {
      },
      i.call('internal/users/register.json', {
        data: b.extend(this.toRegisterJSON(), {
          gRecaptchaResponse: a.gRecaptchaResponse
        }),
        method: 'POST',
        success: function (d) {
          i.call('users/acceptTerms', {
            method: 'POST'
          }),
          c.set(b.extend({
          }, d.response, {
            hasAcceptedGdprTerms: !0
          })),
          a.success && a.success(d)
        },
        error: a.error
      })
    },
    saveAvatar: function (a) {
      var b = new window.FormData;
      return b.append('avatar_file', a),
      b.append('api_key', d.keys.api),
      i.call('internal/users/updateAvatar.json', {
        method: 'post',
        data: b,
        cache: !1,
        contentType: !1,
        processData: !1
      })
    },
    saveProfile: function () {
      return i.call('users/updateProfile.json', {
        method: 'POST',
        data: {
          name: this.get('name'),
          about: this.get('about'),
          location: this.get('location'),
          url: this.get('url')
        }
      })
    },
    toRegisterJSON: function () {
      return b.pick(this.toJSON(), 'display_name', 'email', 'password')
    },
    isSession: function (a) {
      return a.user.id && a.user.id === this.id
    },
    isEditable: function (a) {
      return this.isSession(a) && !this.get('remote')
    },
    toJSON: function (a) {
      a = a || {
      };
      var b = j.prototype.toJSON.call(this),
      c = this.collection && this.collection.thread;
      return b.thread.canModerate = Boolean(c && c.isModerator(this)),
      b.thread.isOP = Boolean(c && c.isOP(this)),
      a.session && (b.isSession = this.isSession(a.session), b.isEditable = this.isEditable(a.session)),
      b
    },
    _changeFollowState: function (a) {
      this.set({
        isFollowing: a,
        numFollowers: Math.max(0, this.get('numFollowers') + (a ? 1 : - 1))
      });
      var b = 'users/' + (a ? 'follow' : 'unfollow'),
      c = this;
      return i.call(b + '.json', {
        data: {
          target: this.get('id')
        },
        method: 'POST',
        success: function (a) {
          c.trigger('sync', c, a, {
          })
        }
      })
    },
    follow: function () {
      return this._changeFollowState(!0)
    },
    unfollow: function () {
      return this._changeFollowState(!1)
    },
    _changeBlockState: function (a) {
      var b = 'users/block/' + (a ? 'create' : 'delete'),
      c = this;
      return i.call(b + '.json', {
        data: {
          user: this.get('id')
        },
        method: 'POST',
        success: function (a) {
          c.set(a.response)
        }
      })
    },
    block: function () {
      return this._changeBlockState(!0)
    },
    unblock: function () {
      return this._changeBlockState(!1)
    },
    report: function (a) {
      var b = this;
      return i.call('users/report.json', {
        data: {
          reason: a,
          user: this.get('id')
        },
        method: 'POST',
        success: function () {
          b.set('isFlagged', !0)
        }
      })
    },
    toggleFollowState: function () {
      return this._changeFollowState(!this.get('isFollowing'))
    },
    registeredLessThan: function (a, b) {
      var d = e.assureTzOffset(this.get('joinedAt')),
      f = c().subtract(a, b);
      return c(d).isAfter(f)
    },
    registeredToday: function () {
      return this.registeredLessThan(1, 'day')
    },
    registeredThisWeek: function () {
      return this.registeredLessThan(1, 'week')
    },
    shouldHomeOnboard: function () {
      return !this.get('homeOnboardingComplete') && !h.isFeatureActive('onboarding_without_channels')
    },
    setHomeOnboardComplete: function (a) {
      this.updateFlags({
        homeOnboardingComplete: a
      }),
      a && this.listenTo(this, 'change:homeOnboardingComplete', b.bind(this.set, this, 'homeOnboardingComplete', a, {
        silent: !0
      }))
    },
    handleBadgesUpdate: function (a) {
      if (this.collection && this.collection.thread && this.collection.thread.forum && this.collection.thread.forum.get('badges')) {
        var b = this.collection.thread.forum.get('badges');
        a.badges = a.badges ? a.badges.filter(function (a) {
          return b[a.id]
        }) : [
        ]
      }
      return a
    },
    updateFlags: function (a) {
      return this.set(a),
      i.call('internal/users/updateFlags.json', {
        data: b.mapObject(a, function (a) {
          return a ? 1 : 0
        }),
        method: 'POST'
      })
    }
  }, {
    MIN_PASSWORD_LEN: 6,
    MIN_NAME_LEN: 2,
    MAX_NAME_LEN: 30,
    MAX_LOCATION_LEN: 255,
    MAX_URL_LEN: 200
  });
  return m
}),
define('core/utils/html', [
], function () {
  'use strict';
  var a = '...',
  b = a.length,
  c = function (a) {
    var b;
    try {
      b = (new window.DOMParser).parseFromString('<!doctype html><meta charset=utf-8><title> </title>', 'text/html')
    } catch (c) {
    }
    return b || (b = window.document.implementation.createHTMLDocument('')),
    b.body && (b.body.innerHTML = a),
    b;
  };
  return {
    stripTags: function (a) {
      var b = c(a).body;
      return (b.textContent || b.innerText).replace(/\r?\n/g, ' ')
    },
    replaceAnchors: function (a, d) {
      var e = c(a);
      return [].forEach.call(e.querySelectorAll('a'), function (a) {
        var c = a.getAttribute('href') || '',
        e = a.innerHTML,
        f = d(a);
        0 === c.indexOf(e.slice(0, - b)) ? e = f : c.length && e.indexOf(c) !== - 1 ? e = e.replace(c, f) : e += ' ' + f,
        a.insertAdjacentHTML('afterend', e),
        a.parentNode.removeChild(a)
      }),
      e.body.innerHTML.trim()
    }
  }
}),
define('core/advice', [
  'underscore'
], function (a) {
  'use strict';
  function b() {
    a.each(['before',
    'after',
    'around'], function (a) {
      this[a] = function (b, d) {
        return 'function' == typeof this[b] ? this[b] = c[a](this[b], d) : this[b] = d,
        this[b]
      }
    }, this)
  }
  var c = {
    around: function (b, c) {
      return function () {
        var d = a.toArray(arguments);
        return c.apply(this, [
          a.bind(b, this)
        ].concat(d))
      }
    },
    before: function (b, d) {
      return c.around(b, function () {
        var b = a.toArray(arguments),
        c = b.shift();
        return d.apply(this, b),
        c.apply(this, b)
      })
    },
    after: function (b, d) {
      return c.around(b, function () {
        var b = a.toArray(arguments),
        c = b.shift(),
        e = c.apply(this, b);
        return d.apply(this, b),
        e
      })
    }
  };
  return {
    withAdvice: b
  }
}),
define('core/models/mixins', [
  'underscore',
  'moment',
  'core/time'
], function (a, b, c) {
  'use strict';
  function d() {
    b.locale('en', {
      relativeTime: {
        future: '%s from now',
        past: '%s ago',
        s: 'a few seconds',
        ss: '%d seconds',
        m: 'a minute',
        mm: '%d minutes',
        h: 'an hour',
        hh: '%d hours',
        d: 'a day',
        dd: '%d days',
        M: 'a month',
        MM: '%d months',
        y: 'a year',
        yy: '%d years'
      }
    }),
    this._getCreatedMoment = a.memoize(function (a) {
      var d = this.get(a || 'createdAt');
      if (d) return b(c.assureTzOffset(d), c.ISO_8601)
    }, function (a) {
      return this.get(a || 'createdAt')
    }),
    this.getRelativeCreatedAt = function (a) {
      var b = this._getCreatedMoment(a);
      return b && b.from(Number(new Date))
    },
    this.getFormattedCreatedAt = a.memoize(function (a) {
      var b = this._getCreatedMoment(a);
      return b && b.format('LLLL')
    }, function (a) {
      return this.get(a || 'createdAt')
    })
  }
  return {
    withCreatedAt: d
  }
}),
define('core/collections/UserCollection', [
  'jquery',
  'backbone',
  'core/models/User'
], function (a, b, c) {
  'use strict';
  var d = b.Collection.extend({
    model: c,
    initialize: function (a, c) {
      b.Collection.prototype.initialize.apply(this, arguments),
      this.thread = c && c.thread
    },
    fetch: function () {
      return a.when(!0)
    }
  });
  return d
}),
define('core/collections/VotersUserCollection', [
  'underscore',
  'backbone',
  'core/api',
  'core/collections/UserCollection'
], function (a, b, c, d) {
  'use strict';
  var e = d.extend({
    LIMIT: 50,
    url: function () {
      return c.getURL('posts/listUsersVotedPost')
    },
    initialize: function (a, b) {
      this.postId = b.postId,
      this.threadId = b.threadId
    },
    fetch: function (c) {
      return b.Collection.prototype.fetch.call(this, a.extend({
        data: {
          post: this.postId,
          thread: this.threadId,
          vote: c.vote,
          limit: this.LIMIT
        }
      }, c))
    }
  });
  return e
}),
define('core/collections/VoteCollection', [
  'backbone',
  'core/models/Vote'
], function (a, b) {
  'use strict';
  var c = a.Collection.extend({
    model: b
  });
  return c
}),
define('core/models/Post', [
  'jquery',
  'underscore',
  'backbone',
  'moment',
  'core/config/urls',
  'core/api',
  'core/strings',
  'core/time',
  'core/utils',
  'core/utils/html',
  'core/advice',
  'remote/config',
  'core/models/mixins',
  'core/collections/VotersUserCollection',
  'core/collections/VoteCollection'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o) {
  'use strict';
  var p = 1000,
  q = 0,
  r = 25000,
  s = function () {
    var b = a.now();
    return !(b - q < p) && (q = b, !0)
  },
  t = g.get,
  u = c.Model.extend({
    votersCollectionClass: n,
    defaults: function () {
      return {
        createdAt: d().format(h.ISO_8601),
        editableUntil: d().add(l.max_post_edit_days, 'days').format(h.ISO_8601),
        dislikes: 0,
        isApproved: !0,
        isDeleted: !1,
        isEdited: !1,
        isFlagged: !1,
        isFlaggedByUser: !1,
        isHighlighted: !1,
        isRealtime: !1,
        isImmediateReply: !1,
        isMinimized: null,
        hasMedia: !1,
        message: null,
        raw_message: null,
        likes: 0,
        media: [
        ],
        parent: null,
        points: 0,
        depth: 0,
        userScore: 0,
        rating: null
      }
    },
    initialize: function () {
      this.votes = new o
    },
    messageText: function () {
      var a = this.get('message');
      return a && j.stripTags(a)
    },
    permalink: function (a, b) {
      var c = this.id;
      if (!c || !a) return '';
      var d = b !== !1 && a.currentUrl || a.permalink(),
      e = window.document.createElement('a');
      return e.href = d,
      e.hash = '#comment-' + c,
      e.href
    },
    shortLink: function () {
      return e.shortener + '/p/' + Number(this.id).toString(36)
    },
    twitterText: function (a) {
      var b = 140,
      c = this.author.get('name') || this.author.get('username');
      b -= c.length + 3,
      b -= a.length + 1,
      b -= 2;
      var d = i.niceTruncate(this.messageText(), b);
      return '"' + d + '" — ' + c
    },
    toJSON: function (a) {
      var b = c.Model.prototype.toJSON.call(this);
      if (a) {
        var d = a.session,
        e = a.thread;
        b.canBeEdited = this.canBeEdited(d, e),
        b.canBeRepliedTo = this.canBeRepliedTo(d, e),
        b.canBeShared = this.canBeShared(),
        b.permalink = this.permalink(e)
      }
      return b.shortLink = this.shortLink(),
      b.isMinimized = this.isMinimized(),
      b.plaintext = this.messageText(),
      b.relativeCreatedAt = this.getRelativeCreatedAt(),
      b.formattedCreatedAt = this.getFormattedCreatedAt(),
      b.cid = this.cid,
      b
    },
    isPublic: function () {
      return !(!this.get('isHighlighted') && !this.get('isSponsored')) || !this.get('isDeleted') && this.get('isApproved')
    },
    isMinimized: function () {
      return !this.get('isHighlighted') && (this.get('isMinimized') !== !1 && !this.get('isApproved'))
    },
    isAuthorSessionUser: function () {
      return !1
    },
    canBeEdited: function () {
      return !1
    },
    canBeRepliedTo: function () {
      return !1
    },
    canBeShared: function () {
      return !1
    },
    validateMessage: function (a) {
      if (b.isString(a.raw_message)) {
        if ('' === a.raw_message) return t('Comments can\'t be blank.');
        if (a.raw_message.length < 2) return t('Comments must have at least 2 characters.');
        if (a.raw_message.length > r) return g.interpolate(t('Comments can\'t be longer than %(maxLength)s characters (currently %(currentLength)s characters).'), {
          maxLength: r,
          currentLength: a.raw_message.length
        })
      }
    },
    validate: function (c) {
      if (!this.id && !c.id) {
        var d = this.validateMessage(c);
        return d ? d : (c.author_email && (c.author_email = a.trim(c.author_email)), c.author_name && (c.author_name = a.trim(c.author_name)), '' === c.author_email && '' === c.author_name ? t('Please sign in or enter a name and email address.') : '' === c.author_email || '' === c.author_name ? t('Please enter both a name and email address.') : b.isString(c.author_email) && !this.validateEmail(c.author_email) ? t('Invalid email address format.') : void 0)
      }
    },
    validateEmail: function (a) {
      return i.validateEmail(a)
    },
    report: function (a) {
      this.set('isFlagged', !0);
      var b = {
        post: this.id
      };
      a && (b.reason = a),
      f.call('posts/report.json', {
        data: b,
        method: 'POST'
      })
    },
    _highlight: function (a) {
      this.set('isHighlighted', a),
      f.call('posts/' + (a ? 'highlight' : 'unhighlight') + '.json', {
        data: {
          post: this.id
        },
        method: 'POST'
      })
    },
    highlight: function () {
      this._highlight(!0)
    },
    unhighlight: function () {
      this._highlight(!1)
    },
    getThreadId: function () {
      return this.get('thread')
    },
    getUpvotersUserCollection: b.memoize(function () {
      var a = this.votersCollectionClass;
      return new a((void 0), {
        postId: this.id,
        threadId: this.getThreadId()
      })
    }, function () {
      return [this.id,
      '1'].join('')
    }),
    getDownvotersUserCollection: b.memoize(function () {
      var a = this.votersCollectionClass;
      return new a((void 0), {
        postId: this.id,
        threadId: this.getThreadId()
      })
    }, function () {
      return [this.id,
      '-1'].join('')
    }),
    _vote: function (a, b, c) {
      var d = a - b,
      e = {
        likes: this.get('likes'),
        dislikes: this.get('dislikes'),
        points: this.get('points')
      };
      return 0 === d ? d : (a > 0 ? (e.likes += a, e.dislikes += b) : a < 0 ? (e.dislikes -= a, e.likes -= b) : b > 0 ? e.likes -= b : e.dislikes += b, e.points += d, c && (1 === a ? (this.getUpvotersUserCollection().add(c), this.getDownvotersUserCollection().remove(c)) : (this.getDownvotersUserCollection().add(c), this.getUpvotersUserCollection().remove(c))), this.set(e), d)
    },
    vote: function (a) {
      if (!s()) return 0;
      var b = this,
      c = b._vote(a, b.get('userScore'));
      if (0 !== c) {
        var d = b.author ? b.author.get('numLikesReceived') : 0;
        1 === b.get('userScore') ? d -= 1 : 1 === a && (d += 1),
        b.set('userScore', a),
        f.call('posts/vote.json', {
          data: {
            post: b.id,
            vote: a
          },
          method: 'POST',
          success: function (c) {
            b.votes.add({
              id: c.response.id,
              score: a
            }, {
              merge: !0
            }),
            b.author && b.author.set('numLikesReceived', d)
          }
        })
      }
    },
    _delete: function () {
      return this.set({
        isApproved: !1,
        isDeleted: !0
      }),
      f.call('posts/remove.json', {
        data: {
          post: this.id
        },
        method: 'POST'
      })
    },
    spam: function () {
      this.set({
        isApproved: !1,
        isDeleted: !0,
        isSpam: !0
      }),
      this.trigger('spam'),
      f.call('posts/spam.json', {
        data: {
          post: this.id
        },
        method: 'POST'
      })
    },
    _create: function (a, b) {
      var c = this,
      d = a.attributes,
      e = {
        thread: d.thread,
        message: d.raw_message,
        rating: d.rating
      };
      return d.parent && (e.parent = d.parent),
      d.author_name && (e.author_name = d.author_name, e.author_email = d.author_email),
      f.call('posts/create.json', {
        data: e,
        method: 'POST',
        success: function (a) {
          c.set(a.response),
          b.success && b.success()
        },
        error: b.error
      })
    },
    _update: function (a, b) {
      var c = this,
      d = a.attributes,
      e = {
        post: d.id,
        message: d.raw_message,
        rating: d.rating
      };
      return f.call('posts/update.json', {
        data: e,
        method: 'POST',
        success: function (a) {
          c.set(a.response),
          b.success && b.success()
        },
        error: b.error
      })
    },
    _read: function (a, b) {
      var c = this;
      return b = b || {
      },
      f.call('posts/details.json', {
        data: {
          post: c.id
        },
        method: 'GET',
        success: function (a) {
          b.isHighlighted && !a.response.isHighlighted && (a.response.isHighlighted = !0),
          c.set(a.response),
          b.success && b.success()
        },
        error: b.error
      })
    },
    sync: function (a, b, c) {
      c = c || {
      };
      var d = c.error;
      switch (d && (c.error = function (a) {
          var b = {
          };
          try {
            b = JSON.parse(a.responseText)
          } catch (c) {
          }
          d(b)
        }), a) {
        case 'create':
          return this._create(b, c);
        case 'update':
          return this._update(b, c);
        case 'delete':
          return this._delete();
        case 'read':
          return this._read(b, c);
        default:
          return null
      }
    },
    storageKey: function () {
      if (this.isNew() && this.getThreadId()) return ['drafts',
      'thread',
      this.getThreadId(),
      'parent',
      this.get('parent') || 0].join(':')
    }
  }, {
    formatMessage: function () {
      var a = /(?:\r\n|\r|\n){2,}/,
      c = /\r\n|\r|\n/;
      return function (d) {
        var e = b.chain(d.split(a)).compact().value(),
        f = b.map(e, function (a) {
          return b.chain(a.split(c)).compact().map(b.escape).join('<br>').value()
        }).join('</p><p>');
        return '<p>' + f + '</p>'
      }
    }()
  });
  return m.withCreatedAt.call(u.prototype),
  k.withAdvice.call(u.prototype),
  u.withAuthor = function (a) {
    this.around('set', function (c, d, e, f) {
      var g;
      if (null == d) return this;
      'object' == typeof d ? (g = d, f = e) : (g = {
      }, g[d] = e);
      var h = g.author;
      if (h) {
        if (b.isString(h) || b.isNumber(h)) {
          var i = h;
          h = {
          },
          h[a.prototype.idAttribute || 'id'] = i
        }
        var j = this.collection || this.author && this.author.collection,
        k = j && j.thread && j.thread.forum;
        if (this.author && this.author.get('badges').length && this.author.get('badges') [0].id) h.badges = this.author.get('badges');
         else if (k && k.get('badges') && h.badges) {
          var l = [
          ],
          m = h.badges || [
          ],
          n = k.get('badges');
          m.forEach(function (a) {
            n[a] && l.push(n[a])
          }),
          h.badges = l
        }
        this.author = new a(h),
        this.trigger('changeRelated:author'),
        delete g.author
      }
      return c.call(this, g, f)
    }),
    this.around('toJSON', function (a) {
      var c = a.apply(this, b.rest(arguments));
      return this.author && (c.author = this.author.toJSON()),
      c
    })
  },
  u.withMediaCollection = function (a) {
    this.after('set', function (c) {
      c && 'string' != typeof c && (b.isUndefined(c.media) || (this.media ? this.media.reset(c.media) : this.media = new a(c.media), delete c.media))
    }),
    this.around('toJSON', function (a) {
      var c = a.apply(this, b.rest(arguments));
      return this.media && (c.media = this.media.toJSON()),
      c
    })
  },
  u
}),
define('core/utils/threadRatingsHelpers', [
  'core/utils/object/get'
], function (a) {
  'use strict';
  var b = {
  };
  return b.isThreadRatingsEnabled = function (b, c) {
    return !!(b && b.forum && c && c.id === b.forum) && Boolean(a(b, [
      'ratingsEnabled'
    ]) && a(c, [
      'settings',
      'threadRatingsEnabled'
    ]) && a(c, [
      'features',
      'threadRatings'
    ]))
  },
  b.isThreadModelRatingsEnabled = function (a) {
    if (!a || !a.forum) return !1;
    var b = a.forum.get('settings'),
    c = a.forum.get('features');
    return Boolean(a.get('ratingsEnabled') && b && b.threadRatingsEnabled && c && c.threadRatings)
  },
  b.isForumRatingsEnabled = function (b) {
    return !!b && Boolean(a(b, [
      'settings',
      'threadRatingsEnabled'
    ]) && a(b, [
      'features',
      'threadRatings'
    ]))
  },
  b.isForumModelRatingsEnabled = function (a) {
    if (!a) return !1;
    var b = a.get('settings'),
    c = a.get('features');
    return Boolean(b && b.threadRatingsEnabled && c && c.threadRatings)
  },
  b
}),
define('core/models/Thread', [
  'underscore',
  'backbone',
  'loglevel',
  'core/config/urls',
  'core/utils',
  'core/api',
  'core/config',
  'core/advice',
  'core/UniqueModel',
  'core/utils/threadRatingsHelpers',
  'core/models/User'
], function (a, b, c, d, e, f, g, h, i, j, k) {
  'use strict';
  var l = b.Model,
  m = l.prototype,
  n = l.extend({
    defaults: {
      author: null,
      category: null,
      createdAt: null,
      forum: null,
      identifiers: [
      ],
      ipAddress: null,
      isClosed: !1,
      isDeleted: !1,
      hasStreaming: !1,
      link: null,
      message: null,
      slug: null,
      title: null,
      userSubscription: !1,
      posts: 0,
      likes: 0,
      dislikes: 0,
      userScore: 0
    },
    initialize: function (a, b) {
      b = b || {
      },
      this.moderators = b.moderators,
      this.forum = b.forum,
      this.on('change:userScore', function () {
        var a = this.get('userScore');
        a > 0 && 0 === this.get('likes') && this.set('likes', a)
      }, this)
    },
    _vote: function (a, b) {
      var c = a - b;
      return 0 === c ? c : (this.set('likes', this.get('likes') + c), c)
    },
    vote: function (a) {
      var b = this,
      c = b._vote(a, b.get('userScore'));
      0 !== c && (this.set('userScore', a), f.call('threads/vote.json', {
        data: {
          thread: this.id,
          vote: a
        },
        method: 'POST',
        success: function (a) {
          a.response.id && b.trigger('vote:success', a)
        }
      }))
    },
    fetch: function (a) {
      var b,
      d = this,
      e = d.attributes;
      a = a || {
      },
      b = e.identifier ? 'ident:' + e.identifier : 'link:' + e.url,
      f.call('threads/details.json', {
        data: {
          thread: b,
          forum: e.forum
        },
        success: function (b) {
          d.set(b.response),
          a.success && a.success()
        },
        error: function () {
          g.debug ? d.save({
          }, {
            success: a.success
          }) : c.info('Couldn\'t find thread; not creating in production.')
        }
      })
    },
    _toggleState: function (a, b) {
      b || (b = {
      });
      var c = a ? 'open.json' : 'close.json';
      return this.set('isClosed', !a),
      f.call('threads/' + c, {
        method: 'POST',
        data: {
          thread: this.id
        },
        success: b.success,
        error: b.error
      })
    },
    open: function (a) {
      return this._toggleState(!0, a)
    },
    close: function (a) {
      return this._toggleState(!1, a)
    },
    premoderate: function (b, c) {
      return this.set('validateAllPosts', b),
      f.call('threads/update', a.extend({
      }, c, {
        method: 'POST',
        data: a.extend({
          thread: this.id,
          validateAllPosts: b ? 1 : 0
        }, c && c.data)
      }))
    },
    sync: function () {
      var a = this,
      b = a.attributes;
      f.call('threads/create.json', {
        data: {
          title: b.title,
          forum: b.forum,
          identifier: b.identifier,
          url: b.url
        },
        method: 'POST',
        success: function (b) {
          a.set(b.response)
        }
      })
    },
    fetchRatings: function () {
      var a = this,
      b = {
        thread: a.id
      };
      return f.call('threads/ratingsSummary.json', {
        data: b,
        method: 'GET',
        success: function (b) {
          a.set('ratings', b.response)
        }
      })
    },
    toggleRatingsEnabled: function () {
      var a = this;
      if (j.isForumModelRatingsEnabled(a.forum)) {
        var b = a.get('ratingsEnabled'),
        c = {
          thread: a.id,
          ratingsEnabled: b ? 0 : 1
        };
        return a.set('ratingsEnabled', !b),
        f.call('threads/update.json', {
          data: c,
          method: 'POST'
        })
      }
    },
    incrementPostCount: function (a) {
      var b = this.get('posts') + a;
      this.set('posts', b > 0 ? b : 0)
    },
    isModerator: function (b) {
      var c;
      if (this.moderators) return c = b instanceof k || a.isObject(b) ? b.id : b,
      c = parseInt(c, 10),
      a(this.moderators).contains(c)
    },
    isOP: function (b) {
      var c = b instanceof k || a.isObject(b) ? b.id : b;
      return this.get('author') === c
    },
    subscribe: function (a) {
      a = a !== !1;
      var b = this.get('userSubscription');
      if (b !== a) {
        this.set('userSubscription', a);
        var c = a ? 'subscribe.json' : 'unsubscribe.json',
        d = {
          thread: this.id
        };
        return f.call('threads/' + c, {
          data: d,
          method: 'POST'
        })
      }
    },
    twitterText: function (a) {
      var b = 140 - (a.length + 1),
      c = this.get('clean_title');
      return c = e.niceTruncate(c, b)
    },
    permalink: function () {
      return this.get('url') || this.get('link') || this.currentUrl
    },
    shortLink: function () {
      return d.shortener + '/t/' + Number(this.id).toString(36)
    },
    toJSON: function () {
      var a = m.toJSON.call(this);
      return a.permalink = this.permalink(),
      a.shortLink = this.shortLink(),
      a
    },
    getDiscussionRoute: function (a) {
      var b = [
        '',
        'home',
        'discussion',
        this.forum.id,
        this.get('slug'),
        ''
      ];
      return a = a || this.forum.channel,
      a && (a = a.attributes || a, b.splice(2, 0, 'channel', a.slug), b.splice(1, 1)),
      b.join('/')
    }
  });
  return h.withAdvice.call(n.prototype),
  n.withThreadVoteCollection = function (a) {
    this.after('initialize', function () {
      this.votes = new a,
      this.on('vote:success', function (a) {
        this.votes.get(a.response.id) || this.votes.add({
          id: a.response.id,
          score: a.response.vote,
          currentUser: !0
        })
      }, this)
    })
  },
  n.withPostCollection = function (b) {
    this.after('initialize', function (c) {
      c = c || {
      },
      this.posts = new b(c.posts, {
        thread: this,
        cursor: c.postCursor,
        order: c.order,
        perPage: this.postsPerPage
      }),
      this.listenTo(this.posts, 'add reset', function (b) {
        b = b.models ? b.models : [
          b
        ],
        this.users && a.each(b, function (a) {
          this.users.get(a.author.id) || this.users.add(a.author)
        }),
        this.recalculatePostCount()
      }),
      this.listenTo(this.posts, 'change:isDeleted change:isFlagged', function (a, b) {
        b && this.incrementPostCount( - 1)
      })
    }),
    this.recalculatePostCount = function () {
      var a = this.get('posts');
      a > 50 || (a = this.posts.reduce(function (a, b) {
        return b.isPublic() ? a + 1 : a
      }, 0), this.set('posts', a))
    }
  },
  i.addType('Thread', n),
  n
}),
define('core/models/Forum', [
  'backbone',
  'core/UniqueModel',
  'core/api'
], function (a, b, c) {
  'use strict';
  var d = a.Model.extend({
    defaults: {
      settings: {
      },
      badges: [
      ],
      followUrl: 'forums/follow',
      unfollowUrl: 'forums/unfollow',
      isFollowing: !1
    },
    initialize: function (a, b) {
      b && b.channel && (this.channel = b.channel),
      this.getFeatures(),
      this.on('change:id', this.getFeatures),
      this.on('change:id', this.getBadges)
    },
    _changeFollowingState: function (a) {
      return c.call(a, {
        method: 'POST',
        data: {
          target: this.get('id')
        }
      })
    },
    follow: function () {
      return this.set('isFollowing', !0),
      this._changeFollowingState(this.get('followUrl'))
    },
    unfollow: function () {
      return this.set('isFollowing', !1),
      this._changeFollowingState(this.get('unfollowUrl'))
    },
    toggleFollowed: function () {
      if (this.channel && this.channel.get('options').isCurationOnlyChannel) return this.channel.toggleFollowed();
      var a = this.get('isFollowing') ? this.unfollow() : this.follow();
      return this.trigger('toggled:isFollowing'),
      a
    },
    getFeatures: function () {
      var a = this;
      a.id && c.call('forums/details', {
        data: {
          forum: this.id,
          attach: 'forumFeatures'
        },
        success: function (b) {
          b && b.response && a.set('features', b.response.features)
        }
      })
    },
    getBadges: function () {
      if (this.id && this.get('badges')) {
        var a = {
        },
        b = {
        };
        b.id = this.get('pk'),
        b.url = this.get('id'),
        this.get('badges').forEach(function (c) {
          c.forum = b,
          a[c.id] = c
        }),
        this.set('badges', a)
      }
    }
  });
  return b.addType('Forum', d),
  d
}),
define('core/models/Media', [
  'underscore',
  'backbone',
  'core/api',
  'core/UniqueModel'
], function (a, b, c, d) {
  'use strict';
  var e = b.Model.extend({
    idAttribute: 'url',
    defaults: {
      mediaType: null,
      html: '',
      htmlWidth: null,
      htmlHeight: null,
      thumbnailUrl: '',
      thumbnailWidth: null,
      thumbnailHeight: null,
      url: '',
      urlRedirect: '',
      resolvedUrl: '',
      resolvedUrlRedirect: '',
      title: '',
      description: '',
      providerName: ''
    },
    parse: function (a) {
      return a.response
    },
    sync: function (b, d, e) {
      if ('read' !== b) throw new Error('Media models do not support methods other than "read".');
      return c.call('media/details.json', a.extend({
        method: 'POST',
        data: {
          url: this.get('url'),
          forum: e.forum
        }
      }, e))
    }
  }, {
    MEDIA_TYPES: {
      IMAGE: '1',
      IMAGE_UPLOAD: '2',
      YOUTUBE_VIDEO: '3',
      WEBPAGE: '4',
      TWITTER_STATUS: '5',
      FACEBOOK_PAGE: '6',
      FACEBOOK_POST: '7',
      FACEBOOK_PHOTO: '8',
      FACEBOOK_VIDEO: '9',
      SOUNDCLOUD_SOUND: '10',
      GOOGLE_MAP: '11',
      VIMEO_VIDEO: '12',
      VINE_VIDEO: '14',
      GIF_VIDEO: '15',
      MP4_VIDEO: '16'
    },
    WEBPAGE_TYPES: [
      '4',
      '6',
      '7'
    ]
  });
  return d.addType('Media', e),
  e
}),
define('core/collections/MediaCollection', [
  'backbone',
  'core/models/Media'
], function (a, b) {
  'use strict';
  var c = a.Collection.extend({
    model: b
  });
  return c
}),
define('core/utils/sso', [
], function () {
  'use strict';
  var a = function (a) {
    var b = a;
    return b && (b = String(b), 0 === b.indexOf('//') && (b = 'https:' + b), /https?:\/\//.test(b) || (b = null), /\{username\}/.test(b) || (b = null)),
    b
  },
  b = function (a, b) {
    return a.replace(/\{username\}/gi, encodeURIComponent(b))
  };
  return {
    getProfileUrlTemplate: a,
    getProfileUrl: b
  }
}),
define('common/collections/VotersUserCollection', [
  'core/collections/VotersUserCollection'
], function (a) {
  'use strict';
  var b = a.extend({
    initialize: function (b, c) {
      a.prototype.initialize.call(this, b, c);
      var d = require('common/Session');
      this.session = d.get()
    },
    parse: function (a) {
      return this.session.get('canModerate') && a.response && a.response.forEach(function (a) {
        a.isBlocking = !1
      }),
      a.response
    }
  });
  return b
}),
define('common/models', [
  'require',
  'jquery',
  'underscore',
  'backbone',
  'modernizr',
  'core/api',
  'core/UniqueModel',
  'core/models/User',
  'core/models/Post',
  'core/models/Thread',
  'core/models/Forum',
  'core/collections/MediaCollection',
  'core/utils/object/get',
  'core/utils/sso',
  'core/utils/url/serialize',
  'core/utils/guid',
  'common/utils',
  'core/utils',
  'common/urls',
  'core/shared/urls',
  'common/collections/VotersUserCollection',
  'backbone.uniquemodel'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u) {
  'use strict';
  var v = k.extend({
    defaults: {
      settings: {
      }
    },
    toJSON: function () {
      return c.extend(d.Model.prototype.toJSON.apply(this, arguments), {
        homeUrl: t.apps.home + 'home/forums/' + this.id + '/'
      })
    }
  }),
  w = j.extend({
    initialize: function (b, d) {
      j.prototype.initialize.apply(this, arguments),
      d = d || {
      };
      var e = this,
      f = a('common/collections');
      e.users = new f.UserCollection(d.users, {
        thread: e
      }),
      e.forum && (e.moderatorList = new f.ModeratorCollection(null, {
        forum: e.forum.get('id')
      })),
      e.posts = new f.SubpaginatedPostCollection(d.posts, {
        thread: e,
        cursor: d.postCursor,
        order: d.order,
        perPage: r.isMobileUserAgent() ? 20 : 50
      }),
      e.votes = new f.ThreadVoteCollection,
      e.posts.on('add reset', function (a) {
        a = a.models ? a.models : [
          a
        ],
        c.each(a, function (a) {
          e.users.get(a.author.id) || e.users.add(a.author)
        }),
        e.recalculatePostCount()
      }),
      e.listenTo(e.posts, 'change:isDeleted change:isFlagged', function (a, b) {
        b && e.incrementPostCount( - 1)
      }),
      e.queue = new f.QueuedPostCollection(null, {
        thread: e
      })
    },
    recalculatePostCount: function () {
      var a = this.get('posts');
      a > 50 || (a = this.posts.buffer.reduce(function (a, b) {
        var c = b.isPublic() && (!b.get('sb') || b.isAuthorSessionUser());
        return c ? a + 1 : a
      }, 0), this.set('posts', a))
    },
    toJSON: function () {
      var a = this.get('forum'),
      b = c.isObject(a) ? a.id : a;
      return c.extend(j.prototype.toJSON.apply(this, arguments), {
        homeUrl: t.apps.home + 'home/discussions/' + b + '/' + this.get('slug') + '/'
      })
    }
  });
  j.withThreadVoteCollection.call(w.prototype, d.Collection);
  var x = i.extend({
    votersCollectionClass: u,
    initialize: function () {
      i.prototype.initialize.apply(this, arguments);
      var b = a('common/collections');
      this.usersTyping = new b.TypingUserCollection
    },
    isAuthorSessionUser: function (b) {
      var c = a('common/Session'),
      d = m(b, [
        'user',
        'id'
      ]) || c.fromCookie().id;
      return !!(d && this.author && this.author.id) && this.author.id.toString() === d.toString()
    },
    canBeEdited: function (a, b) {
      var c = this.get('editableUntil'),
      d = (new Date).toISOString();
      return !b.get('isClosed') && !this.get('isDeleted') && a.isLoggedIn() && this.isAuthorSessionUser(a) && this.get('raw_message') && !this.get('isHighlighted') && !this.get('isSponsored') && d < c
    },
    canBeRepliedTo: function (a, b) {
      return !b.get('isClosed') && a.get('canReply') && !this.get('isDeleted') && (this.get('isApproved') || b.isModerator(a.user))
    },
    canBeShared: function () {
      return !this.get('isDeleted') && !this.get('isSponsored')
    },
    getParent: function () {
      var a = this.get('parent');
      if (a) return new g(x, {
        id: String(a)
      })
    }
  }, {
    fetchContext: function (a, d, e) {
      e = e || {
      };
      var h = b.Deferred();
      return f.call('posts/getContext.json', {
        method: 'GET',
        data: {
          post: a,
          order: d.posts.buffer.order
        },
        success: function (a) {
          var b = c.filter(a.response, function (a) {
            return a.thread === d.get('id')
          });
          return b ? (c.each(b, function (a) {
            d.posts.get(a.id) && delete a.hasMore,
            a = new g(x, a),
            e.requestedByPermalink && (a.requestedByPermalink = !0),
            d.posts.add(a)
          }), void h.resolve(b)) : void h.reject()
        }
      }),
      h.promise()
    }
  });
  i.withAuthor.call(x.prototype, g.wrap(h)),
  i.withMediaCollection.call(x.prototype, l),
  g.addType('Post', x);
  var y = d.Model.extend({
    defaults: {
      user: null,
      message: null,
      parentId: null,
      immedReply: !1,
      createdAt: void 0
    },
    getVisibleParent: function (a) {
      for (var b, c = this; c.get('parentId'); ) {
        if (b = a.posts.get(c.get('parentId'))) return b;
        if (c = a.queue.get(c.get('parentId')), !c) return null
      }
      return null
    },
    toPost: function (a) {
      var b = this,
      c = a.posts.get(b.get('parentId')),
      d = c ? c.get('depth') + 1 : 0,
      e = new g(x, {
        id: b.id,
        forum: a.get('forum'),
        thread: a.id,
        message: b.get('message'),
        parent: b.get('parentId'),
        depth: d,
        createdAt: b.get('createdAt'),
        isRealtime: !0,
        media: b.get('media'),
        isImmediateReply: b.get('immedReply')
      });
      return e.author = b.get('user'),
      e
    }
  }),
  z = d.Model.extend({
    defaults: {
      user: null,
      post: null,
      thread: null,
      client_context: null,
      typing: !0
    },
    idAttribute: 'client_context',
    set: function () {
      return this.lastModified = new Date,
      d.Model.prototype.set.apply(this, arguments)
    },
    sync: function () {
      var a = this.toJSON(),
      b = o(s.realertime + '/api/typing', a);
      try {
        q.CORS.request('GET', b).send()
      } catch (c) {
      }
    }
  }, {
    make: function (a) {
      return a.client_context || (a.client_context = p.generate()),
      new g(z, a)
    }
  });
  g.addType('TypingUser', z);
  var A = h.prototype.toJSON;
  c.extend(h.prototype, {
    getFollowing: function () {
      var b = a('common/collections/profile');
      return this.following || (this.following = new b.FollowingCollection(null, {
        user: this
      }))
    },
    hasDisqusProfileUrl: function () {
      var a = A.apply(this, arguments);
      if (!a.profileUrl) return !1;
      var b = a.profileUrl.match(/^https?:\/\/([^/?#]+)(?:[/?#]|$)/i);
      return b && b.length >= 2 && ('disqus.com' === b[1] || 'dev.disqus.org:8000' === b[1])
    },
    toJSON: function () {
      var b = A.apply(this, arguments),
      c = a('common/Session'),
      d = c.get(),
      e = n.getProfileUrlTemplate(d && d.get('sso') && d.get('sso').profile_url),
      f = this.hasDisqusProfileUrl();
      return b.isSSOProfileUrl = !f || Boolean(e),
      f && e && (b.profileUrl = n.getProfileUrl(e, b.name)),
      b
    }
  }),
  g.addType('User', h);
  var B = h.extend({
    defaults: c.extend({
      numPosts: 0
    }, h.prototype.defaults)
  }),
  C = e.sessionstorage ? 'sessionStorage' : null,
  D = d.UniqueModel(h, 'User', C),
  E = d.UniqueModel(B, 'User', C),
  F = d.Model.extend({
  }),
  G = d.Model.extend({
    defaults: {
      id: '',
      title: '',
      rating: 'g',
      'default': {
        url: '',
        height: '',
        width: ''
      },
      fixedWidth200: {
        url: '',
        height: '',
        width: ''
      },
      fixedWidth100: {
        url: '',
        height: '',
        width: ''
      }
    }
  });
  return {
    Forum: v,
    Thread: w,
    Post: x,
    QueuedPost: y,
    TypingUser: z,
    User: h,
    TopUser: B,
    Switch: F,
    SyncedUser: D,
    SyncedTopUser: E,
    GifObject: G
  }
}),
define('core/models/Channel', [
  'underscore',
  'backbone',
  'core/UniqueModel',
  'core/api',
  'core/models/Forum',
  'core/strings'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = f.get,
  h = b.Model.extend({
    defaults: {
      primaryForum: {
      },
      slug: null,
      name: null,
      options: {
      },
      followUrl: 'channels/follow',
      unfollowUrl: 'channels/unfollow'
    },
    idAttribute: 'slug',
    initialize: function (a, b) {
      this.buildPrimaryForum(b),
      this.listenTo(this, 'change:primaryForum', this.updatePrimaryForum),
      this.listenTo(this, 'change:primaryCategory', this.updatePrimaryCategory)
    },
    buildPrimaryForum: function () {
      if (!this.primaryForum) {
        var a = this.get('primaryForum');
        a && (this.primaryForum = new c(e, a, {
          channel: this
        }), this.unset('primaryForum'))
      }
    },
    updatePrimaryForum: function () {
      var a = this.get('primaryForum');
      a && (this.primaryForum || this.buildPrimaryForum(), this.primaryForum.set(a), this.unset('primaryForum'))
    },
    updatePrimaryCategory: function () {
      var a = this.get('primaryCategory'),
      b = this.primaryCategory;
      null === a ? this.primaryCategory = void 0 : b ? b.set(a) : this.primaryCategory = new c(h, a),
      this.unset('primaryCategory'),
      this.trigger('changeRelated:primaryCategory')
    },
    fetch: function (c) {
      return c = c ? a.clone(c) : {
      },
      c.data = this.buildFetchData(c.data),
      b.Model.prototype.fetch.call(this, c)
    },
    buildFetchData: function (b) {
      var c = b ? a.clone(b) : {
      };
      return this.id && (c.channel = this.id),
      c
    },
    url: function (a) {
      return d.getURL(this.constructor.URLS[a] || this.constructor.URLS.read)
    },
    sync: function (c, d, e) {
      var f = d.attributes;
      e = a.extend({
        url: this.url(c),
        emulateHTTP: !0
      }, e);
      var g = {
        bannerColor: f.bannerColor,
        description: f.description,
        primaryCategory: d.primaryCategory && d.primaryCategory.get('slug') || ''
      };
      switch ('default' === e.avatarType ? g.avatar = '' : f.avatar && !a.isString(f.avatar) && (g.avatar = f.avatar), 'file' !== e.bannerType ? g.banner = '' : f.banner && !a.isString(f.banner) && (g.banner = f.banner), c) {
        case 'create':
          e.processData = !1,
          e.contentType = !1,
          g.name = f.name,
          e.data = this.toFormData(a.extend({
          }, g, e.data));
          break;
        case 'update':
          e.processData = !1,
          e.contentType = !1,
          g.channel = f.slug,
          e.data = this.toFormData(a.extend({
          }, g, e.data))
      }
      return b.sync(c, d, e)
    },
    toFormData: function (b) {
      return a.reduce(b, function (b, c, d) {
        return b.append(d, a.isString(c) ? c.trim() : c),
        b
      }, new window.FormData)
    },
    parse: function (a) {
      return a.response || a
    },
    shouldFetch: function () {
      return !this.get('name') || !this.get('dateAdded')
    },
    ensureFetched: function () {
      this.shouldFetch() && this.fetch()
    },
    validate: function (b) {
      var c = [
      ],
      d = b.name.trim();
      d.length < this.constructor.MIN_NAME_LENGTH ? c.push({
        attrName: 'name',
        message: f.interpolate(g('Name must have at least %(minLength)s characters.'), {
          minLength: this.constructor.MIN_NAME_LENGTH
        })
      }) : d.length > this.constructor.MAX_NAME_LENGTH && c.push({
        attrName: 'name',
        message: f.interpolate(g('Name must have less than %(maxLength)s characters.'), {
          maxLength: this.constructor.MAX_NAME_LENGTH
        })
      });
      var e = b.description.trim();
      if (e.length < this.constructor.MIN_DESCRIPTION_LENGTH ? c.push({
        attrName: 'description',
        message: f.interpolate(g('Description must have at least %(minLength)s characters.'), {
          minLength: this.constructor.MIN_DESCRIPTION_LENGTH
        })
      }) : e.length > this.constructor.MAX_DESCRIPTION_LENGTH && c.push({
        attrName: 'description',
        message: f.interpolate(g('Description must have less than %(maxLength)s characters.'), {
          maxLength: this.constructor.MAX_DESCRIPTION_LENGTH
        })
      }), this.constructor.BANNER_COLORS[b.bannerColor] || c.push({
        attrName: 'bannerColor',
        message: f.interpolate(g('Banner color must be one of ' + a.invoke(a.values(this.constructor.BANNER_COLORS), 'toLowerCase').join(', ')) + '.')
      }), !a.isEmpty(c)) return c
    },
    _changeFollowingState: function (b, c) {
      return c = c || {
      },
      c.type = 'POST',
      c.data = a.extend({
        target: this.get('slug')
      }, c.data),
      d.call(b, c)
    },
    follow: function (a) {
      return this.primaryForum.set('isFollowing', !0),
      this._changeFollowingState(this.get('followUrl'), a)
    },
    unfollow: function (a) {
      return this.primaryForum.set('isFollowing', !1),
      this._changeFollowingState(this.get('unfollowUrl'), a)
    },
    toggleFollowed: function () {
      if (this.get('options').isCurationOnlyChannel && this.primaryForum) {
        var a = this.primaryForum.get('isFollowing') ? this.unfollow() : this.follow();
        return this.primaryForum.trigger('toggled:isFollowing'),
        a
      }
    },
    toJSON: function () {
      var c = b.Model.prototype.toJSON.call(this);
      return a.defaults({
        primaryCategory: this.primaryCategory ? this.primaryCategory.toJSON() : {
        }
      }, c)
    }
  }, {
    URLS: {
      read: 'channels/details',
      create: 'channels/create',
      update: 'channels/update'
    },
    BANNER_COLORS: {
      gray: g('Gray'),
      blue: g('Blue'),
      green: g('Green'),
      yellow: g('Yellow'),
      orange: g('Orange'),
      red: g('Red'),
      purple: g('Purple')
    },
    MIN_NAME_LENGTH: 3,
    MAX_NAME_LENGTH: 100,
    MIN_DESCRIPTION_LENGTH: 5,
    MAX_DESCRIPTION_LENGTH: 200
  });
  return c.addType('Channel', h),
  h
}),
define('core/utils/objectExpander', [
  'underscore',
  'core/UniqueModel',
  'core/models/Channel',
  'core/models/Thread'
], function (a, b, c, d) {
  'use strict';
  return {
    Channel: c,
    Thread: d,
    parseObject: function (b, c) {
      return a.isString(c) ? b[c] : c
    },
    buildThread: function (c, d) {
      if (d instanceof this.Thread) return d;
      if (d = this.parseObject(c, d), a.isString(d.author)) {
        var e = d.author.replace('auth.User?id=', '');
        d.author = c['auth.User?id=' + e] || e
      }
      return new b(this.Thread, d, {
        forum: this.parseObject(c, d.forum),
        author: d.author
      })
    },
    buildChannel: function (a, c) {
      return c instanceof this.Channel ? c : (c = this.parseObject(a, c), new b(this.Channel, c))
    }
  }
}),
define('core/collections/PaginatedCollection', [
  'underscore',
  'backbone'
], function (a, b) {
  'use strict';
  var c = b.Collection.extend({
    PER_PAGE: 30,
    initialize: function (b, c) {
      this.cid = a.uniqueId('collection'),
      c = c || {
      },
      this.cursor = c.cursor || {
      }
    },
    ensureFetched: a.memoize(function () {
      return this.fetch()
    }, function () {
      return this.cid
    }),
    fetch: function (c) {
      return c = c || {
      },
      c.data = a.defaults(c.data || {
      }, {
        cursor: c.cursor || '',
        limit: c.limit || this.PER_PAGE
      }),
      b.Collection.prototype.fetch.call(this, c)
    },
    hasPrev: function () {
      return this.cursor.hasPrev
    },
    hasNext: function () {
      return this.cursor.hasNext
    },
    next: function (b) {
      return this.cursor.hasNext ? this.fetch(a.extend({
      }, b, {
        add: !0,
        remove: !0,
        cursor: this.cursor.next
      })) : void this.trigger('nodata')
    },
    prev: function (b) {
      return this.cursor.hasPrev ? this.fetch(a.extend({
      }, b, {
        add: !0,
        remove: !0,
        cursor: this.cursor.prev
      })) : void this.trigger('nodata')
    },
    more: function (b) {
      function c(a) {
        f.push(a)
      }
      var d = this;
      if (b = b || {
      }, b.post ? !b.post.attributes.hasMore : !this.cursor.hasNext) return void d.trigger('nodata');
      var e,
      f = [
      ];
      if (b.post) {
        var g = this.postCursors[b.post.id];
        e = g && g.cursor ? g.cursor.next : ''
      } else e = this.cursor.next;
      return this.on('add', c),
      this.fetch(a.extend({
      }, b, {
        add: !0,
        remove: !1,
        cursor: e,
        limit: this.PER_PAGE || this.perPage,
        success: function () {
          d.trigger('add:many', f, d, b),
          d.off('add', c),
          b.success && b.success.apply(this, arguments)
        }
      }))
    },
    parse: function (c) {
      return Array.isArray(c) && a.every(c, function (a) {
        return a instanceof b.Model
      }) ? c : (this.cursor = c.cursor || {
        hasNext: !1
      }, c.response)
    },
    getLength: function () {
      return this.length
    }
  });
  return c
}),
define('core/collections/ChannelCollection', [
  'underscore',
  'core/collections/PaginatedCollection',
  'core/UniqueModel',
  'core/api',
  'core/models/Channel',
  'core/utils/objectExpander'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = b.extend({
    url: d.getURL('channels/list'),
    model: c.boundModel(e),
    initialize: function (a, c) {
      b.prototype.initialize.call(this, a, c),
      c = c || {
      },
      this.listName = c.listName
    },
    fetch: function (c) {
      return c = c || {
      },
      this.listName && (c.data = a.extend({
        listName: this.listName
      }, c.data)),
      b.prototype.fetch.call(this, c)
    },
    parse: function (c) {
      return c = b.prototype.parse.call(this, c),
      c.items ? a.map(c.items, function (a) {
        return f.buildChannel(c.objects, a.reference)
      }) : c
    }
  });
  return g
}),
define('core/common/cached-storage', [
  'underscore',
  'core/utils/storage'
], function (a, b) {
  'use strict';
  var c = function (a, b) {
    this.namespace = a,
    this.ttl = b || 300,
    this.cache = this.getFromStorage()
  };
  return a.extend(c.prototype, {
    getItem: function (a) {
      var b = this.cache[a];
      if (b) {
        if (!this.isExpired(b)) return b.value;
        delete this.cache[a]
      }
    },
    getCurrentTime: function () {
      return Math.floor((new Date).getTime() / 1000)
    },
    persist: function () {
      b.set(this.namespace, this.cache)
    },
    getFromStorage: function () {
      var c = b.get(this.namespace);
      return a.isObject(c) ? c : {
      }
    },
    isExpired: function (a) {
      return this.getCurrentTime() > a.expiry
    },
    setItem: function (a, b) {
      this.cache[a] = {
        value: b,
        expiry: this.getCurrentTime() + this.ttl
      },
      this.persist()
    },
    removeItem: function (a) {
      delete this.cache[a],
      this.persist()
    },
    getAll: function () {
      var b = a.chain(this.cache).map(function (a, b) {
        return this.getItem(b)
      }, this).compact().value();
      return this.persist(),
      b
    }
  }),
  c
}),
define('common/collections', [
  'underscore',
  'backbone',
  'moment',
  'core/api',
  'core/utils/objectExpander',
  'core/utils/storage',
  'core/collections/UserCollection',
  'core/collections/PaginatedCollection',
  'core/collections/ChannelCollection',
  'core/models/ThreadVote',
  'core/UniqueModel',
  'common/models',
  'core/common/cached-storage',
  'core/constants/voteConstants',
  'lounge/common'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o) {
  'use strict';
  var p = b.Collection.extend({
    model: j
  }),
  q = h.extend({
    PER_PAGE: 50,
    model: k.wrap(l.Post),
    url: d.getURL('threads/listPostsThreaded'),
    initialize: function (a, b) {
      h.prototype.initialize.apply(this, arguments),
      b = b || {
      },
      this.thread = b.thread,
      this.setOrder(b.order)
    },
    fetch: function (b) {
      return b = b || {
      },
      a.extend(b, {
        data: {
          limit: this.PER_PAGE,
          thread: this.thread.id,
          forum: this.thread.get('forum'),
          order: this.getOrder()
        }
      }),
      h.prototype.fetch.call(this, b)
    },
    getOrder: function () {
      return this.order
    },
    setOrder: function (a) {
      'popular' === a && this.thread.forum.get('votingType') === n.VOTING_TYPES.DISABLED ? this.order = 'desc' : this.order = a
    }
  }),
  r = b.Collection.extend({
    collection: b.Collection,
    initialize: function (a, b) {
      this.lounge = o.getLounge(),
      this.thread = b.thread,
      this.perPage = b.perPage || 20,
      this.buffer = new this.collection(a, b),
      this.resetPage(),
      this.listenTo(this.buffer, 'reset', this.resetPage)
    },
    resetPage: function (c, d) {
      d = d || {
      };
      var e = a.isUndefined(d.customThreadLength) ? this.perPage : Math.min(d.customThreadLength, this.perPage),
      f = this.buffer.slice(0, e);
      return this.postCursors = {
      },
      this.fetchedReplies = 0,
      this.trigger('set:done', f),
      b.Collection.prototype.reset.call(this, f, d)
    },
    currentPage: function () {
      var a = Math.floor((this.length - this.fetchedReplies) / this.perPage);
      return (this.length - this.fetchedReplies) % this.perPage && (a += 1),
      a
    },
    setPageFor: function (a, b) {
      var c = this.buffer.get(a),
      d = this.perPage;
      c && (d = this.perPage * Math.floor(this.buffer.indexOf(c) / this.perPage + 1)),
      this.add(this.buffer.slice(0, d), b)
    },
    hasNext: function () {
      return this.buffer.length > this.length || this.buffer.hasNext()
    },
    more: function (a) {
      a = a || {
      };
      var b = this,
      c = b.length + b.perPage,
      d = a.success;
      a.success = function () {
        a.post || b.add(b.buffer.slice(0, c)),
        b.trigger('set:done', b.models),
        d && d()
      };
      var e = a.post ? b.get(a.post.id) : null;
      e && e.attributes.hasMore ? b.collection.prototype.more.call(b, a) : !e && b.buffer.length < b.length + b.perPage && b.buffer.hasNext() ? (b.add(b.buffer.slice(0, c)), b.buffer.more(a)) : a.success()
    }
  });
  a.each(['setOrder',
  'getOrder',
  'reset'], function (a) {
    r.prototype[a] = function () {
      return this.buffer[a].apply(this.buffer, arguments)
    }
  }),
  a.each(['add',
  'remove'], function (a) {
    r.prototype[a] = function () {
      return this.buffer[a].apply(this.buffer, arguments),
      b.Collection.prototype[a].apply(this, arguments)
    }
  });
  var s = r.extend({
    model: q.prototype.model,
    collection: q,
    initialize: function () {
      r.prototype.initialize.apply(this, arguments),
      this.postCursors = {
      },
      this.fetchedReplies = 0,
      this.submittedPostsCache = new m('submitted_posts_cache'),
      this.on('set:done', this.mapStartPosts)
    },
    restoreFromCache: function () {
      var b = this.submittedPostsCache.getAll(),
      c = this;
      this.add(a.chain(b).reject(function (a) {
        return c.thread.get('id') !== a.thread || a.parent && !c.get(a.parent)
      }).map(function (a) {
        return a.isCached = !0,
        a
      }).value())
    },
    removeFromCache: function (a) {
      this.submittedPostsCache.removeItem(a.id)
    },
    saveToCache: function (a) {
      this.submittedPostsCache.setItem(a.id, a.toJSON())
    },
    mapStartPosts: function (c) {
      if (null !== c) {
        var d = this;
        c = Array.isArray(c) ? c : [
          c
        ],
        a.forEach(c.slice().reverse(), function (a) {
          var c = a instanceof b.Model ? a.get('parent') : a.parent;
          c && !d.postCursors[c] && (d.postCursors[c] = Object.defineProperty({
          }, 'startPost', {
            value: a.id,
            writeable: !1
          }))
        })
      }
    },
    fetch: function (c) {
      if (c = c || {
      }, !c.post) return this.buffer.fetch(c);
      var e = this;
      return c = a.extend({
        url: d.getURL('posts/getDescendants'),
        data: {
          limit: c.limit || this.perPage,
          order: this.getOrder(),
          post: c.post.id,
          start_post: this.postCursors[c.post.id] ? e.postCursors[c.post.id].startPost : '',
          cursor: c.cursor || ''
        }
      }, c),
      b.Collection.prototype.fetch.call(e, c)
    },
    parse: function (a, b) {
      if (!(b.url && b.url.indexOf('posts/getDescendants') > - 1)) return this.buffer.parse(a, b);
      this.postCursors[b.data.post] || (this.postCursors[b.data.post] = {
      }),
      this.postCursors[b.data.post].cursor = a.cursor,
      b.post.set('hasMore', a.cursor.hasNext),
      this.fetchedReplies += a.response.length;
      var c = this.buffer.indexOf(b.post),
      d = this.getDescendantsFromBuffer(b.post);
      return d && this.add(d, {
        at: c
      }),
      this.buffer.add(a.response, {
        at: c + d.length
      }),
      a.response
    },
    getDescendantsFromBuffer: function (b) {
      var c = {
      };
      c[b.id] = b;
      var d = this.buffer.slice(this.buffer.indexOf(b) + 1);
      return a.some(d, function (a) {
        var b = a.get('parent');
        return !b || !c[b] || (c[a.id] = a, !1)
      }),
      a.values(c)
    }
  }),
  t = b.Collection.extend({
    model: l.QueuedPost,
    initialize: function (a, b) {
      var c = this;
      c.thread = b.thread,
      c.counters = {
        comments: 0,
        replies: {
        }
      },
      c.on('add', function (a) {
        var b = a.getVisibleParent(c.thread),
        d = c.counters.replies;
        b ? (d[b.id] = (d[b.id] || 0) + 1, b.id === a.get('parentId') && a.set('immedReply', !0)) : c.counters.comments += 1
      })
    },
    comparator: function (a) {
      return parseInt(a.id, 10)
    },
    isDescendant: function (b, c) {
      var d = b.get('parentId'),
      e = d ? this.get(d) : null,
      f = {
      };
      for (a.each(c, function (a) {
        f[a] = !0
      }); e; ) {
        if (f[e.get('id')] === !0) return !0;
        d = e.get('parentId'),
        e = d ? this.get(d) : null
      }
      return !1
    },
    drain: function D(b) {
      function c(a) {
        var b = [
        ];
        e.each(function (a) {
          null === a.get('parentId') && b.push(a.get('id'))
        }),
        e.reset(e.filter(function (c) {
          return null === c.get('parentId') || e.isDescendant(c, b) ? void a(c) : c
        })),
        e.counters.comments = 0
      }
      function d(c) {
        var d,
        f = [
        ];
        d = e.filter(function (a) {
          var c = a.getVisibleParent(e.thread);
          return c && c.get('id') === b ? void f.push(a) : a
        }),
        f = a.sortBy(f, function (a) {
          return parseInt(a.get('id'), 10)
        }),
        a.each(f, function (a) {
          c(a)
        }),
        e.reset(d),
        e.counters.replies[b] = 0
      }
      var e = this,
      D = b ? d : c;
      return D(function (a) {
        e.thread.posts.add(a.toPost(e.thread))
      })
    }
  }),
  u = b.Collection.extend({
    models: l.TypingUser,
    initialize: function () {
      var b = this;
      b.gc = null,
      b.on('add remove reset', function () {
        var c = b.count();
        return c > 0 && null === b.gc ? void (b.gc = setInterval(a.bind(b.cleanup, b), 60000)) : void (c <= 0 && null !== b.gc && (clearInterval(b.gc), b.gc = null))
      }, b)
    },
    count: function (a) {
      var b = this.filter(function (b) {
        return !(a && b.id === a) && b.get('typing')
      });
      return b.length
    },
    cleanup: function () {
      var a = c();
      this.reset(this.filter(function (b) {
        return a.diff(b.lastModified, 'minutes') < 5
      }))
    }
  }),
  v = h.extend({
    model: k.wrap(l.Post),
    url: d.getURL('users/listPostActivity')
  }),
  w = h.extend({
    model: l.Thread,
    url: d.getURL('timelines/ranked'),
    initialize: function (a, b) {
      b = b || {
      },
      this.type = b.type,
      this.target = b.target
    },
    fetch: function (b) {
      return b = b || {
      },
      b.data = a.extend({
        type: this.type,
        target: this.target
      }, b.data),
      h.prototype.fetch.call(this, b)
    },
    parse: function (b) {
      return b = h.prototype.parse.call(this, b),
      a.map(b.activities, function (a) {
        return e.buildThread(b.objects, a.items[0].object)
      })
    }
  }),
  x = b.Collection.extend({
    model: l.SyncedTopUser,
    url: d.getURL('forums/listMostActiveUsers'),
    initialize: function (a, b) {
      this.forum = b.forum,
      this.limit = b.limit
    },
    fetch: function (c) {
      return b.Collection.prototype.fetch.call(this, a.extend({
        data: {
          forum: this.forum,
          limit: this.limit
        }
      }, c))
    },
    parse: function (b) {
      return a.filter(b.response, function (a) {
        if (parseFloat(a.rep) > 0.7) return a
      })
    }
  });
  g.prototype.model = k.wrap(l.User);
  var y = b.Collection.extend({
    model: l.SyncedUser,
    url: d.getURL('forums/listModerators'),
    initialize: function (a, b) {
      this.forum = b.forum
    },
    fetch: function (c) {
      return b.Collection.prototype.fetch.call(this, a.extend({
        data: {
          forum: this.forum
        }
      }, c))
    },
    parse: function (b) {
      return a.map(b.response, function (a) {
        return a.user
      })
    }
  }),
  z = 'reaction-vote',
  A = b.Collection.extend({
    url: d.getURL('threadReactions/loadReactions'),
    initialize: function (a, b) {
      this.thread = b.thread,
      this.enabled = Boolean(a.length),
      this.eligible = Boolean(b.eligible),
      this.userIsAnonymous = b.userIsAnonymous
    },
    fetch: function (c) {
      return b.Collection.prototype.fetch.call(this, a.extend({
        data: {
          thread: this.thread.id
        }
      }, c))
    },
    parse: function (a) {
      var b = a.response,
      c = b.reactions,
      d = b.selected && b.selected.id;
      if (!d && this.userIsAnonymous) {
        var e = f.get(z);
        d = e && e[this.thread.get('id')]
      }
      if (d) {
        var g = c.filter(function (a) {
          return a.id === d
        });
        g.length && (g[0].isSelected = !0, g[0].votes || (g[0].votes = 1))
      }
      return this.enabled = Boolean(c.length),
      this.eligible = b.eligible,
      this.prompt = b.prompt,
      c
    },
    toggleEnabled: function () {
      var a = this;
      d.call('threadReactions/disableForThread', {
        method: 'POST',
        data: {
          thread: this.thread.get('id'),
          enable: this.enabled ? 0 : 1
        },
        success: function () {
          a.enabled = !a.enabled,
          a.trigger('change:enabled'),
          a.enabled && !a.length && a.fetch()
        }
      })
    },
    vote: function (b, c) {
      var e = this.at(b);
      if (e && !e.get('isSelected')) {
        c = c || {
        },
        this.trigger('vote:start');
        var g = this;
        d.call('threadReactions/vote', a.extend({
        }, c, {
          method: 'POST',
          data: {
            thread: this.thread.get('id'),
            reaction: e.get('id')
          },
          success: function () {
            if (g.forEach(function (a, c) {
              var d = c === b,
              e = a.get('votes');
              d && (e += 1),
              a.get('isSelected') && (e = Math.max(0, e - 1)),
              a.set({
                isSelected: d,
                votes: e
              })
            }, g), g.trigger('vote:end'), g.userIsAnonymous) {
              var a = f.get(z) || {
              };
              a[g.thread.get('id')] = e.get('id'),
              f.set(z, a)
            }
            c.success && c.success()
          },
          error: function () {
            g.trigger('vote:end'),
            c.error && c.error()
          }
        }))
      }
    }
  }),
  B = b.Collection.extend({
    url: d.getURL('gifs/search'),
    model: l.GifObject,
    query: null,
    page: null,
    fetch: function (c) {
      return c.query === this.query ? this.page += 1 : this.page = 1,
      b.Collection.prototype.fetch.call(this, a.extend({
        data: {
          forum: c.forum,
          query: c.query,
          page: this.page
        }
      }, c))
    },
    parse: function (a, b) {
      var c = a.response,
      d = this.toJSON();
      return b.query === this.query ? d.concat(c) : (this.query = b.query, c)
    },
    reset: function () {
      return this.query = null,
      this.page = null,
      b.Collection.prototype.reset.call(this)
    }
  }),
  C = b.Collection.extend({
    url: d.getURL('mentions/listUsers'),
    model: l.SyncedUser,
    LIMIT: 5,
    query: null,
    cursor: null,
    initialize: function (a, b) {
      this.threadId = b && b.threadId
    },
    fetch: function (c) {
      var d = this.cursor && this.cursor.hasNext;
      if (this.query !== c.query || d) return b.Collection.prototype.fetch.call(this, a.extend({
        data: {
          thread: this.threadId,
          cursor: c.next && d && this.cursor.next ? this.cursor.next.slice(2) : null,
          query: c.query,
          limit: c.limit || this.LIMIT
        }
      }, c))
    },
    parse: function (a, c) {
      var d = a.response,
      e = a.cursor,
      f = this.toJSON();
      return f = c.query === this.query ? f.concat(d) : d,
      this.query = c.query,
      this.cursor = e,
      this.set(f),
      b.Collection.prototype.parse.call(this, f),
      f
    },
    reset: function () {
      return this.query = null,
      this.cursor = null,
      b.Collection.prototype.reset.call(this)
    }
  });
  return {
    PaginatedCollection: h,
    UserCollection: g,
    ChannelCollection: i,
    PostCollection: q,
    SubpaginatedPostCollection: s,
    TypingUserCollection: u,
    TopUserCollection: x,
    RankedThreadCollection: w,
    ThreadVoteCollection: p,
    PostActivityCollection: v,
    QueuedPostCollection: t,
    ModeratorCollection: y,
    ReactionsCollection: A,
    GifObjectsCollection: B,
    UserSuggestionsCollection: C
  }
}),
define('core/constants/storageConstants', [
  'exports'
], function (a) {
  'use strict';
  a.STORAGE_KEY_SESSION_ID = 'sessionId'
}),
define('core/models/Session', [
  'jquery',
  'underscore',
  'backbone',
  'moment',
  'core/api',
  'core/bus',
  'core/config',
  'core/constants/storageConstants',
  'core/time',
  'core/utils',
  'core/utils/cookies',
  'core/utils/guid',
  'core/utils/auth',
  'core/utils/storage',
  'core/models/BaseUser',
  'core/models/User'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p) {
  'use strict';
  var q = function () {
    return m.getFromCookie()
  },
  r = function () {
    return n.get(h.STORAGE_KEY_SESSION_ID)
  },
  s = c.Model.extend({
    initialize: function () {
      this.constructor.fromCookie = b.once(q),
      this.user = this.getAnonUserInstance()
    },
    setUser: function (a) {
      this.user && this.stopListening(this.user),
      this.user = a,
      this.setIfNewUser(),
      this.listenTo(a, 'all', this.trigger),
      this.trigger('change:id', a)
    },
    isLoggedOut: function () {
      return !this.isLoggedIn()
    },
    isLoggedIn: function () {
      return Boolean(this.user.get('id'))
    },
    fetch: function (a) {
      var c = a || {
      };
      return e.call('users/details.json', {
        data: c.data,
        success: b.bind(function (a) {
          a = a.response,
          a.id && this.setUser(this.getUserInstance(a)),
          c.success && c.success(a),
          c.complete && c.complete(a)
        }, this),
        error: function (a) {
          c.error && c.error(a),
          c.complete && c.complete(a)
        }
      })
    },
    getAnonUserInstance: function (a) {
      return new o(a)
    },
    getUserInstance: function (a) {
      return new p(a)
    },
    getCsrfToken: function () {
      var a = k.read('csrftoken');
      return a || (a = l.generate().replace(/\W/g, ''), k.create('csrftoken', a, {
        domain: window.location.hostname,
        expiresIn: 31536000000
      })),
      a
    },
    authenticate: function (c) {
      var d = this.authServices[c];
      if (d) {
        if (b.isFunction(d)) return d.call(this);
        f.trigger('uiAction:openLogin', c);
        var e = this.getAuthWindowArgs(d),
        g = d.url;
        g += (g.indexOf('?') > - 1 ? '&' : '?') + a.param(e),
        this.openAuthWindow(g, d.width, d.height)
      }
    },
    authServices: {
      disqus: {
        url: g.urls.login,
        width: 460,
        height: 355,
        attachExperiment: !0
      },
      twitter: {
        url: g.urls.oauth.twitter,
        width: 650,
        height: 680,
        csrf: !0,
        attachExperiment: !0
      },
      facebook: {
        url: g.urls.oauth.facebook,
        width: 550,
        height: 320,
        csrf: !0,
        attachExperiment: !0
      },
      google: {
        url: g.urls.oauth.google,
        width: 445,
        height: 635,
        csrf: !0,
        attachExperiment: !0
      },
      microsoft: {
        url: g.urls.oauth.microsoft,
        width: 650,
        height: 635,
        csrf: !0,
        attachExperiment: !0
      },
      apple: {
        url: g.urls.oauth.apple,
        width: 445,
        height: 750,
        csrf: !0,
        attachExperiment: !0
      }
    },
    getAuthWindowArgs: function (a) {
      var c = {
      };
      return a.csrf && (c.ctkn = this.getCsrfToken()),
      b.extend(c, a.params),
      c
    },
    openAuthWindow: function (a, b, c) {
      return j.openWindow(a, '_blank', {
        width: b,
        height: c
      })
    },
    setIfNewUser: function () {
      var a = this.user.get('joinedAt');
      if (this.user.get('isAnonymous') || !a) return void this.user.set('joinedRecently', !1);
      var b = i.assureTzOffset(a);
      this.user.set('joinedRecently', d().subtract(10, 'seconds').isBefore(b))
    }
  });
  return s.fromCookie = q,
  s.fromLocalStorage = r,
  s.isKnownToBeLoggedOut = function () {
    return !s.fromCookie().id && !s.fromLocalStorage()
  },
  s
}),
define('core/WindowBus', [
  'jquery',
  'underscore',
  'backbone',
  'modernizr'
], function (a, b, c, d) {
  'use strict';
  var e = c.Model.extend({
    initialize: function () {
      d.localstorage && a(window).on('storage', b.bind(this.onStorageEvent, this))
    },
    broadcast: function (a, b) {
      if (d.localstorage) {
        var c = JSON.stringify({
          name: a,
          data: b,
          time: (new Date).getTime()
        });
        try {
          window.localStorage.setItem(this.constructor.STORAGE_KEY, c)
        } catch (e) {
        }
      }
    },
    onStorageEvent: function (a) {
      var b = a.originalEvent.key,
      c = a.originalEvent.newValue;
      if (c && b === this.constructor.STORAGE_KEY) try {
        c = JSON.parse(c),
        this.trigger(c.name, c.data)
      } catch (d) {
      }
    }
  }, {
    STORAGE_KEY: 'disqus.bus'
  });
  return e
}),
define('templates/lounge/threadVotes', [
  'react',
  'core/config/urls',
  'core/strings',
  'core/switches',
  'core/utils/object/get'
], function (a, b, c, d, e) {
  'use strict';
  var f = c.gettext,
  g = function (c) {
    var g = c.thread && c.thread.forum,
    h = d.isFeatureActive('embed_refresh', {
      forum: g
    }),
    i = h && d.isFeatureActive('embed_refresh_v2', {
      forum: g
    }),
    j = h ? 'favorite-button-toggle' : 'dropdown-toggle',
    k = h ? 'label-count-refresh' : 'label-count',
    l = i ? 'favorite-icon favorite-icon--refresh-v2' : 'favorite-icon',
    m = function () {
      return i ? a.createElement('span', {
        className: 'label label-default'
      }, a.createElement('span', {
        className: l + ' icon-heart-empty'
      })) : h ? null : a.createElement('span', {
        className: 'label label-default'
      }, a.createElement('span', {
        className: 'favorite-icon icon-heart-empty'
      }))
    },
    n = function () {
      return i ? a.createElement('span', {
        className: 'label label-favorited'
      }, a.createElement('span', {
        className: l + ' icon-heart'
      })) : h ? null : a.createElement('span', {
        className: 'label label-favorited'
      }, a.createElement('span', {
        className: 'favorite-icon icon-heart'
      }))
    },
    o = function () {
      return h && !i ? a.createElement('div', {
        className: 'favorite-icon-wrapper'
      }, a.createElement('i', {
        className: 'favorite-icon-refresh'
      })) : null
    };
    return a.createElement('div', null, a.createElement('a', {
      href: '#',
      'data-action': 'favorite',
      title: f('Favorite this discussion'),
      className: j + ' ' + (i ? j + '--v2' : '') + ' ' + (e(c.thread, [
        'userScore'
      ]) ? 'upvoted' : ''),
      'aria-label': f('Favorite this discussion')
    }, m(), n(), o(), ' ', e(c.thread, [
      'likes'
    ]) ? a.createElement('span', {
      className: 'label ' + k + ' ' + (i ? k + '--v2' : '')
    }, e(c.thread, [
      'likes'
    ], null)) : null), a.createElement('ul', {
      className: 'dropdown-menu dropdown-menu--coachmark pull-right'
    }, a.createElement('li', null, c.loggedIn ? a.createElement('div', null, a.createElement('h2', {
      className: 'coachmark__heading'
    }, f('Your 1st favorited discussion!')), a.createElement('p', {
      className: 'coachmark__description'
    }, f('Favoriting means this is a discussion worth sharing. It gets shared to your followers\' %(Disqus)s feeds if you log in, and gives the creator kudos!', {
      Disqus: 'Disqus'
    }))) : a.createElement('div', null, a.createElement('h2', {
      className: 'coachmark__heading'
    }, f('Discussion Favorited!')), a.createElement('p', {
      className: 'coachmark__description'
    }, f('Favoriting means this is a discussion worth sharing. It gets shared to your followers\' %(Disqus)s feeds, and gives the creator kudos!', {
      Disqus: 'Disqus'
    }))), ' ', a.createElement('a', {
      href: (b.root || '') + '/home/?utm_source=disqus_embed&utm_content=recommend_btn',
      className: 'btn btn-primary coachmark__button',
      target: '_blank',
      rel: 'noopener noreferrer'
    }, f(c.loggedIn ? 'See Your Feed' : 'Find More Discussions')))))
  };
  return g
}),
define('lounge/views/favorite-button', [
  'backbone',
  'core/utils/storage',
  'templates/lounge/threadVotes'
], function (a, b, c) {
  'use strict';
  var d = a.View.extend({
    className: 'thread-likes',
    events: {
      'click [data-action=favorite]': 'favoriteHandler'
    },
    initialize: function (a) {
      this.session = a.session,
      this.thread = a.thread,
      this.loggedOutFavoriteFlag = this.session.getLoggedOutUserFlags().get(d.ONBOARDING_KEY),
      this.listenTo(this.thread, 'change:userScore', this.render),
      this.listenTo(this.thread, 'change:likes', this.render),
      this.listenTo(this.session, 'change:id', this.startFavoriteOnboarding),
      this.setTooltipEnabled()
    },
    setTooltipEnabled: function () {
      this.tooltipEnabled = this.session.isLoggedIn() ? b.get(d.ONBOARDING_KEY) : !this.loggedOutFavoriteFlag.isRead()
    },
    render: function () {
      return this.$el.html(c({
        thread: this.thread.toJSON(),
        user: this.session.toJSON(),
        loggedIn: this.session.isLoggedIn()
      })),
      this
    },
    startFavoriteOnboarding: function () {
      this.session.user.get('joinedRecently') && b.set(d.ONBOARDING_KEY, 'true'),
      this.setTooltipEnabled()
    },
    favoriteHandler: function (a) {
      a.stopPropagation(),
      a.preventDefault();
      var b = 0 === this.thread.get('userScore');
      this.trigger(b ? 'vote:like' : 'vote:unlike'),
      this.thread.vote(b ? 1 : 0),
      this.toggleTooltip(b),
      this.tooltipEnabled && b && this.markAsSeen()
    },
    markAsSeen: function () {
      this.session.isLoggedIn() ? b.remove(d.ONBOARDING_KEY) : this.loggedOutFavoriteFlag.markRead()
    },
    toggleTooltip: function (a) {
      this.tooltipEnabled && (a ? this.$el.parent().addClass('open') : this.$el.parent().removeClass('open'))
    }
  }, {
    ONBOARDING_KEY: 'showRecommendOnboarding'
  });
  return d
}),
define('common/collections/LoggedOutCache', [
  'backbone',
  'core/common/cached-storage',
  'lounge/views/favorite-button'
], function (a, b, c) {
  'use strict';
  var d = [
    {
      id: 'welcome',
      title: '',
      body: ''
    }
  ],
  e = [
    {
      id: c.ONBOARDING_KEY
    }
  ],
  f = new b('notes', 7776000),
  g = a.Model.extend({
    markRead: function () {
      f.setItem(this.id, !0)
    },
    isRead: function () {
      return Boolean(f.getItem(this.id))
    }
  }),
  h = a.Collection.extend({
    initialize: function (a, b) {
      this.session = b.session
    },
    model: g,
    markAllRead: function () {
      return this.each(function (a) {
        a.markRead()
      }),
      this.session.set('notificationCount', 0),
      this
    },
    getUnread: function () {
      return this.filter(function (a) {
        return !a.isRead()
      })
    }
  });
  return {
    storage: f,
    Collection: h,
    Model: g,
    LOGGED_OUT_NOTES: d,
    LOGGED_OUT_FLAGS: e
  }
}),
define('common/Session', [
  'jquery',
  'underscore',
  'core/analytics/jester',
  'core/api',
  'core/bus',
  'core/config',
  'core/constants/storageConstants',
  'common/models',
  'common/urls',
  'core/models/Session',
  'core/switches',
  'core/UniqueModel',
  'core/utils/cookies',
  'core/utils/url/serialize',
  'core/WindowBus',
  'core/utils/storage',
  'common/collections/LoggedOutCache',
  'common/keys',
  'common/utils',
  'lounge/common',
  'lounge/tracking'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u) {
  'use strict';
  var v,
  w = 3500,
  x = {
  },
  y = new o,
  z = j.extend({
    _defaults: {
      canReply: !0,
      canModerate: !1,
      audienceSyncVerified: !1,
      sso: null
    },
    socialLoginProviders: {
      facebook: function () {
        var b = a.Deferred();
        return require(['fb'], b.resolve.bind(b), b.reject.bind(b)),
        b.promise().then(function () {
          window.FB.init({
            appId: r.facebook,
            xfbml: !1,
            status: !0,
            version: 'v2.8'
          });
          var b = a.Deferred();
          return window.FB.getLoginStatus(function (a) {
            'connected' === a.status ? b.resolve(a) : b.reject()
          }),
          b.promise()
        }).then(function (a) {
          c.logStat('lounge.auto_login.fb');
          var b = a.authResponse;
          return {
            grant_type: 'urn:disqus:params:oauth:grant-type:facebook-login',
            client_id: r.embedAPI,
            expires: b.expiresIn,
            fb_access_token: b.accessToken
          }
        })
      },
      google: function () {
        var b = a.Deferred();
        return require(['gapi'], function (a) {
          setTimeout(b.reject.bind(b), w),
          a.load('auth2', b.resolve.bind(b, a))
        }, b.reject.bind(b)),
        b.promise().then(function (b) {
          var c = b.auth2.init({
            client_id: r.google,
            fetch_basic_profile: !1,
            scope: 'profile email'
          }),
          d = a.Deferred();
          return c.then(function () {
            c.isSignedIn.get() ? d.resolve(c.currentUser.get()) : d.reject()
          }),
          d.promise()
        }).then(function (a) {
          c.logStat('lounge.auto_login.google');
          var b = a.getAuthResponse();
          return {
            grant_type: 'urn:disqus:params:oauth:grant-type:google-login',
            client_id: r.embedAPI,
            expires: b.expires_in,
            google_access_token: JSON.stringify(b)
          }
        })
      }
    },
    initialize: function () {
      z.__super__.initialize.apply(this, arguments),
      !x.fromCookie().isAuthenticated && this.getSessionId() && d.headers({
        'X-Sessionid': this.getSessionId()
      })
    },
    setSessionId: function (a) {
      p.set(g.STORAGE_KEY_SESSION_ID, a)
    },
    removeSessionId: function () {
      p.remove(g.STORAGE_KEY_SESSION_ID)
    },
    getSessionId: function () {
      return p.get(g.STORAGE_KEY_SESSION_ID)
    },
    defaults: function () {
      var a = new q.Collection(q.LOGGED_OUT_NOTES, {
        session: this
      });
      return b.extend(this._defaults, {
        notificationCount: a.getUnread().length
      })
    },
    start: function (b) {
      var c = b || {
      };
      if (this.set(c), this.listenTo(y, 'auth:success', this.fetch), this.listenTo(e.frame, {
        '!auth:success': function (a) {
          a && (a.sessionId && (d.headers({
            'X-Sessionid': a.sessionId
          }), x.fromCookie().isAuthenticated || this.setSessionId(a.sessionId)), a.message && this.trigger('alert', a.message, {
            type: 'info'
          }), a.logEvent && e.trigger('uiAction:' + a.logEvent)),
          y.broadcast('auth:success'),
          this.fetch()
        }
      }), this.bindAudienceSyncHandlers(), this.shouldFetchSession()) this.fetch();
       else if (m.read('no_auto_login') || u.isPrivate() || c && c.thread && c.thread.forum.get('settings').ssoRequired) this.loginAsAnon();
       else {
        var f = this.socialLoginProviders,
        g = !1,
        h = 0,
        i = a.Deferred(),
        j = Object.keys(f).map(function (a) {
          return f[a].call(this)
        }, this),
        k = function (a) {
          g || (g = !0, i.resolve(a))
        },
        l = function (a) {
          h += 1,
          h === j.length && i.reject(a)
        };
        j.forEach(function (a) {
          a.then(k).fail(l)
        }),
        i.promise().then(function (b) {
          return a.post('https://disqus.com/api/oauth/2.0/access_token/', b)
        }).then(function (a) {
          this.fetch({
            data: {
              access_token: a.access_token
            }
          })
        }.bind(this)).fail(this.loginAsAnon.bind(this))
      }
    },
    stop: function () {
      this.stopListening(),
      this.off()
    },
    loginAsAnon: function () {
      this.setUser(this.getAnonUserInstance())
    },
    shouldFetchSession: function () {
      return Boolean(this.get('remoteAuthS3') || x.fromCookie().id || this.getSessionId())
    },
    getUserInstance: function (a) {
      return new l(h.User, a)
    },
    toJSON: function () {
      var a = this.user.toJSON.apply(this.user, arguments);
      return a.thread.canReply = this.get('canReply'),
      a.thread.canModerate || (a.thread.canModerate = this.get('canModerate')),
      a
    },
    fetch: function (a) {
      var b = this,
      c = a || {
      };
      b.has('thread') && (c.thread = b.get('thread'));
      var d = c.thread ? b.fetchThreadDetails(c) : j.prototype.fetch.call(b, c);
      return d.done(function () {
        b.set('notificationCount', 0)
      }),
      d
    },
    fetchNotificationCount: function () {
      var b = this;
      return b.isLoggedIn() ? d.call('timelines/getUnreadCount.json', {
        data: {
          type: 'notifications',
          routingVersion: f.feedApiVersion
        }
      }).done(function (a) {
        b.set('notificationCount', a.response)
      }) : a.Deferred().resolve()
    },
    fetchThreadDetails: function (a) {
      var c = this,
      e = a.thread;
      c._request && (c._request.abort(), c._request = null);
      var f = {
        thread: e.id,
        post: e.posts.pluck('id')
      };
      return c._request = d.call('embed/threadDetails.json', {
        data: f,
        success: function (a) {
          var d = a.response,
          f = {
          };
          if (d.user && (b.extend(f, d.user, {
            votes: d.votes
          }), f = b.omit(f, 'badges')), d.blockedUsers || d.blockingUsers) {
            var g = d.session.canModerate ? new Set(d.blockedUsers) : new Set([].concat(_toConsumableArray(d.blockedUsers), _toConsumableArray(d.blockingUsers)));
            b.extend(f, d.user, {
              blockedUserIdSet: g
            }),
            f.blockedUserIdSet.forEach(function (a) {
              new l(h.User, {
                id: a
              }).set({
                isBlocked: !0
              })
            })
          }
          var i = c.get('thread') && c.get('thread').forum && c.get('thread').forum.id;
          k.isFeatureActive('embed_refresh', {
            forum: i
          }) && d.followingUsers && (b.extend(f, d.user, {
            followingUserIdSet: new Set(d.followingUsers)
          }), f.followingUserIdSet.forEach(function (a) {
            return new l(h.User, {
              id: a,
              isFollowing: !0
            })
          })),
          c.set(d.session),
          f.id ? (c.setUser(new l(h.User, f)), e.users.add(c.user), d.thread && (e.set('userScore', d.thread.userScore), e.set('userSubscription', d.thread.userSubscription), e.set('userRating', d.thread.userRating))) : c.loginAsAnon(),
          c.trigger('fetchThreadDetails:success')
        },
        complete: function () {
          c._request = null
        }
      }),
      c._request
    },
    logout: function () {
      this.removeSessionId();
      var a = this.get('sso');
      this.isSSO() && a && a.logout ? e.frame.sendHostMessage('navigate', a.logout) : this.locationReplace(n(i.logout, {
        redirect: window.location.href
      }))
    },
    locationReplace: function (a) {
      window.location.replace(a)
    },
    isSSO: function () {
      return this.user && 'sso' === this.user.get('user_type')
    },
    getAuthWindowArgs: function (a) {
      var c = j.prototype.getAuthWindowArgs.call(this, a),
      d = t.getLounge().config;
      if (a.attachExperiment && d && d.experiment) {
        var e = d.experiment;
        c.evs = window.btoa([e.experiment,
        e.variant,
        e.service].join(':'))
      }
      return b.defaults({
        forum: this.get('thread') && this.get('thread').forum.id
      }, c)
    },
    openAuthWindow: function (a, b, c) {
      try {
        var d = this.get('thread'),
        e = d && d.currentUrl;
        window.sessionStorage && e && window.sessionStorage.setItem('discussionUrl', e)
      } catch (f) {
      }
      return j.prototype.openAuthWindow.call(this, a, b, c)
    },
    authServices: b.defaults({
      disqusDotcom: {
        url: i.dotcomLogin,
        width: 478,
        height: 590,
        params: {
          next: i.login
        },
        attachExperiment: !0
      },
      sso: function A() {
        var A = this.get('sso'),
        a = parseInt(A.width || '800', 10),
        c = parseInt(A.height || '500', 10),
        d = this.openAuthWindow(A.url, a, c);
        !function f() {
          s.isWindowClosed(d) ? e.frame.sendHostMessage('reload') : b.delay(f, 500)
        }()
      }
    }, j.prototype.authServices),
    bindAudienceSyncHandlers: function () {
      this.listenTo(this, 'change:id change:audienceSyncVerified', function () {
        this.get('audienceSyncVerified') && e.frame.sendHostMessage('session.identify', this.user.id)
      }),
      this.listenTo(e.frame, {
        '!audiencesync:grant': function () {
          this.set('audienceSyncVerified', !0)
        }
      })
    },
    getAudienceSyncUrl: function () {
      var a = {
        client_id: this.get('apiKey'),
        response_type: 'audiencesync',
        forum_id: this.get('thread').forum.id
      };
      return 'https:' === window.location.protocol && (a.ssl = 1),
      n(i.authorize, a)
    },
    getRecaptchaKey: function () {
      return this.get('recaptchaPublicKey')
    },
    audienceSync: function () {
      this.openAuthWindow(this.getAudienceSyncUrl(), 460, 355)
    },
    needsAudienceSyncAuth: function (a) {
      return a.get('settings').audienceSyncEnabled && this.isLoggedIn() && !this.get('audienceSyncVerified')
    },
    getLoggedOutUserFlags: function () {
      return this._loggedOutUserFlags ? this._loggedOutUserFlags : (this._loggedOutUserFlags = new q.Collection(q.LOGGED_OUT_FLAGS, {
        session: this
      }), this._loggedOutUserFlags)
    }
  });
  return b.extend(x, b.chain(z).keys().map(function (a) {
    return [a,
    z[a]]
  }).object().value(), {
    get: function () {
      return v = v || new z
    },
    setDefaults: function (a) {
      if (v) throw new Error('Session defaults cannot be changed after a session instance is created!');
      return z._defaults = b.extend(z.prototype._defaults, a),
      z._defaults
    },
    forget: function () {
      v && (v.stop(), v = null)
    }
  }),
  x
}),
define('common/views/mixins', [
  'jquery',
  'underscore',
  'core/bus',
  'core/UniqueModel',
  'common/models',
  'common/Session'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = {
    proxyViewEvents: function (a) {
      this.listenTo(a, 'all', function (a) {
        0 === a.indexOf('uiAction:') && this.trigger.apply(this, arguments)
      }, this)
    }
  },
  h = {
    updateUserAvatarHelper: function (b, c) {
      a('img[data-user=' + b + '][data-role="user-avatar"]').attr('src', c)
    },
    updateUserNameHelper: function (c, d) {
      var e = '[data-username="' + c + '"][data-role=username]';
      a('a' + e + ', span' + e).html(b.escape(d))
    },
    bindProfileUIListeners: function (a) {
      this.listenTo(a, {
        'change:avatar': function () {
          this.updateUserAvatarHelper(a.user.id, a.user.get('avatar').cache)
        },
        'change:name': function () {
          this.updateUserNameHelper(a.user.get('username'), a.user.get('name'))
        }
      })
    }
  },
  i = {
    toggleFollow: function (b) {
      b.preventDefault(),
      b.stopPropagation();
      var c,
      g = b && a(b.target).closest('a[data-user]').attr('data-user');
      c = this.collection && g ? this.collection.get(g) : this.user ? this.user : d.get(e.User, g);
      var h = f.get();
      return h.isLoggedOut() ? (this.trigger('authenticating'), this.listenToOnce(h, 'change:id', function () {
        h.isLoggedIn() && this.follow(c)
      }), h.get('sso') && h.get('sso').url ? void h.authenticate('sso') : void h.authenticate('disqusDotcom')) : void (c.get('isFollowing') ? this.unfollow(c) : this.follow(c))
    },
    unfollow: function (a) {
      a.unfollow(),
      c.trigger('uiAction:unfollowUser', a)
    },
    follow: function (a) {
      a.follow(),
      c.trigger('uiAction:followUser', a)
    }
  };
  return {
    FollowButtonMixin: i,
    UiActionEventProxy: g,
    ProfileHtmlHelpers: h
  }
}),
define('core/utils/isIframed', [
], function () {
  'use strict';
  return function (a) {
    try {
      return a.self !== a.top
    } catch (b) {
      return !0
    }
  }
}),
define('core/utils/addElement', [
], function () {
  'use strict';
  var a = window.document;
  return function (b, c, d) {
    var e = a.createElement(c);
    return d && Object.keys(d).forEach(function (a) {
      e.setAttribute(a, d[a])
    }),
    b.appendChild(e),
    e
  }
}),
define('core/utils/isMediaTradecraftAdEnabled', [
  'core/utils/url/parseQueryString',
  'core/switches',
  'core/utils/addElement'
], function (a, b, c) {
  'use strict';
  function d() {
    var b = a();
    if (!window.isMtcAdded) {
      window.isMtcAdded = !0;
      var d = window.document.head;
      c(d, 'link', {
        rel: 'preconnect',
        href: 'https://01.cdn.mediatradecraft.com/',
        crossorigin: ''
      }),
      c(d, 'link', {
        rel: 'dns-prefetch',
        href: 'https://01.cdn.mediatradecraft.com/'
      }),
      c(d, 'link', {
        rel: 'preconnect',
        href: 'https://securepubads.g.doubleclick.net/',
        crossorigin: ''
      }),
      c(d, 'link', {
        rel: 'dns-prefetch',
        href: 'https://securepubads.g.doubleclick.net/'
      }),
      c(d, 'link', {
        rel: 'preconnect',
        href: 'https://c.amazon-adsystem.com/',
        crossorigin: ''
      }),
      c(d, 'link', {
        rel: 'dns-prefetch',
        href: 'https://c.amazon-adsystem.com/'
      }),
      c(d, 'link', {
        rel: 'preconnect',
        href: 'https://micro.rubiconproject.com/',
        crossorigin: ''
      }),
      c(d, 'link', {
        rel: 'dns-prefetch',
        href: 'https://micro.rubiconproject.com/'
      }),
      c(d, 'script', {
        src: 'https://c.amazon-adsystem.com/aax2/apstag.js',
        async: 'true'
      }),
      c(d, 'script', {
        src: 'https://securepubads.g.doubleclick.net/tag/js/gpt.js',
        async: 'true'
      }),
      'true' === b.mtctest && 'true' !== b.mtcprod ? (c(d, 'script', {
        src: 'https://01.cdn.mediatradecraft.com/disqus/stg/main.js',
        async: 'true'
      }), c(d, 'link', {
        href: 'https://01.cdn.mediatradecraft.com/disqus/stg/main.css',
        media: 'print',
        onload: 'this.media=\'all\'',
        rel: 'stylesheet'
      })) : (c(d, 'script', {
        src: 'https://01.cdn.mediatradecraft.com/disqus/main.js',
        async: 'true'
      }), c(d, 'link', {
        href: 'https://01.cdn.mediatradecraft.com/disqus/main.css',
        media: 'print',
        onload: 'this.media=\'all\'',
        rel: 'stylesheet'
      }))
    }
  }
  return function (c, e) {
    var f = a();
    if ('false' === f.mtctest) return !1;
    var g = (!e || !e.channelId || 'true' === f.mtctest || b.isFeatureActive('mtc_ads_channels')) && (c && 'mtcdisabled' === c.experiment.experiment && 'active' === c.experiment.variant || 'true' === f.mtctest || b.isFeatureActive('mtc_ads'));
    return g ? d() : window.isMtcAdded && location.reload(),
    g
  }
}),
define('core/viglink', [
  'remote/config'
], function (a) {
  'use strict';
  var b = {
  },
  c = null;
  return b.resetVersion = function () {
    c = null
  },
  b.forceVersion = function (a) {
    c = a
  },
  b.getVersion = function () {
    return c ? c : a.lounge && a.lounge.viglink && a.lounge.viglink.version || 'none'
  },
  b.getExperimentVersion = function () {
    return a.lounge && a.lounge.viglink && a.lounge.viglink.experiment_version || 'none'
  },
  b
}),
define('common/outboundlinkhandler', [
  'jquery',
  'underscore',
  'core/utils',
  'common/utils'
], function (a, b, c, d) {
  'use strict';
  function e() {
    this.handlers = [
    ],
    this.locked = {
    },
    this.timeout = 1000
  }
  return b.extend(e.prototype, {
    handleClick: function (d) {
      var e = a(d.currentTarget),
      f = this.getLinkTrackingId(e);
      if (this.shouldHandleClick(d, e, f)) {
        var g = b.chain(this.handlers).map(function (a) {
          return a[0].call(a[1], d, e)
        }).compact().value();
        c.willOpenNewWindow(d, e) || (d.preventDefault(), this.setLatestClick(f), this.delayNavigation(d, e, g))
      }
    },
    delayNavigation: function (c, e, f) {
      this.lockLink(this.getLinkTrackingId(e));
      var g = b.bind(function () {
        this.isLatestClick(this.getLinkTrackingId(e)) && d.triggerClick(e, c.originalEvent)
      }, this);
      b.delay(g, this.timeout),
      a.when.apply(a, f).always(g)
    },
    registerBeforeNavigationHandler: function (a, b) {
      this.handlers.push([a,
      b])
    },
    getLinkTrackingId: function (a) {
      var c = a.attr('data-tid');
      return c || (c = b.uniqueId(), a.attr('data-tid', c)),
      c
    },
    shouldHandleClick: function (a, b) {
      if (!this.isLinkLocked(this.getLinkTrackingId(b))) {
        if (a.isDefaultPrevented()) return !1;
        if (!b.is('a')) return !1;
        var c = /#.*/,
        d = (b.attr('href') || '').replace(c, '');
        return !!d
      }
    },
    setLatestClick: function (a) {
      this.latestLinkId = a
    },
    isLatestClick: function (a) {
      return this.latestLinkId === a
    },
    lockLink: function (a) {
      this.locked[a] = !0
    },
    isLinkLocked: function (a) {
      return this.locked[a]
    }
  }),
  e
}),
define('core/mixins/withEmailVerifyLink', [
  'jquery',
  'underscore',
  'core/config',
  'core/utils'
], function (a, b, c, d) {
  'use strict';
  var e = d.preventDefaultHandler,
  f = {
    events: {
      'click [data-action=verify-email]': 'showVerifyEmailPopup'
    },
    showVerifyEmailPopup: e(function (b) {
      var e = a(b.target).attr('data-forum'),
      f = c.urls.verifyEmail;
      return e && (f = f + '?f=' + e),
      d.openWindow(f, '_blank', {
        width: 460,
        height: 355
      })
    })
  };
  return function () {
    this.events = b.defaults({
    }, this.events, f.events),
    b.extend(this, b.pick(f, 'showVerifyEmailPopup'))
  }
}),
define('core/constants/behindClickConstants', [
  'exports',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.get;
  a.DEFAULT_BUTTON_TEXT = b.interpolate(c('Show Comments (%(count)s)'), {
    count: '{postCount}'
  })
}),
define('core/templates/react/BehindClickTemplate', [
  'react',
  'core/constants/behindClickConstants'
], function (a, b) {
  'use strict';
  function c(a) {
    if (!a || a.indexOf(':') === - 1) return {
    };
    var b = {
    },
    c = a.split(';');
    return c.forEach(function (a) {
      var c = a.split(':').map(function (a) {
        return a.trim()
      });
      if (c[0].indexOf('-') > 0) {
        var d = c[0].split('-');
        c[0] = d[0] + d[1].charAt(0).toUpperCase() + d[1].slice(1)
      }
      b[c.splice(0, 1) [0]] = c.join(':')
    }),
    b
  }
  function d(a, b) {
    return a ? a.replace('{postCount}', b.toLocaleString()) : a
  }
  var e = function (e) {
    var f = e.postCount,
    g = e.buttonText,
    h = e.buttonCSS,
    i = e.titleEnabled,
    j = e.titleText,
    k = e.titleCSS;
    return a.createElement('div', {
      id: 'behind-click__container'
    }, i ? a.createElement('h3', {
      id: 'behind-click__title',
      style: c(k)
    }, d(j, f)) : null, a.createElement('button', {
      id: 'thread-visibility__button',
      className: 'btn alert',
      'data-action': 'toggle-thread-visibility',
      style: c(h)
    }, g ? d(g, f) : d(b.DEFAULT_BUTTON_TEXT, f)))
  };
  return e
}),
define('templates/lounge/partials/badgesMessage', [
  'react',
  'core/strings',
  'core/switches',
  'core/bus'
], function (a, b, c, d) {
  'use strict';
  var e = b.gettext,
  f = function (b) {
    var c = b.url;
    return a.createElement('a', {
      href: c,
      target: '_blank',
      rel: 'noopener noreferrer',
      className: 'policy-link publisher-anchor-color',
      onClick: function (a) {
        a.stopPropagation(),
        d.trigger('uiAction:clickBadgesMessage', c)
      }
    }, e('See the available badges'))
  },
  g = function (b) {
    var d = b.forum,
    g = b.forumBadgesLink,
    h = c.isFeatureActive('embed_refresh', {
      forum: d.id
    }),
    i = h ? 'comment-policy-refresh' : 'comment-policy',
    j = h ? 'comment-policy-refresh__text' : 'comment-policy-text',
    k = h ? 'comment-policy-refresh__heading' : 'comment-policy-text text-bold',
    l = h ? 'comment-policy-refresh__link' : 'comment-policy-link';
    return a.createElement('div', {
      id: 'badges-message',
      className: 'badges-message ' + i + ' publisher-anchor-color'
    }, a.createElement('span', {
      'data-action': 'close-badges-message',
      className: 'badges-message-close',
      tabIndex: '0'
    }), a.createElement('div', {
      className: 'content'
    }, a.createElement('p', {
      className: k
    }, e('Earn badges on %(forumName)s!', {
      forumName: d.name
    })), a.createElement('p', {
      className: j
    }, e('Badges are awarded for commenting, receiving upvotes, and other conditions established by the publisher. Awarded badges will be displayed next to your name in comments on this site as well as on your profile.'), a.createElement('p', {
      className: l
    }, a.createElement(f, {
      url: g,
      isRefreshEnabled: h
    })))), a.createElement('span', {
      'aria-hidden': 'true',
      className: 'badges-message-icon'
    }))
  };
  return g
}),
define('templates/lounge/partials/commentPolicy', [
  'react',
  'core/strings',
  'core/bus',
  'core/switches'
], function (a, b, c, d) {
  'use strict';
  var e = b.gettext,
  f = function (b) {
    var d = b.url,
    e = b.className,
    f = void 0 === e ? '' : e,
    g = b.children,
    h = b.isRefreshEnabled,
    i = h ? 'comment-policy-refresh__link' : 'comment-policy-link';
    return a.createElement('a', {
      href: d,
      target: '_blank',
      rel: 'noopener noreferrer',
      className: f + ' ' + i,
      onClick: function (a) {
        a.stopPropagation(),
        c.trigger('uiAction:clickCommentPolicy', d)
      }
    }, g)
  },
  g = function (b) {
    var c = b.forum,
    d = b.isRefreshEnabled;
    if (!c.commentPolicyLink) return null;
    var g = e('Please read our %(commentPolicyLink)s before commenting.', {
      commentPolicyLink: a.createElement(f, {
        url: c.commentPolicyLink,
        isRefreshEnabled: d
      }, e('Comment Policy'))
    });
    return g
  },
  h = function (b) {
    var c = b.forum,
    f = b.isPolicyAccepted,
    h = d.isFeatureActive('embed_refresh', {
      forum: c.id
    }),
    i = h && d.isFeatureActive('embed_refresh_v2', {
      forum: c.id
    }),
    j = h ? 'comment-policy-refresh ' + (i ? 'comment-policy-refresh--v2' : '') : 'comment-policy',
    k = h ? 'comment-policy-refresh__text' : 'comment-policy-text',
    l = h ? 'comment-policy-refresh__heading' : 'comment-policy-text text-bold';
    return a.createElement('div', {
      id: 'comment-policy',
      className: j + ' publisher-anchor-color ' + (f ? 'hidden' : '')
    }, a.createElement('div', {
      className: 'content'
    }, a.createElement('p', {
      className: l
    }, e('%(forumName)s Comment Policy', {
      forumName: c.name
    })), a.createElement('p', {
      className: k
    }, c.commentPolicyText || null, a.createElement('p', {
      className: 'comment-policy-refresh__prompt'
    }, a.createElement(g, {
      forum: c,
      isRefreshEnabled: h
    })))), h ? a.createElement('button', {
      className: 'btn comment-policy-refresh__button publisher-background-color',
      'data-action': 'accept-comment-policy'
    }, e('Got it')) : a.createElement('span', {
      'aria-hidden': 'true',
      className: 'icon icon-chat-bubble'
    }))
  };
  return h
}),
define('core/templates/react/ThreadTemplate', [
  'react',
  'core/constants/voteConstants',
  'core/strings',
  'core/switches',
  'core/utils/object/get',
  'templates/lounge/partials/badgesMessage',
  'templates/lounge/partials/commentPolicy'
], function (a, b, c, d, e, f, g) {
  'use strict';
  var h = c.gettext,
  i = function (b) {
    var c = d.isFeatureActive('embed_refresh', {
      forum: b.forum.id
    }),
    e = c && d.isFeatureActive('embed_refresh_v2', {
      forum: b.forum.id
    }),
    f = !1,
    i = c ? 'disqus-footer__wrapper disqus-footer__wrapper--refresh' : 'disqus-footer__wrapper',
    j = c ? 'load-more-refresh ' + (e ? 'load-more-refresh--v2' : '') : 'load-more',
    k = c ? 'btn load-more-refresh__button ' + (e ? '' : 'publisher-background-color-refresh') : 'btn load-more__button',
    l = c ? 'alert alert--realtime alert--realtime--refresh ' + (e ? 'alert--realtime--refresh-v2' : '') : 'alert alert--realtime',
    m = (b.forum.commentPolicyText || b.forum.commentPolicyLink) && !b.isPolicyAccepted,
    n = a.createElement('button', {
      className: l,
      style: {
        display: 'none'
      },
      'data-role': 'realtime-notification'
    }),
    o = f ? null : a.createElement('div', {
      id: 'highlighted-post',
      'data-tracking-area': 'highlighted',
      className: 'highlighted-post'
    });
    return a.createElement('div', {
      id: 'thread__wrapper'
    }, a.createElement('div', {
      id: 'placement-top',
      'data-tracking-area': 'discovery-north'
    }), a.createElement('div', {
      id: 'onboard',
      'data-tracking-area': 'onboard'
    }), m && c ? a.createElement(g, {
      forum: b.forum,
      isPolicyAccepted: b.isPolicyAccepted
    }) : null, a.createElement('div', {
      id: 'reactions__container'
    }), a.createElement('div', {
      id: 'ratings__container'
    }), m && !c ? a.createElement(g, {
      forum: b.forum,
      isPolicyAccepted: b.isPolicyAccepted
    }) : null, a.createElement('div', {
      id: 'badges-message__container'
    }), c ? null : o, a.createElement('div', {
      id: 'global-alert'
    }), a.createElement('div', {
      id: 'tos__container'
    }), b.inHome ? null : a.createElement('header', {
      id: 'main-nav',
      'data-tracking-area': 'main-nav'
    }), a.createElement('section', {
      id: 'conversation',
      'data-role': 'main',
      'data-tracking-area': 'main'
    }, a.createElement('div', {
      id: 'posts'
    }, a.createElement('div', {
      id: 'form',
      className: 'textarea-outer-wrapper--top-level'
    }), c ? null : n, a.createElement('div', {
      id: 'email-signup'
    }), a.createElement('div', {
      id: 'secondary-navigation'
    }), a.createElement('div', {
      id: 'no-posts',
      style: {
        display: 'none'
      }
    }), c ? o : null, c ? n : null, f ? a.createElement('div', {
      id: 'embed_v2-thread'
    }) : a.createElement('ul', {
      id: 'post-list',
      className: 'post-list loading'
    }), a.createElement('div', {
      className: j,
      'data-role': 'more',
      style: {
        display: 'none'
      }
    }, a.createElement('a', {
      href: '#',
      'data-action': 'more-posts',
      className: k
    }, h('Load more comments'))))), a.createElement('div', {
      id: 'placement-bottom',
      'data-tracking-area': 'discovery-south'
    }), b.hideFooter ? null : a.createElement('footer', {
      id: 'footer',
      'data-tracking-area': 'footer',
      className: i
    }))
  };
  return i
}),
define('lounge/menu-handler', [
  'jquery',
  'core/bus'
], function (a, b) {
  'use strict';
  return {
    init: function (c) {
      function d() {
        a('.dropdown').removeClass('open')
      }
      a('html').on('click', d),
      a('body').delegate('[data-toggle]', 'click', function (b) {
        b.stopPropagation(),
        b.preventDefault();
        var e = a(b.currentTarget),
        f = e.closest('.' + e.attr('data-toggle')),
        g = 'disabled' !== f.attr('data-dropdown') && !f.hasClass('open');
        if (f.attr('data-dropdown', 'enabled'), d(), g) {
          f.addClass('open');
          var h = f.data('view-id');
          h && c.trigger('opened:' + h, f)
        }
      }),
      b.frame.on('window.click', d)
    }
  }
}),
define('lounge/mixins', [
  'core/utils/url/serialize',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.gettext,
  d = {
    _sharePopup: function (a, b) {
      return window.open(a, '_blank', b || 'width=550,height=520')
    },
    share: function (a) {
      this.sharers[a].call(this)
    },
    sharers: {
      twitter: function () {
        var b = 'https://twitter.com/intent/tweet',
        c = this.model.shortLink();
        this._sharePopup(a(b, {
          url: c,
          text: this.model.twitterText(c)
        }))
      },
      facebook: function () {
        this._sharePopup(a('https://www.facebook.com/sharer.php', {
          u: this.model.shortLink()
        }), 'width=655,height=352')
      },
      email: function () {
        window.location.href = a('mailto:', {
          subject: c('Somebody has shared this with you on Disqus'),
          body: c('Check out this discussion') + ': ' + this.model.shortLink()
        })
      }
    }
  },
  e = function () {
    function a() {
      return this.collapseTarget && this.collapseTarget.length || (this.collapseTarget = this.collapseTargetSelector ? this[this.collapseScope].find(this.collapseTargetSelector) : this[this.collapseScope]),
      this.collapseTarget
    }
    function b() {
      var b = this;
      if (b.isCollapseAllowed) {
        var c = a.call(b);
        c && c.length && (c.height(b.collapsedHeight), e.call(b))
      }
    }
    function c(a) {
      var b = this;
      if (b.collapseTarget && b.collapseTarget.length) {
        var c = b.collapseTarget;
        c.css('height', 'auto'),
        c.css('maxHeight', 'none'),
        f.call(b),
        a || (b.isCollapseAllowed = !1)
      }
    }
    function d() {
      return this.seeMoreButton && this.seeMoreButton.length || (this.seeMoreButton = a.call(this).siblings('[data-action=see-more]')),
      this.seeMoreButton
    }
    function e() {
      var a = this;
      d.call(this).removeClass('hidden').on('click', function () {
        a.expand()
      })
    }
    function f() {
      d.call(this).addClass('hidden').off('click')
    }
    return function (a) {
      var d = this;
      d.isCollapseAllowed = !0,
      d.collapsedHeight = a.collapsedHeight,
      d.collapseTargetSelector = a.collapseTargetSelector,
      d.collapseScope = a.collapseScope || '$el',
      d.collapse = b,
      d.expand = c
    }
  }();
  return {
    ShareMixin: d,
    asCollapsible: e
  }
}),
define('lounge/realtime', [
  'underscore',
  'backbone',
  'loglevel',
  'remote/config',
  'common/urls',
  'core/utils/url/serialize',
  'common/utils'
], function (a, b, c, d, e, f, g) {
  'use strict';
  function h() {
    s.apply(this, arguments),
    this.marker = 0,
    this.interval = m,
    this._boundOnError = a.bind(this.onError, this),
    this._boundOnLoad = a.bind(this.onLoad, this),
    this._boundOnProgress = a.bind(this.onProgress, this)
  }
  function i() {
    s.apply(this, arguments),
    this.handshakeSuccess = null,
    this.interval = m,
    this.handshakeFails = 0,
    this._boundOnOpen = a.bind(this.onOpen, this),
    this._boundError = a.bind(this.onError, this),
    this._boundClose = a.bind(this.onClose, this),
    this._boundMessage = a.compose(a.bind(this.onMessage, this), function (a) {
      return JSON.parse(a.data)
    })
  }
  var j = d.lounge.REALTIME || {
  },
  k = j.EXP_BASE || 2,
  l = j.BACKOFF_LIMIT || 300,
  m = j.BACKOFF_INTERVAL || 1,
  n = j.MAX_HANDSHAKE_FAILS || 1,
  o = j.WEBSOCKETS_ENABLED !== !1 && window.WebSocket && 2 === window.WebSocket.CLOSING,
  p = j.XHR_ENABLED !== !1,
  q = function () {
  },
  r = function () {
    throw new Error('Pipe class cannot be used directly.')
  },
  s = function (b) {
    this.channel = b,
    this.connection = null,
    this.paused = !1,
    this._msgBuffer = [
    ],
    this._boundOpen = a.bind(this.open, this)
  };
  a.extend(s.prototype, b.Events, {
    getUrl: function (b) {
      var c = {
      };
      return a.extend(c, b),
      f(this.baseUrl + this.channel, c)
    },
    onMessage: function (a) {
      var b = a.message_type,
      d = a.firehose_id;
      this.lastEventId = d,
      c.debug('RT: new message:', b, d);
      var e = {
        type: b,
        data: a.message_body,
        lastEventId: d
      };
      this.trigger(b, e)
    },
    _msgToBuffer: function () {
      this._msgBuffer.push(a.toArray(arguments))
    },
    pause: function (a) {
      this.paused || (this.paused = !0, this._trigger = this.trigger, this.trigger = a === !1 ? q : this._msgToBuffer, c.debug('RT: paused, buffered: %s', a !== !1))
    },
    resume: function () {
      if (this.paused) {
        this.paused = !1,
        this.trigger = this._trigger,
        c.debug('RT: resumed, buffered messages: %s', this._msgBuffer.length);
        for (var a; a = this._msgBuffer.shift(); ) this.trigger.apply(this, a)
      }
    },
    open: r,
    close: function () {
      var a = this.connection;
      return !!a && (this.connection = null, a)
    }
  }),
  a.extend(h.prototype, s.prototype, {
    baseUrl: e.realertime + '/api/2/',
    onError: function () {
      this.connection && (this.connection = null, this.trigger('error', this), this.interval <= l && (this.interval *= k), c.info('RT: Connection error, backing off %s secs', this.interval), a.delay(this._boundOpen, 1000 * this.interval))
    },
    onLoad: function () {
      this.connection && (this.connection = null, this.trigger('success', this), a.defer(this._boundOpen))
    },
    onProgress: function () {
      if (this.connection) {
        var a,
        b,
        d,
        e,
        f = this.connection.responseText,
        g = 0;
        if (f && !(this.marker >= f.length)) {
          a = f.slice(this.marker).split('\n');
          for (var h = a.length, i = 0; i < h; i++) if (b = a[i], g += b.length + 1, d = b.replace(/^\s+|\s+$/g, '')) {
            try {
              e = JSON.parse(d)
            } catch (j) {
              if (i === h - 1) {
                g -= b.length + 1;
                break
              }
              c.debug('RT: unable to parse: ', d, b);
              continue
            }
            this.onMessage(e)
          } else c.debug('RT: ignoring empty row...');
          g > 0 && (this.marker += g - 1)
        }
      }
    },
    open: function () {
      this.close();
      var a = this.connection = g.CORS.request('GET', this.getUrl(), this._boundOnLoad, this._boundOnError);
      if (!a) return void c.debug('RT: Cannot use any cross-domain request tool with StreamPipe. Bailing out.');
      a.onprogress = this._boundOnProgress,
      this.connection = a,
      this.marker = 0;
      try {
        a.send()
      } catch (b) {
        this.connection = null,
        c.debug('RT: Attempt to send a CORS request failed.')
      }
    },
    close: function () {
      var a = s.prototype.close.apply(this);
      return a && a.abort()
    }
  }),
  a.extend(i.prototype, s.prototype, {
    baseUrl: 'wss:' + e.realertime + '/ws/2/',
    onOpen: function () {
      c.debug('RT: [Socket] Connection established.'),
      this.handshakeSuccess = !0
    },
    onError: function () {
      if (!this.handshakeSuccess) {
        if (this.handshakeFails >= n) return c.debug('RT: [Socket] Error before open, bailing out.'),
        void this.trigger('fail');
        this.handshakeFails += 1
      }
      this.connection && (this.connection = null, this.trigger('error'), this.interval <= l && (this.interval *= k), c.error('RT: Connection error, backing off %s secs', this.interval), a.delay(this._boundOpen, 1000 * this.interval))
    },
    onClose: function (a) {
      if (this.connection) {
        if (!a.wasClean) return this.onError();
        this.connection = null,
        c.debug('RT: [Socket] Connection closed. Restarting...'),
        this.trigger('close'),
        this.open()
      }
    },
    open: function () {
      this.close();
      try {
        this.connection = new window.WebSocket(this.getUrl())
      } catch (a) {
        return this.onError()
      }
      var b = this.connection;
      b.onopen = this._boundOnOpen,
      b.onerror = this._boundError,
      b.onmessage = this._boundMessage,
      b.onclose = this._boundClose
    },
    close: function () {
      var a = s.prototype.close.apply(this);
      return a && a.close()
    }
  });
  var t = {
    _wsSupported: o,
    initialize: function (b, c, d) {
      this.close(),
      this._initArgs = [
        b,
        c,
        d
      ];
      var e = this._wsSupported,
      f = e && i || p && h;
      if (f) {
        var g = this.pipe = new f(b);
        a.chain(c).pairs().each(function (a) {
          g.on(a[0], a[1], d)
        }),
        e && g.on('fail', function () {
          this._wsSupported = !1,
          g.off(),
          this.initialize.apply(this, this._initArgs)
        }, this),
        g.open()
      }
    },
    pause: function (a) {
      this.pipe && this.pipe.pause(a)
    },
    resume: function () {
      this.pipe && this.pipe.resume()
    },
    close: function () {
      this.pipe && (this.pipe.close(), this.pipe = null)
    }
  };
  return window.addEventListener('unload', a.bind(t.close, t)),
  {
    Pipe: s,
    StreamPipe: h,
    SocketPipe: i,
    Manager: t,
    MAX_HANDSHAKE_FAILS: n
  }
}),
define('lounge/views/badges-message', [
  'jquery',
  'underscore',
  'backbone',
  'react',
  'react-dom',
  'core/switches',
  'core/common/cached-storage',
  'templates/lounge/partials/badgesMessage'
], function (a, b, c, d, e, f, g, h) {
  'use strict';
  var i = new g('badges-message', 7776000);
  i.getAll();
  var j = c.View.extend({
    events: {
      'click [data-action=close-badges-message]': 'handleDismiss',
      'keyup [data-action=close-badges-message]': 'handleDismiss'
    },
    initialize: function (a) {
      b.extend(this, b.pick(a, [
        'forum',
        'session'
      ])),
      this.model = new c.Model({
        dismissed: Boolean(i.getItem(this.forum.id))
      }),
      this.handleDismiss = this.handleDismiss.bind(this),
      this.listenTo(this.model, 'change', this.render)
    },
    handleDismiss: function (a) {
      var b = 13;
      if (!a.keyCode || a.keyCode === b) return this.model.set('dismissed', !0),
      i.setItem(this.forum.id, !0),
      Promise.resolve()
    },
    render: function () {
      var a = this.forum.get('badges');
      if (!a || !Object.keys(a).length || this.model.get('dismissed')) return this.$el.empty(),
      this;
      var b = '//disqus.com/home/forum/' + this.forum.get('id') + '/badges';
      return e.render(d.createElement(h, {
        forum: this.forum.toJSON(),
        forumBadgesLink: b
      }), this.el),
      this
    }
  });
  return j
}),
define('core/templates/react/aet/EmailSignupComplete', [
  'react',
  'core/switches'
], function (a, b) {
  'use strict';
  var c = function (c) {
    var d = c.forum,
    e = c.isVerified,
    f = c.onDismiss;
    return a.createElement('div', {
      className: 'newsletter-box spacing-bottom-large text-center'
    }, a.createElement('div', {
      className: b.isFeatureActive('embed_refresh', {
        forum: d.name
      }) ? 'text-large spacing-bottom-small' : 'text-medium spacing-bottom-small'
    }, a.createElement('strong', null, 'Thanks for subscribing!')), e ? a.createElement('div', {
      className: 'spacing-bottom-small'
    }, (d.aetBannerConfirmation || '').split('\n').map(function (b, c) {
      return a.createElement('div', {
        key: c
      }, b)
    })) : a.createElement('div', {
      className: 'spacing-bottom-small'
    }, 'To begin receiving email updates from ', d.name, ', please click the link in the confirmation email we\'ve sent to your inbox.'), a.createElement('a', {
      className: 'newsletter-box__hide',
      href: '#',
      onClick: function (a) {
        a.preventDefault(),
        f()
      }
    }, 'Dismiss this message'))
  };
  return c
}),
define('core/templates/react/aet/EmailSignupForm', [
  'react',
  'core/strings',
  'core/switches'
], function (a, b, c) {
  'use strict';
  var d = b.gettext,
  e = function (b) {
    var e = b.forum,
    f = b.isLoading,
    g = b.isLoggedIn,
    h = b.onDismiss,
    i = b.onSubscribe,
    j = b.allowEmpty;
    return a.createElement('div', {
      className: 'newsletter-box spacing-bottom-large'
    }, a.createElement('div', {
      className: c.isFeatureActive('embed_refresh', {
        forum: e.name
      }) ? 'text-large spacing-bottom-small' : 'text-medium spacing-bottom-small'
    }, a.createElement('strong', null, e.aetBannerTitle)), g ? a.createElement('button', {
      className: 'button button-fill--brand button-padding-wider pull-right',
      disabled: f,
      onClick: function () {
        i && i()
      }
    }, 'Subscribe') : null, a.createElement('div', {
      className: 'spacing-bottom'
    }, (e.aetBannerDescription || '').split('\n').map(function (b, c) {
      return a.createElement('div', {
        key: c
      }, b)
    })), a.createElement('div', {
      className: 'align align--wrap'
    }, g ? null : a.createElement('form', {
      className: 'align__item--grow',
      onSubmit: function (a) {
        a.preventDefault();
        var b = a.target.elements.email.value.trim();
        (b || j) && i && i(b)
      }
    }, a.createElement('div', {
      className: 'newsletter-box__input-group'
    }, a.createElement('span', {
      className: 'icon icon-mail text-large newsletter-box__input-group__icon'
    }), a.createElement('input', {
      type: 'email',
      name: 'email',
      placeholder: d('Enter email address'),
      'aria-label': 'Enter your email address here to opt into receiving a weekly digest of the latest articles from this publisher'
    })), a.createElement('input', {
      type: 'submit',
      className: 'button button-fill--brand button-padding-wider newsletter-box__submit',
      disabled: f,
      value: d('Subscribe'),
      'aria-label': 'Submit your email address'
    })), a.createElement('a', {
      href: '#',
      className: 'newsletter-box__hide publisher-anchor-color',
      onClick: function (a) {
        a.preventDefault(),
        h && h()
      }
    }, d('Hide this message'))))
  };
  return e
}),
define('lounge/views/email-signup', [
  'backbone',
  'react',
  'react-dom',
  'stance',
  'core/api',
  'core/bus',
  'core/templates/react/aet/EmailSignupComplete',
  'core/templates/react/aet/EmailSignupForm',
  'core/common/cached-storage'
], function (a, b, c, d, e, f, g, h, i) {
  'use strict';
  var j = 0,
  k = 2,
  l = new i('aet-dismiss');
  l.getAll();
  var m = a.View.extend({
    initialize: function (b) {
      var c = b.forum,
      d = b.session;
      this.forum = c,
      this.session = d,
      this.model = new a.Model({
        dismissed: Boolean(l.getItem(this.forum.id)),
        loading: !1,
        signupComplete: !1
      }),
      this._isFirstRender = !0,
      this.handleCompleteDismiss = this.handleCompleteDismiss.bind(this),
      this.handleDismiss = this.handleDismiss.bind(this),
      this.handleSubscribe = this.handleSubscribe.bind(this),
      this.listenTo(this.model, 'change', this.render),
      this.listenTo(this.session, 'change', this.render)
    },
    getTrackingCopy: function () {
      return {
        title: this.forum.get('aetBannerTitle'),
        description_copy: this.forum.get('aetBannerDescription'),
        confirmation_copy: this.forum.get('aetBannerConfirmation')
      }
    },
    isLoggedIn: function () {
      return Boolean(this.session.user && this.session.user.id)
    },
    handleDismiss: function () {
      return this.model.set('dismissed', !0),
      f.trigger('uiAction:clickEmailSubscriptionPromptDismiss', this.getTrackingCopy()),
      this.isLoggedIn() ? Promise.resolve(e.call('aet/dismiss', {
        data: {
          forum: this.forum.id
        },
        method: 'POST'
      })) : (l.setItem(this.forum.id, !0), Promise.resolve())
    },
    handleCompleteDismiss: function () {
      this.model.set('dismissed', !0)
    },
    handleSubscribe: function () {
      var a = this,
      b = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : null;
      if (!this.model.get('loading')) return f.trigger('uiAction:clickEmailSubscriptionPromptSubscribe', this.getTrackingCopy()),
      this.model.set('loading', !0),
      Promise.resolve(b ? e.call('aet/anonymousSubscribe', {
        data: {
          email: b,
          forum: this.forum.id
        },
        method: 'POST'
      }) : e.call('aet/subscribe', {
        data: {
          forum: this.forum.id
        },
        method: 'POST'
      })).then(function (b) {
        return a.model.set({
          loading: !1,
          signupComplete: !0
        }),
        b
      }) ['catch'](function () {
        a.model.set('loading', !1)
      })
    },
    reportView: function () {
      f.trigger('uiAction:viewEmailSubscriptionPrompt', this.getTrackingCopy())
    },
    render: function () {
      if (!this.forum.get('aetEnabled') || this.model.get('dismissed')) return this.$el.empty(),
      this;
      var a = this.session.shouldFetchSession() ? this.session.get('aetBannerStatus') : j;
      switch (a) {
        case j:
        case k:
          if (this.model.get('signupComplete') || a === k ? c.render(b.createElement(g, {
            forum: this.forum.toJSON(),
            isVerified: Boolean(this.session.user && this.session.user.get('isVerified')),
            onDismiss: this.handleCompleteDismiss
          }), this.el) : c.render(b.createElement(h, {
            forum: this.forum.toJSON(),
            isLoading: this.model.get('loading'),
            isLoggedIn: this.isLoggedIn(),
            onDismiss: this.handleDismiss,
            onSubscribe: this.handleSubscribe
          }), this.el), this._isFirstRender) {
            this._isFirstRender = !1,
            f.trigger('uiAction:loadEmailSubscriptionPrompt', this.getTrackingCopy());
            var e = d(this);
            e.isVisible() ? this.reportView() : this.listenToOnce(e, 'enter', this.reportView)
          }
          break;
        default:
          this.$el.empty()
      }
      return this
    }
  });
  return m
}),
define('react-dom/server', [
  'underscore'
], function (a) {
  'use strict';
  var b = function c(b) {
    if (null === b) return '';
    if (a.isArray(b)) return b.map(c).join('');
    if (a.isElement(b)) return b.outerHTML;
    if (b && b.nodeType === window.Node.DOCUMENT_FRAGMENT_NODE) {
      var d = window.document.createElement('div');
      return d.appendChild(b),
      d.innerHTML
    }
    return a.escape(String(b))
  };
  return {
    renderToString: b,
    renderToStaticMarkup: b
  }
}),
define('core/utils/media/upload', [
  'underscore',
  'exports',
  'core/api',
  'core/models/Media',
  'core/UniqueModel'
], function (a, b, c, d, e) {
  'use strict';
  b.uploadSupported = Boolean(window.FormData),
  b._extractFirstImageFile = function (b) {
    return a.find(b, function (a) {
      return a.type.match(/^image\//)
    })
  },
  b._uploadViaApi = function (a, b, d) {
    return Promise.resolve(c.call(a, {
      data: b,
      contentType: !1,
      processData: !1,
      method: 'POST',
      xhr: function () {
        var a = new window.XMLHttpRequest,
        b = d && d.onProgress;
        return b && a.upload.addEventListener('progress', function (a) {
          a.total && b(100 * a.loaded / a.total)
        }),
        a
      }
    }))
  },
  b.UPLOAD_URL = 'https://uploads.services.disqus.com/api/3.0/media/create.json',
  b.uploadMediaUrl = function (c, f) {
    var g,
    h = new window.FormData,
    i = b._extractFirstImageFile(c);
    return i ? (h.append('upload', i), h.append('permanent', 1), b._uploadViaApi(b.UPLOAD_URL, h, f).then(function (b) {
      var c = b.response,
      f = a.first(a.values(c));
      if (!f || !f.ok) throw g = new Error('Upload failed'),
      g.code = f && f['error-code'],
      g;
      return new e(d, {
        mediaType: d.MEDIA_TYPES.IMAGE_UPLOAD,
        url: f.url,
        thumbnailUrl: f.url
      })
    }, function (a) {
      if (a.responseJSON && 4 === a.responseJSON.code) throw g = new Error('Upload failed'),
      g.code = 'not-authenticated',
      g;
      throw a
    })) : (g = new Error('No image file to upload'), g.code = 'invalid-content-type', Promise.reject(g))
  }
}),
define('core/views/media/DragDropUploadView', [
  'underscore',
  'backbone',
  'core/utils'
], function (a, b, c) {
  'use strict';
  var d = c.stopEventHandler,
  e = b.View.extend({
    events: {
      dragover: '_dragOn',
      dragenter: '_dragOn',
      dragleave: '_dragOff',
      dragexit: '_dragOff',
      drop: '_drop'
    },
    _dragOn: d(function () {
      this.trigger('uploader:dragEnter'),
      this._toggleDragPlaceholder(!0)
    }),
    _dragOff: d(function () {
      this._toggleDragPlaceholder(!1)
    }),
    _drop: d(function (a) {
      this._toggleDragPlaceholder(!1);
      var b = a.originalEvent.dataTransfer.files;
      return b.length ? void this.trigger('uploader:attachMedia', b) : void this.trigger('uploader:dropError', 'No files')
    }),
    _toggleDragPlaceholder: a.throttle(function (a) {
      a ? this.trigger('uploader:showPlaceholder') : this.trigger('uploader:hidePlaceholder')
    }, 50)
  });
  return e
}),
define('core/templates/postMediaUploadButton', [
  'handlebars',
  'core/templates/handlebars.partials',
  'core/extensions/handlebars.helpers'
], function (a) {
  return a.template({
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      return '<a href="#" data-action="attach" class="attach" title="' + a.escapeExpression(c.gettext.call(null != b ? b : a.nullContext || {
      }, 'Upload Images', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 1,
            column: 55
          },
          end: {
            line: 1,
            column: 82
          }
        }
      })) + '" tabIndex="0" aria-label="Open file attachment menu">\n<div class="wysiwyg__attach wysiwyg__attach-dims"\nrole="img"\n/>\n</a>\n<input type="file" data-role="media-upload" tabIndex="-1" accept="image/*">\n'
    },
    useData: !0
  })
}),
define('core/views/media/UploadButtonView', [
  'jquery',
  'underscore',
  'backbone',
  'core/templates/postMediaUploadButton',
  'core/utils'
], function (a, b, c, d, e) {
  'use strict';
  var f = e.stopEventHandler,
  g = 'input[type=file][data-role=media-upload]',
  h = c.View.extend({
    events: function () {
      var a = {
        'click [data-action=attach]': '_attachMedia',
        'keydown [data-action=attach]': 'keydownHandler'
      };
      return a['change ' + g] = '_selectorChange',
      a
    }(),
    initialize: function (a) {
      this.template = a && a.template || this.generateImageUploadButton
    },
    keydownHandler: function (a) {
      var b = 13,
      c = 32;
      a.keyCode !== b && a.keyCode !== c || (a.preventDefault(), this._attachMedia())
    },
    generateImageUploadButton: function () {
      return d({
        imageUrl: 'https://c.disquscdn.com/next/embed/assets/img/attach.03c320b14aa9c071da30c904d0a0827f.svg'
      })
    },
    render: function () {
      return this.$el.html(this.template()),
      this
    },
    _attachMedia: f(b.throttle(function () {
      this.$(g).click()
    }, 1000, {
      trailing: !1
    })),
    _selectorChange: function (b) {
      var c = b.target,
      d = c.files;
      d.length && (this.trigger('uploader:attachMedia', d), a(c).replaceWith(c.cloneNode()))
    }
  });
  return h
}),
define('core/templates/postMediaUploadProgress', [
  'handlebars',
  'core/templates/handlebars.partials',
  'core/extensions/handlebars.helpers'
], function (a) {
  return a.template({
    1: function (a, b, c, d, e) {
      return '<li>\n<div class="media-progress-box">\n<div class="media-progress">\n<div class="bar" style="right: ' + a.escapeExpression(a.lambda(null != b ? b.remainingPerc : b, b)) + '%"></div>\n</div>\n</div>\n</li>\n'
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f;
      return null != (f = c.each.call(null != b ? b : a.nullContext || {
      }, null != b ? b.collection : b, {
        name: 'each',
        hash: {
        },
        fn: a.program(1, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 1,
            column: 0
          },
          end: {
            line: 9,
            column: 9
          }
        }
      })) ? f : ''
    },
    useData: !0
  })
}),
define('core/views/media/UploadsProgressSubView', [
  'backbone',
  'core/templates/postMediaUploadProgress'
], function (a, b) {
  'use strict';
  var c = a.View.extend({
    initialize: function () {
      this.collection = new a.Collection,
      this.listenTo(this.collection, 'add remove change', this.render)
    },
    hasVisible: function () {
      return Boolean(this.collection.length)
    },
    render: function () {
      return this.$el.html(b({
        collection: this.collection.toJSON()
      })),
      this
    }
  });
  return c
}),
define('core/templates/postMediaUploadRich', [
  'handlebars',
  'core/templates/handlebars.partials',
  'core/extensions/handlebars.helpers'
], function (a) {
  return a.template({
    1: function (a, b, c, d, e) {
      return '<video src="' + a.escapeExpression(a.lambda(null != b ? b.thumbnailUrl : b, b)) + '" autoplay muted loop></video>\n'
    },
    3: function (a, b, c, d, e) {
      var f;
      return '<img src="' + a.escapeExpression(a.lambda(null != b ? b.thumbnailUrl : b, b)) + '" alt="' + (null != (f = c['if'].call(null != b ? b : a.nullContext || {
      }, null != (f = null != b ? b.media : b) ? f.title : f, {
        name: 'if',
        hash: {
        },
        fn: a.program(4, e, 0),
        inverse: a.program(6, e, 0),
        data: e,
        loc: {
          start: {
            line: 9,
            column: 33
          },
          end: {
            line: 9,
            column: 112
          }
        }
      })) ? f : '') + '">\n'
    },
    4: function (a, b, c, d, e) {
      var f;
      return a.escapeExpression(a.lambda(null != (f = null != b ? b.media : b) ? f.title : f, b))
    },
    6: function (a, b, c, d, e) {
      return a.escapeExpression(c.gettext.call(null != b ? b : a.nullContext || {
      }, 'Media attachment', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 9,
            column: 75
          },
          end: {
            line: 9,
            column: 105
          }
        }
      }))
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f;
      return '<li class="publisher-border-color">\n<div class="media-box">\n<div class="media-ct">\n<div class="media-surface">\n<a href="' + a.escapeExpression(a.lambda(null != (f = null != b ? b.media : b) ? f.url : f, b)) + '" target="_blank">\n' + (null != (f = c['if'].call(null != b ? b : a.nullContext || {
      }, null != b ? b.isVideo : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(1, e, 0),
        inverse: a.program(3, e, 0),
        data: e,
        loc: {
          start: {
            line: 6,
            column: 0
          },
          end: {
            line: 10,
            column: 7
          }
        }
      })) ? f : '') + '</a>\n</div>\n</div>\n</div>\n</li>\n'
    },
    useData: !0
  })
}),
define('core/views/media/UploadsRichSubView', [
  'underscore',
  'backbone',
  'core/models/Media',
  'core/UniqueModel',
  'core/utils',
  'core/templates/postMediaUploadRich'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = b.View.extend({
    initialize: function () {
      this._hasVisible = !1,
      this.collection = new b.Collection([], {
        model: c,
        comparator: 'index'
      }),
      this.listenTo(this.collection, 'add remove reset sort change:thumbnailUrl change:mediaType change:editsFinished', this.render),
      this.listenTo(this.collection, 'change:index', a.bind(this.collection.sort, this.collection))
    },
    render: function () {
      return this.$el.empty(),
      this._hasVisible = !1,
      this.collection.each(function (b) {
        b.get('thumbnailUrl') && (a.contains(c.WEBPAGE_TYPES, b.get('mediaType')) || b.get('editsFinished') && (this.$el.append(f({
          media: b.toJSON(),
          isVideo: this.isVideo(b),
          thumbnailUrl: b.get('thumbnailUrl')
        })), this._hasVisible = !0))
      }, this),
      this
    },
    isVideo: function (a) {
      return a.get('mediaType') === c.MEDIA_TYPES.MP4_VIDEO
    },
    hasVisible: function () {
      return this._hasVisible
    },
    addMedia: function (a, b) {
      var e = d.get(c, a.url);
      if (e) e.set(a);
       else {
        if (!a.editsFinished) return;
        e = new d(c, a),
        e.fetch(b)
      }
      return this.collection.add(e),
      e
    },
    updateFromText: function (b, c, d) {
      if (!b) return void this.collection.reset();
      var f = e.bleachFindUrls(b);
      f = a.uniq(f, !1, function (a) {
        return a.url
      });
      var g = {
      };
      a.each(f, function (e) {
        g[e.url] = !0;
        var f = a.pick(e, 'index', 'url'),
        h = e.index < c && c <= e.endIndex || '.' === b[e.endIndex];
        h && !d.isPasteEvent || (f.editsFinished = !0),
        this.addMedia(f, d)
      }, this);
      var h = this.collection.pluck('url');
      g = a.keys(g);
      var i = a.difference(h, g);
      this.collection.remove(this.collection.filter(function (b) {
        return a.contains(i, b.get('url'))
      }))
    }
  });
  return g
}),
define('core/templates/postMediaUploads', [
  'handlebars',
  'core/templates/handlebars.partials',
  'core/extensions/handlebars.helpers'
], function (a) {
  return a.template({
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      return '<ul data-role="media-progress-list"></ul>\n<ul data-role="media-rich-list"></ul>\n<div class="media-expanded empty" data-role="media-preview-expanded">\n<img src=""\ndata-role="media-preview-expanded-image" alt="' + a.escapeExpression(c.gettext.call(null != b ? b : a.nullContext || {
      }, 'Media preview placeholder', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 6,
            column: 46
          },
          end: {
            line: 6,
            column: 85
          }
        }
      })) + '">\n</div>\n'
    },
    useData: !0
  })
}),
define('core/views/media/UploadsView', [
  'backbone',
  'core/views/media/UploadsProgressSubView',
  'core/views/media/UploadsRichSubView',
  'core/templates/postMediaUploads'
], function (a, b, c, d) {
  'use strict';
  var e = a.View.extend({
    initialize: function () {
      this.richView = new c,
      this.rich = this.richView.collection,
      this.uploadProgressView = new b,
      this.uploadProgress = this.uploadProgressView.collection,
      this.listenTo(this.rich, 'all', this._updateEmpty),
      this.listenTo(this.uploadProgress, 'all', this._updateEmpty)
    },
    render: function () {
      return this.richView.$el.detach(),
      this.uploadProgressView.$el.detach(),
      this.$el.html(d()),
      this._updateEmpty(),
      this.richView.setElement(this.$('[data-role=media-rich-list]') [0]),
      this.uploadProgressView.setElement(this.$('[data-role=media-progress-list]') [0]),
      this
    },
    clear: function () {
      this.rich.reset(),
      this.uploadProgress.reset()
    },
    _updateEmpty: function () {
      this.richView.hasVisible() || this.uploadProgressView.hasVisible() ? this.$el.removeClass('empty') : this.$el.addClass('empty')
    }
  });
  return e
}),
define('core/mixins/withUploadForm', [
  'underscore',
  'backbone',
  'core/strings',
  'core/utils',
  'core/utils/media/upload',
  'core/utils/storage',
  'core/views/media/DragDropUploadView',
  'core/views/media/UploadButtonView',
  'core/views/media/UploadsView'
], function (a, b, c, d, e, f, g, h, i) {
  'use strict';
  var j = c.get,
  k = function () {
    a.defaults(this, k.bothProto, k.uploadsProto, k.previewsProto)
  },
  l = {
    'invalid-image-file': j('Unfortunately your image upload failed. Please verify that the file is valid and in a supported format (JPEG, PNG, or GIF).'),
    'invalid-content-type': j('Unfortunately your image upload failed. Please verify that the file is in a supported format (JPEG, PNG, or GIF).'),
    'file-too-large': j('Unfortunately your image upload failed. Please verify that your image is under 5MB.'),
    'not-authenticated': j('You must be logged in to upload an image.')
  },
  m = j('Unfortunately your image upload failed. Please verify that your image is in a supported format (JPEG, PNG, or GIF) and under 5MB. If you continue seeing this error, please try again later.');
  return k.previewsProto = {
    initMediaPreviews: function (b, c) {
      this.mediaUploadsView = new i({
        el: b[0]
      }),
      this.mediaUploadsView.render(),
      this.updateLiveMediaDebounced = a.partial(a.debounce(this.updateLiveMedia, 500), c, !1),
      this.stopListening(c, 'keychange'),
      this.stopListening(c, 'paste'),
      this.listenTo(c, {
        keychange: this.updateLiveMediaDebounced,
        paste: function (b, d) {
          d && d.fake || a.defer(a.bind(this.updateLiveMedia, this, c, !0))
        }
      }),
      this.updateLiveMedia(c, !0)
    },
    clearMediaPreviews: function () {
      this.mediaUploadsView && this.mediaUploadsView.clear()
    },
    updateLiveMedia: function (a, b) {
      if (this.mediaUploadsView) {
        var c = a.get(),
        d = a.offset();
        this.mediaUploadsView.richView.updateFromText(c, d, {
          isPasteEvent: b,
          forum: this.thread.forum.id
        })
      }
    }
  },
  k.uploadsProto = {
    initMediaUploads: function (a, b, c) {
      this.mediaDragDropView && this.stopListening(this.mediaDragDropView),
      this.mediaDragDropView = new g({
        el: b[0]
      }),
      this.listenTo(this.mediaDragDropView, {
        'uploader:attachMedia': function () {
          f.set('usedDragDrop', 1),
          this.handleAttachMedia.apply(this, arguments)
        },
        'uploader:dragEnter': function () {
          this.$el.addClass('expanded')
        },
        'uploader:showPlaceholder': function () {
          a.show()
        },
        'uploader:hidePlaceholder': function () {
          a.hide()
        },
        'uploader:dropError': function () {
          var a = j('Sorry we didn\'t catch that. Try again?');
          this.alert(a, {
            type: 'error',
            isUploadError: !0
          })
        }
      }),
      this.mediaUploadButtonView && this.stopListening(this.mediaUploadButtonView),
      this.mediaUploadButtonView = new h({
        el: c[0]
      }),
      this.listenTo(this.mediaUploadButtonView, {
        'uploader:attachMedia': this.handleUploadViaButton
      }),
      this.mediaUploadButtonView.render()
    },
    handleUploadViaButton: function (a) {
      if (a && f.isPersistent && !f.get('usedDragDrop') && !d.isMobileUserAgent()) {
        var b = this.alert(j('Did you know you can drag and drop images too? Try it now!'));
        this.listenToOnce(b, 'dismiss', function () {
          f.set('usedDragDrop', 1)
        })
      }
      this.handleAttachMedia.apply(this, arguments)
    },
    handleAttachMedia: function (c, d) {
      var f = this,
      g = new b.Model({
        remainingPerc: 100
      });
      f.mediaUploadsView.uploadProgress.add(g),
      d = a.extend(d || {
      }, {
        onProgress: function (a) {
          g.set('remainingPerc', 100 - a)
        }
      });
      var h = function () {
        f.mediaUploadsView.uploadProgress.remove(g)
      };
      e.uploadMediaUrl(c, d).then(function (a) {
        a.fetch({
          forum: f.thread.forum.id
        }),
        f.textarea.insertAtCursor(a.get('url')),
        f.updateLiveMedia(f.textarea, !0),
        f.dismissUploadError()
      }) ['catch'](function (a) {
        var b;
        a && a.code && (b = l[a.code]),
        b || (b = m),
        f.alert(b, {
          type: 'error',
          isUploadError: !0
        })
      }).then(h, h)
    },
    dismissUploadError: function () {
      this.dismissAlert(function (a) {
        return a.options && a.options.isUploadError
      })
    },
    uploadSupported: e.uploadSupported,
    isUploadInProgress: function () {
      return this.mediaUploadsView && this.mediaUploadsView.uploadProgress.length
    }
  },
  k.bothProto = {
    initMediaViews: function (a) {
      (a.mediaembedEnabled || a.gifPickerEnabled) && this.initMediaPreviews(this.$('[data-role=media-preview]'), a.textarea),
      a.allowUploads && this.initMediaUploads(this.$('[data-role=drag-drop-placeholder]'), this.$('[data-role=textarea]'), this.$('[data-role=media-uploader]'))
    }
  },
  k
}),
define('core/editable', [
], function () {
  'use strict';
  function a(a) {
    return a.replace(e, ' ')
  }
  function b(c, d, e) {
    var f,
    h,
    i,
    j,
    k = '',
    l = [
    ];
    for ('string' != typeof e && (e = '\n\n'), j = 0; j < c.length; ++j) h = c[j],
    f = h.nodeName.toLowerCase(),
    1 === h.nodeType ? (i = d && d(h), i ? k += i : g.hasOwnProperty(f) ? (k && l.push(k), k = b(h.childNodes, d, e)) : k += 'br' === f ? '\n' : b(h.childNodes, d, e)) : 3 === h.nodeType && (k += a(h.nodeValue));
    return l.push(k),
    l.join(e)
  }
  var c = window.document,
  d = 'character',
  e = new RegExp(String.fromCharCode(160), 'gi'),
  f = 'h1 h2 h3 h4 h5 h6 p pre blockquote address ul ol dir menu li dl div form'.split(' '),
  g = {
  },
  h = 0;
  for (h = 0; h < f.length; h++) g[f[h]] = !0;
  var i = function (a, b, c) {
    var d = this;
    if (!a || !a.contentEditable) throw new Error('First argument must be contentEditable');
    this.elem = a,
    this.emulateTextarea = a.getAttribute('plaintext-only') || b,
    this.emulateTextarea && (this.pasteHandler = function (a) {
      var b = a && a.clipboardData || window.clipboardData;
      b && !b.getData('text') && (a.preventDefault(), a.stopPropagation());
      var c = d.plainTextReformat,
      e = function () {
        c.timeout = null,
        c.call(d)
      };
      c.timeout && clearTimeout(c.timeout),
      c.timeout = setTimeout(e, 0)
    }, a.addEventListener('paste', this.pasteHandler));
    for (var e in c) c.hasOwnProperty(e) && (this[e] = c[e])
  };
  return i.prototype = {
    insertHTML: function (a) {
      if (c.all) {
        var b = c.selection.createRange();
        return b.pasteHTML(a),
        b.collapse(!1),
        b.select()
      }
      return c.execCommand('insertHTML', !1, a)
    },
    insertNode: function (a) {
      var b,
      d,
      e;
      window.getSelection ? (b = window.getSelection(), b.getRangeAt && b.rangeCount && (d = b.getRangeAt(0), d.deleteContents(), d.insertNode(a), d.collapse(!1), b.removeAllRanges(), b.addRange(d))) : c.selection && c.selection.createRange && (d = c.selection.createRange(), e = 3 === a.nodeType ? a.data : a.outerHTML, d.pasteHTML(e), d.collapse(!1))
    },
    getTextNodes: function (a) {
      var b = this.elem;
      a && a.nodeType ? a = [
        a
      ] : a || (a = b.childNodes);
      for (var c, d = [
      ], e = 0; e < a.length; ++e) if (c = a[e]) switch (c.nodeType) {
        case 1:
          d = d.concat(this.getTextNodes(c.childNodes));
          break;
        case 3:
          /^\n\s+/.test(c.nodeValue) || d.push(c)
      }
      return d
    },
    text: function (a) {
      var c,
      d,
      e,
      f = this.elem;
      try {
        d = Array.prototype.slice.call(f.childNodes)
      } catch (g) {
        for (d = [
        ], e = 0; e < f.childNodes.length; ++e) d.push(f.childNodes[e])
      }
      return c = b(d, a, this.emulateTextarea && '\n'),
      c.replace(/^\s+|\s+$/g, '')
    },
    setText: function (a) {
      a = a || '';
      var b,
      d,
      e,
      f = c.createDocumentFragment(),
      g = [
        a
      ],
      h = g && g.length;
      for (b = 0; b < h; b++) d = g[b],
      e = this.createParagraph(d),
      f.appendChild(e);
      if (f.lastChild.appendChild(c.createElement('br')), this.elem.innerHTML = '', this.elem.appendChild(f), 'WebkitAppearance' in c.documentElement.style && window.navigator.userAgent.indexOf('Firefox') === - 1 && window.navigator.userAgent.indexOf('MSIE') === - 1) {
        var i = window.getSelection && window.getSelection();
        i && i.anchorNode === this.elem && i.modify && i.modify('move', 'forward', 'line')
      }
    },
    createParagraph: function (a) {
      var b,
      d,
      e,
      f,
      g,
      h,
      i,
      j = c.createElement('p');
      for (e = a.split(/\r\n|\r|\n/), d = 0, g = e.length; d < g; d++) {
        for (f = e[d], i = this.getHtmlElements(f), b = 0, h = i.length; b < h; b++) j.appendChild(i[b]);
        j.appendChild(c.createElement('br'))
      }
      return j.lastChild && j.removeChild(j.lastChild),
      j
    },
    getHtmlElements: function (a) {
      return [c.createTextNode(a)]
    },
    plainTextReformat: function () {
      if (!(this.elem.getElementsByTagName('p').length <= 1)) {
        this.emulateTextarea = !1;
        var a = this.text();
        this.emulateTextarea = !0,
        this.setText(a)
      }
    },
    removeNode: function (a) {
      var b,
      d,
      e;
      window.getSelection ? (b = a.previousSibling, a.parentNode.removeChild(a), d = window.getSelection(), e = c.createRange(), b && (e.setStart(b, b.length), e.setEnd(b, b.length)), d.addRange(e)) : a.parentNode.removeChild(a)
    },
    selectedTextNode: function () {
      var b,
      e,
      f,
      g,
      h,
      i,
      j,
      k,
      l,
      m = this.elem;
      if (window.getSelection) return b = window.getSelection(),
      b.anchorNode;
      if (c.selection.createRange) {
        for (e = c.selection.createRange().duplicate(); e.moveStart(d, - 1000) === - 1000; );
        var n = e.text;
        for (k = 0; k < m.childNodes.length; ++k) for (f = m.childNodes[k], h = this.getTextNodes(f), l = 0; l < h.length; ++l) if (g = h[l], j = a(g.nodeValue), n.indexOf(j) > - 1) i = g,
        n = n.replace(j, '');
         else if (j.indexOf(n) > - 1) return g;
        return i
      }
    },
    selectedTextNodeOffset: function (b) {
      var e,
      f,
      g;
      if (window.getSelection) {
        var h = window.getSelection();
        h && h.anchorOffset && (g = h.anchorOffset)
      } else if (b && c.selection.createRange) {
        var i = a(b.nodeValue);
        e = c.selection.createRange();
        var j = e.duplicate(),
        k = j.parentElement();
        for (f = 0; 0 !== e.moveStart(d, - 1) && (0 !== i.indexOf(a(e.text)) && k === e.parentElement()); f++) j = e.duplicate(),
        k = j.parentElement();
        g = f
      }
      return isNaN(g) ? 0 : g
    },
    offset: function () {
      function b(d, e) {
        function f(a) {
          i += a[0];
          for (var b = 1; b < a.length; ++b) h.push(i),
          i = a[b]
        }
        'string' != typeof e && (e = '\n\n');
        for (var h = [
        ], i = '', j = 0; j < d.length; ++j) {
          var k = d[j],
          l = k.nodeName.toLowerCase();
          1 === k.nodeType ? g.hasOwnProperty(l) ? (i && (i += e), f(b(k.childNodes, e))) : 'br' === l ? i += '\n' : f(b(k.childNodes, e)) : 3 === k.nodeType && (k === c.anchorNode ? (i += a(k.nodeValue.slice(0, c.anchorOffset)), h.push(i), i = a(k.nodeValue.slice(c.anchorOffset))) : i += a(k.nodeValue))
        }
        return h.push(i),
        h
      }
      var c = window.getSelection();
      if (!c || !c.anchorNode || 3 !== c.anchorNode.nodeType) return 0;
      var d,
      e = this.elem;
      try {
        d = Array.prototype.slice.call(e.childNodes)
      } catch (f) {
        d = [
        ];
        for (var h = 0; h < e.childNodes.length; ++h) d.push(e.childNodes[h])
      }
      var i = b(d, this.emulateTextarea && '\n');
      if (1 === i.length) return 0;
      var j = i[0].length,
      k = i.join(''),
      l = k.match(/\s+$/);
      if (l) {
        var m = l[0].length;
        j = Math.min(j, k.length - m)
      }
      var n = k.match(/^\s+/);
      if (n) {
        var o = n[0].length;
        j -= o
      }
      return j
    },
    selectNodeText: function (b, e, f) {
      var g,
      h,
      i = this.elem;
      if (window.getSelection) return g = window.getSelection(),
      g.removeAllRanges(),
      h = c.createRange(),
      h.setStart(b, e),
      h.setEnd(b, f),
      g.addRange(h),
      g;
      if (c.selection.createRange) {
        h = c.selection.createRange();
        var j = a(b.nodeValue);
        if ('body' === h.parentElement().nodeName.toLowerCase()) {
          for (i.focus(), h = c.selection.createRange(); h.moveStart(d, - 1000) === - 1000; );
          for (; 1000 === h.moveEnd(d, 1000); );
          var k = a(h.text),
          l = k.indexOf(j);
          l > 0 && h.moveStart(d, l + 2),
          h.collapse()
        }
        for (; h.moveStart(d, - 1) === - 1 && 0 !== j.indexOf(a(h.text)); );
        for (; 1 === h.moveEnd(d, 1) && j !== a(h.text); );
        return h.moveStart(d, e),
        h.moveEnd(d, - 1 * (f - e - h.text.length)),
        h.select(),
        h
      }
    }
  },
  i.normalizeSpace = a,
  i
}),
define('core/utils/html/nodeTypes', [
], function () {
  'use strict';
  var a = function (a) {
    return 'p' === a.nodeName.toLowerCase()
  },
  b = function (a) {
    return 'div' === a.nodeName.toLowerCase()
  },
  c = function (a) {
    return '#text' === a.nodeName.toLowerCase()
  },
  d = function (a) {
    return 'br' === a.nodeName.toLowerCase()
  },
  e = function (a) {
    return 'button' === a.nodeName.toLowerCase()
  },
  f = function (a) {
    return 'br' === a.nodeName.toLowerCase() || '#text' === a.nodeName.toLowerCase() && '\n' === a.nodeValue
  },
  g = function (a) {
    return 'p' === a.nodeName.toLowerCase() || 'div' === a.nodeName.toLowerCase()
  },
  h = function (a) {
    return 'span' === a.nodeName.toLowerCase()
  };
  return {
    isP: a,
    isDiv: b,
    isText: c,
    isBr: d,
    isButton: e,
    isNewline: f,
    isPorDiv: g,
    isSpan: h
  }
}),
define('core/CappedStorage', [
  'core/utils/storage'
], function (a) {
  'use strict';
  var b = function (a, b) {
    this.max = a || 10,
    this.queueKey = b || '__queue',
    this.getQueue() || this.setQueue([])
  };
  return b.prototype.set = function (b, c) {
    var d = this.getQueue() || this.setQueue([]);
    d.length === this.max && a.remove(d.shift()),
    a.set(b, c),
    d.push(b),
    this.setQueue(d)
  },
  b.prototype.get = function (b) {
    return a.get(b)
  },
  b.prototype.remove = function (b) {
    a.remove(b);
    for (var c = this.getQueue() || [
    ], d = 0; d < c.length; d++) if (c[d] === b) {
      c.splice(d, 1);
      break
    }
    this.setQueue(c)
  },
  b.prototype.clear = function () {
    a.clear(),
    this.setQueue([])
  },
  b.prototype.getQueue = function () {
    return a.get(this.queueKey)
  },
  b.prototype.setQueue = function (b) {
    return a.set(this.queueKey, b),
    b
  },
  b
}),
define('core/extensions/jquery.autoresize', [
  'jquery',
  'underscore'
], function (a, b) {
  'use strict';
  return a.fn.autoresize = function (c) {
    var d = b.extend({
      extraSpace: 0,
      maxHeight: 1000
    }, c);
    return this.each(function () {
      var c = a(this).css({
        resize: 'none',
        overflow: 'hidden'
      }),
      e = 'true' === String(c[0].contentEditable) ? 'html' : 'val',
      f = 'html' === e ? '<br>' : '\n',
      g = c.height(),
      h = function () {
        var d = {
        };
        b.each(d, function (a, b) {
          d[b] = c.css(b)
        });
        var e = a(c[0].cloneNode(!0));
        return e.removeAttr('id').removeAttr('name').css({
          visibility: 'hidden',
          position: 'absolute',
          top: '-9999px',
          left: '-9999px',
          contentEditable: !1
        }).css(d).attr('tabIndex', '-1'),
        e.insertAfter(c[0]),
        e
      }(),
      i = null,
      j = function () {
        h[0].style.height = 0,
        h[e](c[e]() + f),
        h.scrollTop(h[0].scrollHeight);
        var a = Math.max(h[0].scrollHeight, g) + parseInt(d.extraSpace, 10);
        d.maxHeight && (a >= d.maxHeight ? (c.css('overflow', ''), a = d.maxHeight) : c.css('overflow', 'hidden')),
        i !== a && (i = a, c.height(a), c.trigger && c.trigger('resize'))
      },
      k = b.throttle(j, 500),
      l = function (a) {
        13 === a.keyCode ? j() : k()
      };
      c.bind('keyup', l).bind('paste', j).css('overflow', 'hidden'),
      j()
    })
  },
  a
}),
define('core/views/TextareaView', [
  'underscore',
  'jquery',
  'backbone',
  'core/utils',
  'core/utils/html/nodeTypes',
  'core/CappedStorage',
  'core/extensions/jquery.autoresize'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = c.View.extend({
    events: {
      'keydown  [data-role=editable]': 'handleKeyDown',
      'keyup    [data-role=editable]': 'handleKeyUp',
      'paste    [data-role=editable]': 'handlePaste',
      'focusin  [data-role=editable]': 'handleFocusIn',
      'blur     [data-role=editable]': 'handleBlur'
    },
    initialize: function (b) {
      b = b || {
      },
      this.storageKey = b.storageKey,
      this.value = b.value || this.getDraft() [0],
      this.history = [
        this.value
      ],
      this.historyPosition = 0,
      this.placeholder = b.placeholder,
      this.selectionIndices = {
        start: 0,
        end: 0,
        endElemInd: 0,
        endElemSelectionInd: 0,
        startElemInd: 0,
        startElemSelectionInd: 0
      },
      this.inputFixed = !1,
      this.listenTo(this, 'keychange', a.debounce(this.saveDraft, this.constructor.SAVE_DRAFT_INTERVAL))
    },
    render: function () {
      return this.$input = this.createInput(),
      this.set(this.value),
      this.$el.append(this.$input),
      this.$input.autoresize({
        maxHeight: this.constructor.MAX_TEXTAREA_HEIGHT
      }),
      this
    },
    createInput: function () {
      return b('<textarea>').attr({
        'class': 'textarea',
        placeholder: this.placeholder,
        'data-role': 'editable'
      })
    },
    resize: function () {
      this.$input.trigger('paste', {
        fake: !0
      })
    },
    get: function () {
      return this.$input.val().replace(/^\s+|\s+$/g, '')
    },
    getSelected: function () {
      var a = this.$input[0];
      return 'number' == typeof a.selectionStart ? this.$input.val().substring(a.selectionStart, a.selectionEnd) : ''
    },
    offset: function () {
      var a = this.$input[0],
      b = this.$input.val(),
      c = 'number' == typeof a.selectionStart ? a.selectionStart : 0,
      d = b.match(/\s+$/);
      if (d) {
        var e = d[0].length;
        c = Math.min(c, b.length - e)
      }
      var f = b.match(/^\s+/);
      if (f) {
        var g = f[0].length;
        c = Math.max(c - g, 0)
      }
      return c
    },
    insertAtCursor: function (a) {
      this.focus();
      var b = this.get(),
      c = this.offset(),
      e = d.insertWithWhitespace(b, c, a),
      f = this.$input[0];
      if (this.set(e), f.setSelectionRange) {
        var g = e.indexOf(a, c) + a.length + 1;
        f.setSelectionRange(g, g)
      }
    },
    insertAroundSelection: function (a, b) {
      this.focus();
      var c,
      d,
      e = this.$input[0];
      'number' == typeof e.selectionStart ? (c = e.selectionStart, d = e.selectionEnd) : c = d = 0;
      var f = this.get(),
      g = f.substring(0, c) + a + f.substring(c, d) + b + f.substring(d);
      this.set(g),
      e.setSelectionRange && e.setSelectionRange(c + a.length, d + a.length)
    },
    set: function (a) {
      this.$input.val(a)
    },
    clear: function () {
      this.set('')
    },
    focus: function () {
      this.$input.focus()
    },
    handleKeyDown: function (a) {
      this.trigger('keydown', a)
    },
    handleKeyUp: function (a) {
      this.trigger('keychange', a)
    },
    handlePaste: function (a, b) {
      b = b || {
      },
      this.trigger(b.fake ? 'paste' : 'paste keychange'),
      this.$input.trigger('resize')
    },
    handleFocusIn: function () {
      this.fixInputStructure(),
      this.trigger('focus')
    },
    handleBlur: function () {
      this.trigger('blur')
    },
    saveDraft: function () {
      if (this.storageKey) return b.trim(this.get()) ? void this.constructor.storage.set(this.storageKey, this.toJSON()) : void this.removeDraft()
    },
    toJSON: function () {
      return [this.get(),
      b.now()]
    },
    getDraft: function () {
      var a = [
        ''
      ];
      if (!this.storageKey) return a;
      var c = this.constructor.storage.get(this.storageKey);
      if (!c) return a;
      if (a = c, !a.length) return [''];
      var d = b.now() - a[1] >= this.constructor.DRAFT_MAX_AGE;
      return d ? (this.removeDraft(), [
        ''
      ]) : a
    },
    removeDraft: function () {
      this.storageKey && this.constructor.storage.remove(this.storageKey)
    },
    fixInputStructure: function () {
      var a,
      b,
      c,
      f,
      g,
      h,
      i,
      j = !1,
      k = !1,
      l = window.document,
      m = this.$input[0];
      if (m.type && 'textarea' === m.type);
       else if (d.browser.isChrome()) 0 === m.childNodes.length ? (b = m.appendChild(l.createElement('p')), b.appendChild(l.createTextNode('\n')), j = !0) : (a = m.childNodes[0], a.childNodes.forEach(function (b) {
        e.isBr(b) && a.replaceChild(l.createTextNode('\n'), b)
      }));
       else if (d.browser.isIE()) {
        if (0 === m.childNodes.length) c = l.createElement('p'),
        c.appendChild(l.createTextNode('')),
        m.appendChild(c),
        j = !0;
         else for (g = m.childNodes.length, i = 0; i < g; i++) if (e.isP(m.childNodes[i])) if (f = m.childNodes[i].childNodes.length, 0 === f) m.childNodes[i].appendChild(l.createTextNode('')),
        1 === g && (j = !0);
         else if (1 === f) e.isBr(m.childNodes[i].childNodes[0]) && (m.childNodes[i].replaceChild(l.createTextNode(''), m.childNodes[i].childNodes[0]), 1 === g && (j = !0));
         else for (; f > 0; ) h = m.childNodes[i].childNodes[0],
        1 === f && e.isBr(h) ? (m.childNodes[i].replaceChild(l.createTextNode(''), h), f -= 1) : 2 === f && e.isBr(h) && e.isText(m.childNodes[i].childNodes[1]) && this.inputFixed ? (c = l.createElement('p'), c.appendChild(l.createTextNode('')), m.insertBefore(c, m.childNodes[i]), i += 1, g += 1, m.childNodes[i].removeChild(h), f -= 2, this.selectionIndices = {
          startElemInd: i,
          endElemInd: i,
          startElemSelectionInd: 0,
          endElemSelectionInd: 0
        }, k = !0) : 2 === f && e.isText(h) && e.isBr(m.childNodes[i].childNodes[1]) ? (this.inputFixed && (c = l.createElement('p'), c.appendChild(l.createTextNode('')), i === g - 1 ? m.appendChild(c) : m.insertBefore(c, m.childNodes[i + 1]), g += 1, this.selectionIndices = {
          startElemInd: i + 1,
          endElemInd: i + 1,
          startElemSelectionInd: 0,
          endElemSelectionInd: 0
        }, k = !0), m.childNodes[i].removeChild(m.childNodes[i].childNodes[1]), f -= 2) : f > 2 && e.isText(h) && e.isBr(m.childNodes[i].childNodes[1]) ? (c = l.createElement('p'), c.appendChild(l.createTextNode(h.nodeValue)), m.insertBefore(c, m.childNodes[i]), i += 1, g += 1, m.childNodes[i].removeChild(m.childNodes[i].childNodes[1]), m.childNodes[i].removeChild(h), f -= 2) : f -= 1
      } else if (d.browser.isFirefox()) {
        if (1 === m.childNodes.length && e.isP(m.childNodes[0]) && m.childNodes[0].childNodes.length > 2) {
          for (f = m.childNodes[0].childNodes.length, i = 0; i < f; i++) h = m.childNodes[0].childNodes[i],
          e.isText(h) ? (c = l.createElement('p'), c.appendChild(l.createTextNode(h.nodeValue)), i < f - 1 && e.isBr(m.childNodes[0].childNodes[i + 1]) && (i += 1)) : e.isBr(h) && (c = l.createElement('p'), c.appendChild(l.createElement('br'))),
          m.appendChild(c);
          m.removeChild(m.childNodes[0])
        } else 1 === m.childNodes.length && e.isBr(m.childNodes[0]) ? (m.removeChild(m.childNodes[0]), c = l.createElement('p'), c.appendChild(l.createElement('br')), m.appendChild(c)) : 0 === m.childNodes.length && (c = l.createElement('p'), c.appendChild(l.createElement('br')), m.appendChild(c), j = !0);
        for (i = 0; i < m.childNodes.length; i++) {
          var n = m.childNodes[i];
          e.isP(n) && 1 === n.childNodes.length && e.isBr(n.childNodes[0]) ? n.insertBefore(l.createTextNode(''), n.childNodes[0]) : e.isDiv(n) && (c = l.createElement('p'), 1 === n.childNodes.length && e.isBr(n.childNodes[0]) ? (c.appendChild(l.createTextNode('')), c.appendChild(l.createElement('br'))) : 2 === n.childNodes.length && e.isText(n.childNodes[0]) && n.childNodes[0].nodeValue.length > 0 && e.isBr(n.childNodes[1]) && c.appendChild(l.createTextNode(n.childNodes[0].nodeValue)), m.replaceChild(c, n))
        }
      } else if (d.browser.isSafari() || d.browser.isEdge()) if (0 !== m.childNodes.length && e.isP(m.childNodes[0])) {
        for (a = m.childNodes[0], f = a.childNodes.length, i = 0; i < f; i += 1) e.isBr(a.childNodes[i]) && (0 === i || e.isBr(a.childNodes[i - 1])) && (a.insertBefore(l.createTextNode(''), a.childNodes[i]), i === f - 1 && (j = !0));
        for (i = 0; i < f - 1; i += 1) e.isText(a.childNodes[i]) && '' === a.childNodes[i].nodeValue && e.isText(a.childNodes[i + 1]) && (a.removeChild(a.childNodes[i]), i -= 1, f -= 1)
      } else {
        for (c = l.createElement('p'), c.appendChild(l.createTextNode('')), c.appendChild(l.createElement('br')); m.firstChild; ) m.removeChild(m.firstChild);
        m.appendChild(c),
        j = !0
      } else if (d.browser.isOpera()) if (0 === m.childNodes.length) c = l.createElement('p'),
      c.appendChild(l.createTextNode('\n')),
      m.appendChild(c),
      j = !0;
       else for (a = m.childNodes[0], i = 0; i < a.childNodes.length; i++) e.isBr(a.childNodes[i]) && a.replaceChild(l.createTextNode('\n'), a.childNodes[i]);
      this.inputFixed = !0,
      k ? this.selectText() : j && this.focusEndOfText()
    },
    focusEndOfText: function () {
      var a,
      b = this.$input[0],
      c = 0,
      f = 0,
      g = 0,
      h = 0;
      d.browser.isChrome() || d.browser.isOpera() ? (a = b.childNodes[0], c = f = a.childNodes.length - 1, g = h = a.childNodes[c].nodeValue.length) : d.browser.isSafari() || d.browser.isEdge() ? (a = b.childNodes[0], c = f = e.isText(a.childNodes[a.childNodes.length - 1]) ? a.childNodes.length - 1 : a.childNodes.length - 2, g = h = a.childNodes[c].nodeValue.length) : (d.browser.isFirefox() || d.browser.isIE()) && (c = f = b.childNodes.length - 1, g = b.childNodes[c].childNodes[0].nodeValue.length, h = g),
      this.selectionIndices = {
        startElemInd: c,
        startElemSelectionInd: g,
        endElemInd: f,
        endElemSelectionInd: h
      },
      this.selectText()
    },
    getWhichChildIndex: function (a, b) {
      for (var c = 0; c < a.childNodes.length; c++) if (a.childNodes[c] === b) return c;
      return - 1
    },
    getNodeLength: function (a) {
      return e.isBr(a) ? 1 : a.nodeValue.length
    },
    placeholderSetSelection: function () {
      var a,
      b,
      c = window.getSelection();
      this.$input[0].type && 'textarea' === this.$input[0].type ? (a = this.$input[0].selectionStart, b = this.$input[0].selectionEnd) : 'DIV' === c.anchorNode.tagName ? (a = 0, b = this.get().length) : 'P' === c.anchorNode.tagName ? a = b = this.get().length : (a = Math.min(c.focusOffset, c.anchorOffset), b = Math.max(c.focusOffset, c.anchorOffset)),
      this.selectionIndices = {
        start: a,
        end: b,
        endElemInd: 0,
        endElemSelectionInd: 0,
        startElemInd: 0,
        startElemSelectionInd: 0
      }
    },
    setSelection: function () {
      var a,
      b,
      c,
      f,
      g,
      h,
      i;
      this.fixInputStructure();
      var j = this.$input[0],
      k = !1,
      l = window.getSelection();
      if (j.type && 'textarea' === j.type) b = j.selectionStart,
      c = j.selectionEnd;
       else if (l.rangeCount) {
        var m = l.getRangeAt(0);
        if (d.browser.isChrome()) {
          for (a = j.childNodes[0], b = f = 0; a.childNodes[f] && a.childNodes[f] !== m.startContainer; ) e.isSpan(a.childNodes[f]) || (b += this.getNodeLength(a.childNodes[f])),
          f += 1;
          if (h = m.startOffset, b += m.startOffset, m.collapsed) g = f,
          c = b,
          i = h;
           else if (m.startContainer === m.endContainer) g = f,
          i = m.endOffset,
          c = b + (m.endOffset - m.startOffset);
           else {
            for (g = f, c = b - m.startOffset; a.childNodes[g] && a.childNodes[g] !== m.endContainer; ) e.isSpan(a.childNodes[g]) || (c += this.getNodeLength(a.childNodes[g])),
            g += 1;
            e.isNewline(a.childNodes[g]) ? (i = this.getNodeLength(a.childNodes[g - 1]), g -= 1) : (c += m.endOffset, i = m.endOffset)
          }
        } else if (d.browser.isIE()) e.isDiv(m.startContainer) && e.isDiv(m.endContainer) && m.collapsed ? (f = j.childNodes.length - 1, g = j.childNodes.length - 1, h = j.childNodes[f].childNodes[0].nodeValue.length, i = j.childNodes[g].childNodes[0].nodeValue.length, k = !0) : e.isDiv(m.startContainer) && e.isDiv(m.endContainer) && !m.collapsed ? (f = m.startOffset, g = m.endOffset - 1, h = 0, i = j.childNodes[g].childNodes[0].nodeValue.length) : e.isText(m.startContainer) && e.isText(m.endContainer) ? (f = this.getWhichChildIndex(j, m.startContainer.parentNode), g = this.getWhichChildIndex(j, m.endContainer.parentNode), h = m.startOffset, i = m.endOffset) : e.isText(m.startContainer) && e.isDiv(m.endContainer) ? (f = this.getWhichChildIndex(j, m.startContainer.parentNode), g = m.endOffset - 1, h = m.startOffset, i = j.childNodes[g].childNodes[0].nodeValue.length) : (f = 0, g = 0, h = 0, i = 0);
         else if (d.browser.isFirefox()) e.isDiv(m.startContainer) && e.isDiv(m.endContainer) && m.startContainer === j && m.endContainer === j && m.collapsed ? (f = j.childNodes.length - 1, g = j.childNodes.length - 1, h = j.childNodes[f].childNodes[0].nodeValue.length, i = j.childNodes[g].childNodes[0].nodeValue.length, k = !0) : e.isDiv(m.startContainer) && e.isDiv(m.endContainer) && m.startContainer === j && m.endContainer === j && !m.collapsed ? (f = m.startOffset, g = m.endOffset - 1, h = 0, i = j.childNodes[g].childNodes[0].nodeValue.length) : e.isDiv(m.startContainer) && e.isText(m.endContainer) && m.startContainer === j ? (f = 0, g = this.getWhichChildIndex(j, m.endContainer.parentNode), h = 0, i = m.endOffset) : e.isDiv(m.startContainer) && e.isP(m.endContainer) && m.startContainer === j ? (f = 0, g = this.getWhichChildIndex(j, m.endContainer), h = 0, i = j.childNodes[g].childNodes[0].nodeValue.length) : e.isText(m.startContainer) && e.isText(m.endContainer) ? (f = this.getWhichChildIndex(j, m.startContainer.parentNode), g = this.getWhichChildIndex(j, m.endContainer.parentNode), h = m.startOffset, i = m.endOffset) : e.isText(m.startContainer) && e.isP(m.endContainer) ? (f = this.getWhichChildIndex(j, m.startContainer.parentNode), g = this.getWhichChildIndex(j, m.endContainer), h = m.startOffset, i = f === g ? j.childNodes[g].childNodes[0].nodeValue.length : 0) : e.isP(m.startContainer) && e.isText(m.endContainer) ? (f = this.getWhichChildIndex(j, m.startContainer), g = this.getWhichChildIndex(j, m.endContainer.parentNode), h = 0, i = m.endOffset) : e.isP(m.startContainer) && e.isP(m.endContainer) ? (f = this.getWhichChildIndex(j, m.startContainer), g = this.getWhichChildIndex(j, m.endContainer), h = 0, i = j.childNodes[g].childNodes[0].nodeValue.length) : (f = 0, g = 0, h = 0, i = 0);
         else if (d.browser.isSafari() || d.browser.isEdge()) a = j.childNodes[0],
        e.isText(m.startContainer) ? (f = this.getWhichChildIndex(a, m.startContainer), h = m.startOffset) : e.isP(m.startContainer) ? (f = m.startOffset < a.childNodes.length && e.isText(a.childNodes[m.startOffset]) ? m.collapsed ? m.startOffset : m.startOffset - 2 : m.startOffset - 1, h = a.childNodes[f].nodeValue.length) : e.isDiv(m.startContainer) && (m.collapsed ? (f = e.isText(a.childNodes[a.childNodes.length - 1]) ? a.childNodes.length - 1 : a.childNodes.length - 2, h = a.childNodes[f].nodeValue.length) : (f = 0, h = 0)),
        e.isText(m.endContainer) ? (g = this.getWhichChildIndex(a, m.endContainer), i = m.endOffset) : e.isP(m.endContainer) ? (g = m.endOffset < a.childNodes.length && e.isText(a.childNodes[m.endOffset]) ? m.collapsed ? m.endOffset : m.endOffset - 2 : m.endOffset - 1 < a.childNodes.length && e.isText(a.childNodes[m.endOffset - 1]) ? m.endOffset - 1 : m.endOffset - 1 < a.childNodes.length && e.isBr(a.childNodes[m.endOffset - 1]) ? m.endOffset - 2 : a.childNodes.length - 2, i = a.childNodes[g].nodeValue.length) : e.isDiv(m.endContainer) && (g = e.isText(a.childNodes[a.childNodes.length - 1]) ? a.childNodes.length - 1 : a.childNodes.length - 2, i = a.childNodes[f].nodeValue.length);
         else {
          if (!d.browser.isOpera()) return this.placeholderSetSelection();
          a = j.childNodes[0],
          f = this.getWhichChildIndex(a, m.startContainer),
          g = this.getWhichChildIndex(a, m.endContainer),
          h = m.startOffset,
          i = m.endOffset
        }
      } else this.focusEndOfText();
      this.selectionIndices = {
        start: b,
        end: c,
        startElemInd: f,
        startElemSelectionInd: h,
        endElemInd: g,
        endElemSelectionInd: i
      },
      k && this.selectText()
    },
    addTagTextarea: function (a) {
      var b,
      c,
      d,
      e = this.selectionIndices.start,
      f = this.selectionIndices.end,
      g = this.selectionIndices.startElemInd,
      h = this.selectionIndices.endElemInd,
      i = this.selectionIndices.startElemSelectionInd,
      j = this.selectionIndices.endElemSelectionInd;
      switch (a) {
        case 'a':
          b = '<a href="#">',
          c = '</a>';
          break;
        default:
          b = '<' + a + '>',
          c = '</' + a + '>'
      }
      var k = this.get(),
      l = k.slice(0, e),
      m = k.slice(e, f),
      n = k.slice(f),
      o = new RegExp('<' + a + '[^<>]*>'),
      p = new RegExp(c + '$'),
      q = m.match(o),
      r = m.match(p);
      q && r && 0 === q.index && r.index === f - e - c.length ? (d = m.replace(o, '').replace(p, ''), f -= q[0].length + r[0].length, j -= q[0].length + r[0].length) : (d = b + m + c, f += b.length + c.length, j += b.length + c.length),
      this.selectionIndices = {
        start: e,
        end: f,
        startElemInd: g,
        endElemInd: h,
        startElemSelectionInd: i,
        endElemSelectionInd: j
      },
      this.set(l + d + n),
      this.debouncedSaveHistory(),
      this.selectText()
    },
    addTag: function (a) {
      var b,
      c,
      e,
      f,
      g,
      h,
      i,
      j,
      k,
      l,
      m,
      n,
      o,
      p = window.document,
      q = this.$input[0],
      r = this.selectionIndices.start,
      s = this.selectionIndices.end,
      t = this.selectionIndices.startElemInd,
      u = this.selectionIndices.endElemInd,
      v = this.selectionIndices.startElemSelectionInd,
      w = this.selectionIndices.endElemSelectionInd;
      switch (a) {
        case 'a':
          b = '<a href="#">',
          c = '</a>';
          break;
        default:
          b = '<' + a + '>',
          c = '</' + a + '>'
      }
      var x = new RegExp('<' + a + '[^<>]*>'),
      y = new RegExp(c + '$');
      if (q.type && 'textarea' === q.type) return this.addTagTextarea(a);
      if (d.browser.isChrome() || d.browser.isSafari() || d.browser.isOpera() || d.browser.isEdge()) k = q.childNodes[0],
      l = k.childNodes[t],
      m = k.childNodes[u],
      n = l.nodeValue,
      o = m.nodeValue,
      f = n.slice(v).match(x),
      g = o.slice(0, w).match(y),
      f && g && 0 === f.index && g.index === w - c.length ? (t === u ? (h = n.slice(0, v) + n.slice(v, w).replace(x, '').replace(y, '') + n.slice(w), k.replaceChild(p.createTextNode(h), l), w -= f[0].length + g[0].length) : (i = n.slice(0, v) + n.slice(v).replace(x, ''), j = o.slice(0, w).replace(y, '') + o.slice(w), k.replaceChild(p.createTextNode(i), l), k.replaceChild(p.createTextNode(j), m), w -= g[0].length), s -= f[0].length + g[0].length) : (t === u ? (h = n.slice(0, v) + b + n.slice(v, w) + c + n.slice(w), k.replaceChild(p.createTextNode(h), l), w += b.length + c.length) : (i = n.slice(0, v) + b + n.slice(v), j = o.slice(0, w) + c + o.slice(w), k.replaceChild(p.createTextNode(i), l), k.replaceChild(p.createTextNode(j), m), w += c.length), s += b.length + c.length);
       else if (d.browser.isFirefox() || d.browser.isIE()) {
        var z = q.childNodes[this.selectionIndices.startElemInd],
        A = q.childNodes[this.selectionIndices.endElemInd];
        l = z.childNodes[0],
        m = A.childNodes[0],
        n = l.nodeValue,
        o = m.nodeValue,
        f = n.slice(v).match(x),
        g = o.slice(0, w).match(y),
        f && g && 0 === f.index && g.index === w - c.length ? (t === u ? (h = n.slice(0, v) + n.slice(v, w).replace(x, '').replace(y, '') + n.slice(w), z.replaceChild(p.createTextNode(h), l), w -= f[0].length + g[0].length) : (i = n.slice(0, v) + n.slice(v).replace(x, ''), j = o.slice(0, w).replace(y, '') + o.slice(w), z.replaceChild(p.createTextNode(i), l), A.replaceChild(p.createTextNode(j), m), w -= g[0].length), s -= f[0].length + g[0].length) : (t === u ? (h = n.slice(0, v) + b + n.slice(v, w) + c + n.slice(w), z.replaceChild(p.createTextNode(h), l), w += b.length + c.length) : (i = n.slice(0, v) + b + n.slice(v), j = o.slice(0, w) + c + o.slice(w), z.replaceChild(p.createTextNode(i), l), A.replaceChild(p.createTextNode(j), m), w += c.length), s += b.length + c.length)
      } else {
        var B = this.get(),
        C = B.slice(0, r),
        D = B.slice(r, s),
        E = B.slice(s);
        f = D.match(x),
        g = D.match(y),
        f && g && 0 === f.index && g.index === s - r - c.length ? (e = D.replace(x, '').replace(y, ''), s = s - f[0].length - g[0].length) : (e = b + D + c, s = s + b.length + c.length),
        this.set(C + e + E)
      }
      this.debouncedSaveHistory(),
      this.selectionIndices = {
        start: r,
        end: s,
        startElemInd: t,
        startElemSelectionInd: v,
        endElemInd: u,
        endElemSelectionInd: w
      },
      this.selectText()
    },
    selectText: function () {
      var a,
      b,
      c,
      e,
      f = this.$input[0],
      g = window.document.createRange(),
      h = this.selectionIndices.start,
      i = this.selectionIndices.end,
      j = f.childNodes[0],
      k = window.getSelection();
      if (f.type && 'textarea' === f.type) f.setSelectionRange(h, i);
       else if (d.browser.isChrome() || d.browser.isSafari() || d.browser.isOpera() || d.browser.isEdge()) a = j.childNodes[this.selectionIndices.startElemInd],
      b = this.selectionIndices.startElemSelectionInd,
      c = j.childNodes[this.selectionIndices.endElemInd],
      e = this.selectionIndices.endElemSelectionInd,
      g.setStart(a, b),
      g.setEnd(c, e),
      k.removeAllRanges(),
      k.addRange(g);
       else if (d.browser.isFirefox() || d.browser.isIE()) a = f.childNodes[this.selectionIndices.startElemInd].childNodes[0],
      b = this.selectionIndices.startElemSelectionInd,
      c = f.childNodes[this.selectionIndices.endElemInd].childNodes[0],
      e = this.selectionIndices.endElemSelectionInd,
      g.setStart(a, b),
      g.setEnd(c, e),
      (!d.browser.isIE() || k.rangeCount > 0 && k.getRangeAt(0).getClientRects().length > 0) && k.removeAllRanges(),
      k.addRange(g);
       else {
        var l = j.childNodes[0];
        g.setStart(l, h),
        g.setEnd(l, i),
        k.removeAllRanges(),
        k.addRange(g)
      }(d.browser.isEdge() || f.type && 'textarea' === f.type) && this.focus()
    },
    debouncedSaveHistory: a.debounce(function () {
      var a = this.toJSON() [0];
      a !== this.history[this.historyPosition] && (this.historyPosition !== this.history.length - 1 && (this.history = this.history.slice(0, this.historyPosition + 1)), this.history.push(a), this.historyPosition += 1)
    }, 200),
    undoTextarea: function () {
      this.historyPosition > 0 && (this.historyPosition -= 1, this.set(this.history[this.historyPosition]), this.fixInputStructure(), this.focusEndOfText())
    },
    redoTextarea: function () {
      this.historyPosition < this.history.length - 1 && (this.historyPosition += 1, this.set(this.history[this.historyPosition]), this.fixInputStructure(), this.focusEndOfText())
    }
  }, {
    MAX_TEXTAREA_HEIGHT: 350,
    SAVE_DRAFT_INTERVAL: 500,
    DRAFT_MAX_AGE: 86400000,
    storage: new f(5, 'drafts.queue')
  });
  return g
}),
define('core/views/ContentEditableView', [
  'jquery',
  'underscore',
  'core/editable',
  'core/views/TextareaView'
], function (a, b, c, d) {
  'use strict';
  var e = window.document,
  f = d,
  g = f.prototype,
  h = f.extend({
    events: b.defaults({
      'focusout [data-role=editable]': 'handleFocusOut',
      'click .placeholder': 'handlePlaceholderClick'
    }, g.events),
    initialize: function () {
      g.initialize.apply(this, arguments),
      this.hasFocus = !1,
      this._selectionRange = null
    },
    saveSelection: function () {
      var a = window.getSelection();
      this._selectionRange = a && a.rangeCount && a.getRangeAt(0)
    },
    restoreSelection: function () {
      if (this._selectionRange) {
        var a = window.getSelection();
        a.removeAllRanges(),
        a.addRange(this._selectionRange),
        this._selectionRange = null
      }
    },
    render: function () {
      return this.$input = this.createInput(),
      this.$el.append(this.$input),
      this.set(this.value),
      this.renderPlaceholder(),
      this
    },
    createInput: function () {
      var b = a('<div>').attr({
        'class': 'textarea',
        tabIndex: 0,
        role: 'textbox',
        'aria-multiline': 'true',
        contenteditable: 'PLAINTEXT-ONLY',
        'data-role': 'editable'
      }).css({
        overflow: 'auto',
        'word-wrap': 'break-word',
        'max-height': this.constructor.MAX_TEXTAREA_HEIGHT + 'px'
      }),
      d = b[0];
      return 'plaintext-only' !== d.contentEditable && (d.contentEditable = 'true'),
      this.content = new c(d, (!0)),
      b
    },
    renderPlaceholder: function () {
      var b = this.placeholder;
      b && (this.$input.attr('aria-label', b), this.$placeholder = a('<span class="placeholder">' + b + '</span>'), this.updatePlaceholderDisplay())
    },
    updatePlaceholderDisplay: function () {
      this.$placeholder && (this.hasFocus || this.content.text() ? this.$placeholder.remove() : this.$el.prepend(this.$placeholder))
    },
    handlePlaceholderClick: function () {
      this.$input.focus()
    },
    handleFocusIn: function () {
      g.handleFocusIn.call(this),
      this.restoreSelection(),
      this.hasFocus = !0,
      this.updatePlaceholderDisplay()
    },
    handleFocusOut: function () {
      this.saveSelection(),
      this.hasFocus = !1,
      this.updatePlaceholderDisplay()
    },
    get: function () {
      return this.content.text()
    },
    getSelected: function () {
      return this.hasFocus && window.getSelection ? window.getSelection().toString() : this._selectionRange ? this._selectionRange.toString() : ''
    },
    offset: function () {
      return this.content.offset()
    },
    set: function (a) {
      this.content.setText(a),
      this.resize(),
      this.updatePlaceholderDisplay()
    },
    insertAtCursor: function (a) {
      this.focus();
      var b = ' ' + a + ' ';
      e.queryCommandSupported && e.queryCommandSupported('insertText') && e.execCommand('insertText', !1, b) || this.content.insertNode(e.createTextNode(b))
    },
    clear: function () {
      g.clear.call(this),
      b.defer(function (a) {
        a.$input.blur()
      }, this)
    },
    insertAroundSelection: function (a, b) {
      this.focus();
      var c = window.getSelection();
      if (c.rangeCount) {
        var d = c.getRangeAt(0),
        f = d.cloneRange();
        f.collapse(!1);
        var g = e.createTextNode(b);
        f.insertNode(g);
        var h = d.cloneRange();
        h.collapse(!0);
        var i = e.createTextNode(a);
        h.insertNode(i),
        d.setStart(i, a.length),
        d.setEnd(g, 0),
        c.removeAllRanges(),
        c.addRange(d)
      }
    }
  });
  return h
}),
define('core/views/PostReplyView', [
  'jquery',
  'underscore',
  'backbone',
  'modernizr',
  'moment',
  'core/UniqueModel',
  'core/mixins/withAlert',
  'core/mixins/withUploadForm',
  'core/models/Post',
  'core/models/User',
  'core/strings',
  'core/time',
  'core/utils',
  'core/switches',
  'core/views/ContentEditableView',
  'core/views/TextareaView',
  'core/utils/threadRatingsHelpers'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q) {
  'use strict';
  var r = k.get,
  s = m.preventDefaultHandler,
  t = c.View.extend({
    tagName: 'form',
    className: 'reply',
    events: {
      submit: 'submitForm'
    },
    postboxAlertSelector: '[role=postbox-alert]',
    initialize: function (a) {
      this.session = a.session,
      this.parent = a.parent,
      this.thread = a.thread,
      this.isRefreshEnabled = n.isFeatureActive('embed_refresh', {
        forum: this.thread && this.thread.forum && this.thread.forum.id
      }),
      this.isRefreshV2Enabled = this.isRefreshEnabled && n.isFeatureActive('embed_refresh_v2', {
        forum: this.thread && this.thread.forum && this.thread.forum.id
      }),
      this.$el.addClass(this.isRefreshEnabled ? 'form-refresh' : ''),
      this.$el.addClass(this.isRefreshV2Enabled ? 'form-refresh-v2' : ''),
      this.gifPickerEnabled = Boolean(this.thread) && Boolean(this.thread.forum) && Boolean(this.thread.forum.get('settings').gifPickerEnabled),
      this.post = this.makePostInstance(),
      this.setAlertSelector('[role=alert]'),
      this.shouldShowEmailAlertInForm = a.shouldShowEmailAlertInForm,
      this.parentView = a.parentView,
      this._isHidden = !1,
      this.parent && (t.open[this.parent.cid] = this),
      this.mediaembedEnabled = this.thread.forum.get('settings').mediaembedEnabled,
      this.allowUploads = this.mediaembedEnabled && this.uploadSupported,
      this.listenTo(this.session, 'change:id', this.redraw)
    },
    redraw: function () {
      var b = this.$el.hasClass('expanded'),
      c = this.el,
      d = this.$el.find('textarea').val();
      this.render(),
      this.$el.find('textarea').val(d),
      b && this.$el.addClass('expanded'),
      0 !== a(c).parent().length && c.parentNode.replaceChild(this.el, c)
    },
    getPlaceholderText: function () {
      return this.thread.get('posts') ? this.thread.forum.get('commentsPlaceholderTextPopulated') || r('Join the discussion…') : this.thread.forum.get('commentsPlaceholderTextEmpty') || r('Start the discussion…')
    },
    getTemplateData: function () {
      return {
        user: this.session.toJSON(),
        displayMediaPreviews: this.mediaembedEnabled || this.gifPickerEnabled,
        displayMediaUploadButton: this.allowUploads,
        gifPickerEnabled: this.gifPickerEnabled
      }
    },
    render: function () {
      return this.$el.html(this.template(this.getTemplateData())),
      this.initTextEditor(null, !0),
      this.parent ? this.$el.addClass('expanded') : this.$el.removeClass('expanded'),
      this.initTextarea(),
      this.initMediaViews({
        mediaembedEnabled: this.mediaembedEnabled,
        gifPickerEnabled: this.gifPickerEnabled,
        allowUploads: this.allowUploads,
        textarea: this.textarea
      }),
      this.constructor.mustVerifyEmailToPost(this.session.user, this.thread.forum) && this._alertMustVerify(this.shouldShowEmailAlertInForm),
      this._isHidden && this.$el.addClass('hidden'),
      this.initStarRatings(),
      this
    },
    createTextarea: function () {
      var a = {
        placeholder: this.getPlaceholderText(),
        storageKey: this.post.storageKey()
      };
      return this.constructor.canUseContentEditable ? new this.constructor.ContentEditableView(a) : new this.constructor.TextareaView(a)
    },
    initTextarea: function () {
      var a = this.textarea = this.createTextarea();
      this.$('[data-role=textarea]').prepend(a.render().el),
      this.listenTo(a, {
        keydown: function (a) {
          !a || !a.ctrlKey && !a.metaKey || 13 !== a.keyCode && 10 !== a.keyCode || this.submitForm(),
          this.session.get('banned') && this.alertBannedError()
        },
        focus: function () {
          this.$el.hasClass('expanded') || this.$el.addClass('expanded')
        }
      })
    },
    resize: function () {
      this.textarea.resize()
    },
    focus: function () {
      this.textarea.focus()
    },
    clear: function () {
      var a = this;
      a.textarea.clear(),
      a.clearMediaPreviews(),
      a.$el.removeClass('expanded'),
      b.delay(function () {
        a.resize()
      }, 200),
      a.parent && a.hide()
    },
    restore: function (a) {
      var c = this;
      c.textarea.set(a.get('raw_message')),
      c.textarea.handleFocusIn(),
      b.delay(function () {
        c.resize()
      }, 200),
      c.parent && c.show()
    },
    _alertMustVerify: function (a) {
      var b = this.emailVerifyAlertTemplate({
        user: this.session.user.toJSON(),
        forumName: this.thread.forum.get('name'),
        forumId: this.thread.forum.id
      });
      this.alert(b, {
        safe: !0,
        type: a ? 'error' : 'warn',
        target: a ? this.postboxAlertSelector : null
      })
    },
    submitForm: s(function () {
      return this.dismissAlert(),
      this.initiatePost()
    }),
    makePostInstance: function () {
      return new f(this.constructor.Post, {
        thread: this.thread.id,
        depth: this.parent ? this.parent.get('depth') + 1 : 0,
        parent: this.parent ? this.parent.id : null
      })
    },
    getPostParams: function () {
      var a = {
        raw_message: this.textarea.get(),
        rating: this.rating
      };
      b.extend(a, this.getAuthorParams());
      var c = this.mediaUploadsView;
      return c && (a.media = c.rich.invoke('toJSON')),
      a
    },
    getAuthorParams: function () {
      return {
        author_id: this.session.user.id
      }
    },
    initiatePost: function () {
      this.createPost(this.getPostParams())
    },
    createPost: function (c) {
      var d = this,
      e = this.post;
      this.dismissAlert();
      var f = a.now();
      if (!this.shouldAbortCreatePost(e, c)) return this.listenTo(e, {
        error: this._onCreateError,
        sync: b.partial(this._onCreateSync, f)
      }),
      e.save(c, {
        success: function () {
          b.isNumber(d.rating) && q.isThreadModelRatingsEnabled(d.thread) && (d.thread.set('userRating', d.rating), b.delay(b.bind(d.thread.fetchRatings, d.thread), 500))
        }
      }),
      this.attachAuthorToPost(e, c),
      e.created = !0,
      this.addPostToThread(e),
      this.clear(),
      e
    },
    shouldAbortCreatePost: function (a, b) {
      return this.isUploadInProgress() ? (this.alert(r('Please wait until your images finish uploading.'), {
        type: 'error',
        target: this.postboxAlertSelector
      }), !0) : !a.set(b, {
        validate: !0
      }) && (this.alert(a.validationError, {
        type: 'error',
        target: this.postboxAlertSelector
      }), !0)
    },
    alertBannedError: function () {
      var a = {
        blocker: this.session.user.get('isOnGlobalBlacklist') ? 'Disqus' : this.thread.forum.get('name')
      };
      if (this.session.get('banExpires')) {
        var b = e(l.assureTzOffset(this.session.get('banExpires')), l.ISO_8601);
        if (b.isBefore(e())) return;
        a.expirationRelative = b.fromNow()
      }
      this.alert(this.blacklistErrorMessageTemplate(a), {
        type: 'error',
        target: this.postboxAlertSelector,
        safe: !0
      })
    },
    _onCreateError: function (a, c) {
      12 === c.code && /not have permission to post on this thread/.test(c.response) ? this.alertBannedError() : 12 === c.code && /not have permission via SSO to post on this thread/.test(c.response) ? this.thread.forum.get('name') ? this.alert(k.interpolate(r('Please sign into %(forumName)s to comment.'), {
        forumName: this.thread.forum.get('name')
      }), {
        type: 'error',
        target: this.postboxAlertSelector
      }) : this.alert(r('Please sign into this site to comment'), {
        type: 'error',
        target: this.postboxAlertSelector
      }) : 12 === c.code && /verify/.test(c.response) ? this._alertMustVerify(!0) : b.isString(c.response) ? this.alert(c.response, {
        type: 'error',
        target: this.postboxAlertSelector
      }) : this.alert(r('Oops! We\'re having trouble posting your comment. Check your internet connection and try again.'), {
        type: 'error',
        target: this.postboxAlertSelector
      }),
      this.thread.posts.remove(a),
      this.restore(a)
    },
    _onCreateSync: function (b, c) {
      this.textarea.removeDraft(),
      this.thread.trigger('create', c),
      this.trigger('uiCallback:postCreated', c, {
        duration: a.now() - b
      }),
      this.parentView && this.parentView.toggleReplyLink(!1),
      this.stopListening(c, 'error', this._onCreateError),
      this.stopListening(c, 'sync', this._onCreateSync),
      this.post = this.makePostInstance(),
      this.trigger('domReflow')
    },
    attachAuthorToPost: function (a, b) {
      this.session.isLoggedIn() ? a.author = this.session.user : a.author = new f(this.constructor.User, {
        name: b.author_name,
        email: b.author_email
      })
    },
    addPostToThread: function (a) {
      this.thread.posts.add(a)
    },
    remove: function () {
      this.parent && delete t.open[this.parent.cid],
      c.View.prototype.remove.call(this)
    },
    toggle: function () {
      this.isOpen() ? this.hide() : this.show()
    },
    show: function () {
      var a = this;
      a._isHidden = !1,
      a.$el.removeClass('hidden'),
      a.trigger('show')
    },
    hide: function () {
      var a = this;
      a._isHidden = !0,
      a.dismissAlert(),
      a.$el.addClass('hidden'),
      a.trigger('hide')
    },
    isOpen: function () {
      return !this._isHidden
    }
  }, {
    mustVerifyEmailToPost: function (a, b) {
      if (a.isAnonymous()) return !1;
      var c = b.get('settings').mustVerifyEmail,
      d = a.get('isVerified');
      return c && !d
    },
    canUseContentEditable: d.contenteditable && !m.isMobileUserAgent() && !(window.opera && window.opera.version),
    TextareaView: p,
    ContentEditableView: o,
    User: j,
    Post: i,
    open: {
    }
  });
  return g.call(t.prototype),
  h.call(t.prototype),
  t
}),
define('constants/gifPickerConstants', [
], function () {
  'use strict';
  return {
    GIF_PICKER_CATEGORIES: {
      LEFT: [
        {
          title: 'Trending',
          gifUrl: 'https://media.giphy.com/media/WsV5AoDeKePw4/200w_d.gif',
          width: 200,
          height: 113
        },
        {
          title: 'OMG',
          gifUrl: 'https://media.giphy.com/media/5VKbvrjxpVJCM/200w_d.gif',
          width: 200,
          height: 160
        },
        {
          title: 'No',
          gifUrl: 'https://media.giphy.com/media/z5WtAAaFpnIgU/200w_d.gif',
          width: 200,
          height: 150
        },
        {
          title: 'Slow clap',
          gifUrl: 'https://media.giphy.com/media/58FMN3DmsmYta2m0aB/200w_d.gif',
          width: 200,
          height: 150
        },
        {
          title: 'Love',
          gifUrl: 'https://media.giphy.com/media/Xf7g5BjIIMun8fR14k/200w_d.gif',
          width: 200,
          height: 199
        },
        {
          title: 'Eye roll',
          gifUrl: 'https://media.giphy.com/media/sbwjM9VRh0mLm/200w_d.gif',
          width: 200,
          height: 142
        }
      ],
      RIGHT: [
        {
          title: 'Applause',
          gifUrl: 'https://media.giphy.com/media/fnK0jeA8vIh2QLq3IZ/200w_d.gif',
          width: 200,
          height: 201
        },
        {
          title: 'Agree',
          gifUrl: 'https://media.giphy.com/media/3og0ILzGlzG26yNINq/200w_d.gif',
          width: 200,
          height: 166
        },
        {
          title: 'Ok',
          gifUrl: 'https://media.giphy.com/media/mgqefqwSbToPe/200w_d.gif',
          width: 200,
          height: 150
        },
        {
          title: 'Thumbs up',
          gifUrl: 'https://media.giphy.com/media/j5QcmXoFWl4Q0/200w_d.gif',
          width: 200,
          height: 125
        },
        {
          title: 'Thumbs down',
          gifUrl: 'https://media.giphy.com/media/KUrgyFtn9bQNW/200w_d.gif',
          width: 200,
          height: 128
        },
        {
          title: 'Thank you',
          gifUrl: 'https://media.giphy.com/media/QAsBwSjx9zVKoGp9nr/200w_d.gif',
          width: 200,
          height: 144
        }
      ]
    }
  }
}),
define('templates/lounge/gifsView', [
  'react'
], function (a) {
  'use strict';
  var b = function (b) {
    return a.createElement('div', {
      className: 'gif-picker__gifs-view'
    }, a.createElement('div', {
      className: 'gif-picker__gifs-view-left'
    }, b.gifsLeft ? b.gifsLeft.map(function (b) {
      return a.createElement('div', {
        key: b.id,
        className: 'gif-picker__image',
        'data-action': 'gif-picker-image',
        'data-tag': b['default'].url,
        tabIndex: '0',
        'aria-label': b.title
      }, a.createElement('img', {
        src: b.fixedWidth200.url,
        title: b.title,
        style: {
          height: parseInt(b.fixedWidth200.height, 10) + 'px',
          width: parseInt(b.fixedWidth200.width, 10) + 'px'
        }
      }))
    }) : null), a.createElement('div', {
      className: 'gif-picker__gifs-view-right'
    }, b.gifsRight ? b.gifsRight.map(function (b) {
      return a.createElement('div', {
        key: b.fixedWidth200.url,
        className: 'gif-picker__image',
        'data-action': 'gif-picker-image',
        'data-tag': b['default'].url
      }, a.createElement('img', {
        src: b.fixedWidth200.url,
        title: b.title,
        style: {
          height: parseInt(b.fixedWidth200.height, 10) + 'px',
          width: parseInt(b.fixedWidth200.width, 10) + 'px'
        }
      }))
    }) : null))
  };
  return b
}),
define('templates/lounge/gifsCategory', [
  'react',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.get,
  d = function (d) {
    return a.createElement('div', {
      className: 'gif-picker__gifs-view gif-picker__categories'
    }, a.createElement('div', {
      className: 'gif-picker__gifs-view-left'
    }, d.categoriesLeft ? d.categoriesLeft.map(function (d) {
      return a.createElement('div', {
        key: d.title,
        className: 'gif-picker__image',
        'data-action': 'gif-picker-category',
        'data-tag': d.title,
        tabIndex: '0',
        'aria-label': 'Collection of animated images in the category of ' + d.title
      }, a.createElement('img', {
        src: d.gifUrl,
        className: 'gif-picker__category-gif',
        style: {
          height: d.height + 'px',
          width: d.width + 'px'
        }
      }), a.createElement('div', {
        className: 'gif-picker__category-overlay'
      }), a.createElement('div', {
        className: 'gif-picker__category-title align align--middle align--center'
      }, a.createElement('b', null, b.interpolate(c('%(title)s'), {
        title: d.title
      }))))
    }) : null), a.createElement('div', {
      className: 'gif-picker__gifs-view-right'
    }, d.categoriesRight ? d.categoriesRight.map(function (d) {
      return a.createElement('div', {
        key: d.title,
        className: 'gif-picker__image',
        'data-action': 'gif-picker-category',
        'data-tag': d.title,
        tabIndex: '0',
        'aria-label': 'Collection of animated images in the category of ' + d.title
      }, a.createElement('img', {
        src: d.gifUrl,
        className: 'gif-picker__category-gif',
        style: {
          height: d.height + 'px',
          width: d.width + 'px'
        }
      }), a.createElement('div', {
        className: 'gif-picker__category-overlay'
      }), a.createElement('div', {
        className: 'gif-picker__category-title align align--middle align--center'
      }, a.createElement('b', null, b.interpolate(c('%(title)s'), {
        title: d.title
      }))))
    }) : null))
  };
  return d
}),
define('templates/lounge/gifsPopout', [
  'react',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.get,
  d = function () {
    return a.createElement('div', {
      className: 'gif-picker__popout'
    }, a.createElement('textarea', {
      className: 'gif-picker__search-bar',
      placeholder: c('Search for gifs'),
      'data-role': 'gif-picker-input',
      wrap: 'soft',
      rows: '1'
    }), a.createElement('div', {
      className: 'gif-picker__gifs-view-container',
      'data-role': 'gifs-view-container'
    }), a.createElement('img', {
      className: 'gif-picker__powered-by',
      src: 'https://c.disquscdn.com/next/embed/assets/img/powered-by-giphy.b72f56fe31b44adb55a65c343c691d63.png'
    }))
  };
  return d
}),
define('lounge/mixins/asGifPicker', [
  'jquery',
  'underscore',
  'core/bus',
  'core/strings',
  'constants/gifPickerConstants',
  'templates/lounge/gifsView',
  'templates/lounge/gifsCategory',
  'templates/lounge/gifsPopout',
  'common/collections'
], function (a, b, c, d, e, f, g, h, i) {
  'use strict';
  var j = d.get,
  k = {
    events: {
      'mousedown  [data-role=gif-picker-toggle]': 'toggleGifPicker',
      'keydown  [data-role=gif-picker-toggle]': 'toggleGifPicker',
      'mousedown  [data-action=gif-picker-image]': 'pickGif',
      'keydown  [data-action=gif-picker-image]': 'pickGif',
      'mousedown  [data-action=gif-picker-category]': 'pickGifCategory',
      'keydown  [data-action=gif-picker-category]': 'pickGifCategory',
      'keydown    [data-role=gif-picker-input]': 'onKeydown',
      'keyup      [data-role=gif-picker-input]': 'onKeyup'
    },
    initialize: function (a, b) {
      b = b || {
      },
      a.call(this, b)
    },
    initGifPicker: function () {
      this.gifPicker = this.$('.gif-picker'),
      this.toggle = this.$('[data-role=gif-picker-toggle]'),
      this.gifsCollection = new i.GifObjectsCollection,
      this.popoutContainer = this.$('[data-role=gif-picker-popout-container]'),
      this.categories = e.GIF_PICKER_CATEGORIES,
      this.gifPickerQuery = null,
      this.rescrollToTop = 0,
      this.popoutTemplate = h({
      }),
      this.popoutContainer.html(this.popoutTemplate),
      this.renderCategoriesView(),
      this.revealGifPicker(),
      this.listenTo(this.gifsCollection, 'sync', this.syncGifsCollection)
    },
    fetchGifObjectsCollection: function (a) {
      this.gifsCollection.fetch({
        forum: this.thread.forum.id,
        query: a
      })
    },
    syncGifsCollection: function () {
      this.renderGifsView(),
      this.positionGifPickerPopout(),
      this.gifsView[0].scrollTo({
        top: this.rescrollToTop
      })
    },
    dismissGifPicker: function (b) {
      this.gifPicker.length && !this.gifPicker[0].contains(b.target) && (this.hideGifPicker(), a(window).off('mousedown', this.dismissGifPicker))
    },
    toggleGifPicker: function (a) {
      if ('keydown' === a.type) {
        var b = 13,
        c = 32;
        if (a.keyCode !== b && a.keyCode !== c) return;
        a.preventDefault()
      }
      this.popoutTemplate ? this.popoutContainer.hasClass('hidden') ? this.revealGifPicker() : this.hideGifPicker() : this.initGifPicker()
    },
    pickGif: function (a) {
      if ('keydown' === a.type) {
        if (32 !== a.keyCode && 13 !== a.keyCode) return;
        a.preventDefault()
      }
      this.textarea.set(this.textarea.get() + ' ' + a.currentTarget.getAttribute('data-tag')),
      b.delay(b.bind(function () {
        this.hideGifPicker()
      }, this), 500)
    },
    pickGifCategory: function (a) {
      if ('keydown' === a.type) {
        if (32 !== a.keyCode && 13 !== a.keyCode) return;
        a.preventDefault()
      }
      var b = a.currentTarget.getAttribute('data-tag');
      b = 'Trending' === b ? '' : d.interpolate(j('%(category)s'), {
        category: b
      }),
      this.gifPickerQuery = b,
      this.rescrollToTop = 0,
      this.fetchGifObjectsCollection(b),
      this.gifsInput.val(b)
    },
    revealGifPicker: function () {
      this.popoutContainer.removeClass('hidden'),
      a(window).on('mousedown', b.bind(this.dismissGifPicker, this)),
      this.positionGifPickerPopout(),
      this.triggerClick()
    },
    hideGifPicker: function () {
      this.popoutContainer.addClass('hidden')
    },
    onKeydown: function (a) {
      13 === a.keyCode && a.preventDefault()
    },
    onKeyup: function (a) {
      a.target.value !== this.gifPickerQuery && (this.gifPickerQuery = '' === a.target.value ? null : a.target.value, this.rescrollToTop = 0, this.debouncedSearch())
    },
    debouncedSearch: b.debounce(function () {
      this.gifPickerQuery || '' === this.gifPickerQuery ? this.fetchGifObjectsCollection(this.gifPickerQuery) : this.renderCategoriesView()
    }, 250),
    renderCategoriesView: function () {
      this.gifsCollection.reset(),
      this.gifsContainer = this.$('[data-role=gifs-view-container]'),
      this.gifsInput = this.$('[data-role=gif-picker-input]'),
      this.gifCategories ? (this.gifsContainer.html(this.gifCategories), this.gifsView = this.gifCategories) : (this.gifsContainer.html(g({
        categoriesLeft: this.categories.LEFT,
        categoriesRight: this.categories.RIGHT
      })), this.gifCategories = this.gifsView = this.gifsContainer.children())
    },
    renderGifsView: function () {
      var a = this.gifsCollection && this.gifsCollection.toJSON(),
      c = [
      ],
      d = [
      ],
      e = 0,
      g = 0;
      b.forEach(a, function (a) {
        var b = parseInt(a.fixedWidth200.height, 10) + 10;
        g >= e ? (c.push(a), e += b) : (d.push(a), g += b)
      }),
      this.gifsContainer.html(f({
        gifsLeft: c,
        gifsRight: d
      })),
      this.gifsView = this.gifsContainer.children()
    },
    positionGifPickerPopout: function () {
      var b = this,
      c = 450,
      d = 800,
      e = 0,
      f = 0,
      g = d,
      h = !1,
      i = 873,
      j = 236,
      k = 73,
      l = 20,
      m = this.toggle.outerWidth() + 2,
      n = this.popoutContainer.height() + l,
      o = this.toggle.outerHeight(),
      p = this.toggle.offset().left,
      q = this.toggle.offset().top + o - 2,
      r = a(window.document).height(),
      s = a(window.document).width();
      if (n > r || n < i && n < r && r < i ? (g = Math.min(r, i) - k, e = - q + o, f = m, h = !0) : r > i && r - q < i ? (e = r - q - Math.max(n, i) + o, f = m, h = !0) : r - q > i && (h = !0, e = o, f = Math.min(0, s - (this.toggle.offset().left + j))), s < c) {
        this.popoutContainer.find('.gif-picker__popout').css({
          padding: '4px 4px 4px'
        });
        var t = this.popoutContainer.outerWidth() - this.gifsView.outerWidth(),
        u = s - (p + t + f + 10),
        v = u / 2;
        this.popoutContainer.find('.gif-picker__image > img').each(function () {
          a(this).css({
            width: v,
            height: v * a(this).height() / a(this).width()
          })
        }),
        h = !0
      }
      h && (this.gifsView.css('maxHeight', g), this.popoutContainer.css({
        top: e,
        left: f
      })),
      this.lastScrollTop = 0,
      this.gifsView[0].onscroll = function (a) {
        var c = a.target.scrollHeight - a.target.scrollTop - g,
        d = a.target.scrollTop > b.lastScrollTop;
        b.lastScrollTop = a.target.scrollTop,
        b.rescrollToTop = a.target.scrollTop,
        d && null !== b.gifPickerQuery && c < Math.min(1000, 0.5 * g) && b.throttledOnScrollToBottom(a.target.scrollTop)
      }
    },
    throttledOnScrollToBottom: b.throttle(function () {
      this.debouncedSearch()
    }, 500, {
      trailing: !1
    }),
    triggerClick: function () {
      c.trigger('uiAction:gifsClickButton')
    },
    triggerScroll: function () {
      c.trigger('uiAction:gifsScrollToBottom')
    }
  };
  return function () {
    this.events = b.defaults({
    }, this.events, k.events),
    this.initialize = b.wrap(this.initialize, k.initialize),
    b.extend(this, b.pick(k, [
      'initGifPicker',
      'fetchGifObjectsCollection',
      'syncGifsCollection',
      'toggleGifPicker',
      'dismissGifPicker',
      'pickGif',
      'pickGifCategory',
      'revealGifPicker',
      'hideGifPicker',
      'onKeydown',
      'onKeyup',
      'debouncedSearch',
      'renderCategoriesView',
      'renderGifsView',
      'positionGifPickerPopout',
      'throttledOnScrollToBottom',
      'triggerClick',
      'triggerScroll'
    ]))
  }
}),
define('core/constants/textEditorConstants', [
  'exports'
], function (a) {
  'use strict';
  a.EDITOR_BUTTONS_ORDER = [
    'b',
    'spoiler',
    'i',
    's',
    'u',
    'a',
    'code',
    'blockquote'
  ],
  a.GIF_PICKER_BUTTON = 'gif-picker',
  a.MEDIA_UPLOADER_BUTTON = 'media-uploader'
}),
define('lounge/mixins/asTextEditor', [
  'jquery',
  'underscore',
  'core/constants/textEditorConstants'
], function (a, b, c) {
  'use strict';
  var d = {
    events: {
      'mousedown [data-action=text-editor-tag]': 'textEditorTag',
      'keydown [data-action=text-editor-tag]': 'textEditorTag',
      'mouseup   [data-action=text-editor-buttons]': 'textEditorForceSelectText',
      'mousedown [data-role=editable]': 'textEditorMouseDown',
      'keyup     [data-role=editable]': 'textEditorKeyUp',
      'keydown   [data-role=editable]': 'textEditorKeyDown'
    },
    initialize: function (c, d) {
      d = d || {
      },
      c.call(this, d),
      this.textEditorMouseUp = b.bind(this.textEditorMouseUp, this),
      this.editBox = this.el && this.el.className && this.el.className.indexOf('edit') > - 1,
      a(window).on('resize', b.bind(this.initTextEditor, this)),
      this.mostRecentPostBoxWidth = null
    },
    textEditorTag: function (a) {
      if ('keydown' === a.type) {
        var b = 13,
        c = 32;
        return void (a.keyCode !== b && a.keyCode !== c || (a.preventDefault(), this.textarea.addTag(a.currentTarget.getAttribute('data-tag'))))
      }
      this.textarea.addTag(a.currentTarget.getAttribute('data-tag'))
    },
    textEditorForceSelectText: function () {
      this.textarea.selectText()
    },
    textEditorMouseDown: function () {
      a(window).on('mouseup', this.textEditorMouseUp)
    },
    textEditorMouseUp: function () {
      a(window).off('mouseup', this.textEditorMouseUp),
      setTimeout(b.bind(this.textarea.setSelection, this.textarea), 200)
    },
    textEditorKeyUp: function () {
      this.textarea.setSelection()
    },
    textEditorKeyDown: function (a) {
      !a.ctrlKey && !a.metaKey || 'z' !== a.key && 'y' !== a.key && 'Z' !== a.key && 'Y' !== a.key ? this.textarea.debouncedSaveHistory() : (a.preventDefault(), this.textarea.debouncedSaveHistory(), 'y' === a.key || 'Y' === a.key || a.shiftKey && ('z' === a.key || 'Z' === a.key) ? this.textarea.redoTextarea() : 'z' !== a.key && 'Z' !== a.key || this.textarea.undoTextarea())
    },
    getTextEditorTemplateData: function () {
      var a = [
      ],
      b = !this.editBox && this.gifPickerEnabled,
      d = !this.editBox && this.allowUploads,
      e = this.$('.post-actions').outerWidth() || 0;
      this.mostRecentPostBoxWidth = e;
      var f = this.$('.wysiwyg__item').outerWidth(!0) || 0,
      g = (this.$('.edit-button').outerWidth() || 0) + (this.$('.post-action__cancel').outerWidth(!0) || 0),
      h = this.$('.full-size-button').outerWidth() || 0,
      i = this.$('.small-size-button').outerWidth() || 0,
      j = b || d ? this.$('.vertical-separator').outerWidth() || 30 : 0,
      k = c.EDITOR_BUTTONS_ORDER.length + (!this.editBox && this.gifPickerEnabled ? 1 : 0) + (!this.editBox && this.allowUploads ? 1 : 0),
      l = h + j + (k + 1) * f >= e,
      m = l ? i : h,
      n = this.editBox ? g : m,
      o = Math.floor((e - n - j) / f) || 0;
      return b && o > a.length && (a = a.concat([c.GIF_PICKER_BUTTON])),
      o > a.length && (a = a.concat(c.EDITOR_BUTTONS_ORDER.slice(0, 1))),
      d && o > a.length && (a = a.concat([c.MEDIA_UPLOADER_BUTTON])),
      o > a.length && (a = a.concat(c.EDITOR_BUTTONS_ORDER.slice(1, o - a.length))),
      {
        user: this.session.toJSON(),
        displayMediaPreviews: this.mediaembedEnabled || this.gifPickerEnabled,
        displayMediaUploadButton: this.allowUploads,
        gifPickerEnabled: this.gifPickerEnabled,
        useSmallPostButton: l,
        buttonsToShow: a,
        edit: this.editBox,
        forum: this.thread.forum.id
      }
    },
    initTextEditor: function (a, b) {
      var c = this.$('.post-actions').outerWidth();
      if (!(a && 'resize' === a.type && this.mostRecentPostBoxWidth && c && c === this.mostRecentPostBoxWidth)) return this.$('.text-editor-container').html(this.textEditorTemplate(this.getTextEditorTemplateData())),
      b && null === c ? void this.initTextEditor(null, !1) : void (!this.editBox && this.textarea && this.initMediaViews({
        mediaembedEnabled: this.mediaembedEnabled,
        gifPickerEnabled: this.gifPickerEnabled,
        allowUploads: this.allowUploads,
        textarea: this.textarea
      }))
    }
  };
  return function () {
    this.events = b.defaults({
    }, this.events, d.events),
    this.initialize = b.wrap(this.initialize, d.initialize),
    b.extend(this, b.pick(d, [
      'textEditorTag',
      'textEditorForceSelectText',
      'textEditorMouseDown',
      'textEditorMouseUp',
      'textEditorKeyUp',
      'textEditorKeyDown',
      'getTextEditorTemplateData',
      'initTextEditor'
    ]))
  }
}),
define('lounge/mixins/asTextEditorV2', [
  'underscore',
  'core/strings',
  'core/switches'
], function (a, b, c) {
  'use strict';
  var d = b.translations,
  e = [
  ];
  Object.defineProperties(window, {
    _loadTextEditor: {
      writable: !0
    },
    loadTextEditor: {
      get: function () {
        return this._loadTextEditor
      },
      set: function (a) {
        for (this._loadTextEditor = a; e.length; ) {
          var b = e.shift();
          b()
        }
      }
    }
  });
  var f = {
    initialize: function (a, b) {
      a.call(this, b),
      this.isEmbedV2Enabled = c.isFeatureActive('embed_v2', {
        forum: this.thread.forum.id
      })
    },
    loadEditorV2: function (b) {
      var c = this.$el.find('[data-role=textarea]') [0],
      f = a.extend({
        forum: this.thread.forum.id,
        thread: this.thread.id,
        lang: this.thread.forum.get('language'),
        translations: d,
        setAlert: a.partial(this.alert, a, a, !0).bind(this),
        clearAlert: this.alert.bind(this, '', null, !0),
        key: this.post && this.post.cid
      }, b),
      g = function () {
        var a = this.editorV2Root && this.editorV2Root._internalRoot && this.editorV2Root._internalRoot.containerInfo === c;
        this.editorV2Root && !a ? (this.editorV2Root.unmount(), this.editorV2Root = window.loadTextEditor(c, f)) : this.editorV2Root = window.loadTextEditor(c, f, this.editorV2Root)
      };
      window.loadTextEditor ? g.call(this) : e.push(g.bind(this))
    },
    resize: function (a) {
      this.isEmbedV2Enabled || a.call(this)
    },
    focus: function (a) {
      this.isEmbedV2Enabled || a.call(this)
    },
    initTextEditor: function (a) {
      this.isEmbedV2Enabled || a.call(this)
    },
    remove: function (a) {
      this.editorV2Root && (this.editorV2Root.unmount(), this.editorV2Root = null),
      a.call(this)
    },
    alert: function (a, b, c, d) {
      c = c || {
      };
      var e = '[role=postbox-alert]' === this._alertSelector || '[role=postbox-alert]' === c.target;
      if (!this.isEmbedV2Enabled || !d && !e) return a.call(this, b, c);
      var f = this.getEditorProps ? this.getEditorProps() : {
      };
      f.alert = {
        message: b,
        type: c.type,
        safe: c.safe
      },
      this.loadEditorV2(f)
    }
  };
  return function () {
    this.initialize = a.wrap(this.initialize, f.initialize),
    this.resize = a.wrap(this.resize, f.resize),
    this.focus = a.wrap(this.focus, f.focus),
    this.remove = a.wrap(this.remove, f.remove),
    this.alert = a.wrap(this.alert, f.alert),
    this.initTextEditor = a.wrap(this.initTextEditor, f.initTextEditor),
    a.extend(this, a.pick(f, [
      'loadEditorV2'
    ]))
  }
}),
define('templates/lounge/rate', [
  'react',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.gettext,
  d = function (b) {
    return a.createElement('div', {
      className: 'ratings-rate'
    }, a.createElement('div', {
      className: 'ratings-text'
    }, c(b.submitted ? 'You rated this' : 'Rate and comment')), a.createElement('div', {
      className: 'ratings-stars'
    }, a.createElement('div', {
      className: 'stars animation-star-container'
    }, a.createElement('div', {
      className: 'animation-star'
    }, a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'))), b.selected ? a.createElement('div', {
      className: 'stars selection-stars',
      style: {
        width: 20 * b.selectedValue + '%'
      }
    }, a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★')) : null, a.createElement('div', {
      className: 'stars voting-stars'
    }, a.createElement('div', {
      className: 'rating-star',
      'data-action': 'rateThread',
      'data-tag': '1',
      tabIndex: '0'
    }, '★'), a.createElement('div', {
      className: 'rating-star',
      'data-action': 'rateThread',
      'data-tag': '2',
      tabIndex: '0'
    }, '★'), a.createElement('div', {
      className: 'rating-star',
      'data-action': 'rateThread',
      'data-tag': '3',
      tabIndex: '0'
    }, '★'), a.createElement('div', {
      className: 'rating-star',
      'data-action': 'rateThread',
      'data-tag': '4',
      tabIndex: '0'
    }, '★'), a.createElement('div', {
      className: 'rating-star',
      'data-action': 'rateThread',
      'data-tag': '5',
      tabIndex: '0'
    }, '★')), a.createElement('div', {
      className: 'stars base-stars'
    }, a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'))))
  };
  return d
}),
define('lounge/mixins/withStarRatings', [
  'underscore',
  'core/strings',
  'core/utils/threadRatingsHelpers',
  'templates/lounge/rate'
], function (a, b, c, d) {
  'use strict';
  var e = b.gettext,
  f = 13,
  g = {
    events: {
      'click     [data-action=rateThread]': 'rateThread',
      'keydown   [data-action=rateThread]': function (a) {
        a.keyCode && a.keyCode === f && (a.preventDefault(), this.rateThread(a))
      },
      'mouseover [data-action=rateThread]': 'highlightRating',
      'mouseout  [data-action=rateThread]': 'unhighlightRating',
      'focusin   [data-action=rateThread]': 'highlightRating',
      'focusout  [data-action=rateThread]': 'unhighlightRating'
    },
    initialize: function (a, b) {
      b = b || {
      },
      a.call(this, b),
      this.rateTemplate = d,
      this.rating = null,
      this.ratingsEnabled = !this.post.get('parent') && c.isThreadModelRatingsEnabled(this.thread),
      this.listenTo(this.thread, 'change', function () {
        var a = this.thread.changedAttributes();
        return void 0 !== a.ratingsEnabled ? (this.ratingsEnabled = !this.post.get('parent') && c.isThreadModelRatingsEnabled(this.thread), this.initStarRatings(this.thread.get('userRating'))) : a.userRating && a.userRating !== this.rating ? this.initStarRatings(a.userRating) : void 0
      }),
      this.listenToOnce(this.thread.forum, 'change:features', function () {
        return this.ratingsEnabled = !this.post.get('parent') && c.isThreadModelRatingsEnabled(this.thread),
        this.initStarRatings(this.thread.get('userRating'))
      })
    },
    initStarRatings: function (b) {
      if (!this.ratingsEnabled) {
        var c = this.$('[data-role=ratings-container]');
        return void (c.length && this.$('[data-role=ratings-container]').empty())
      }
      return this.rating = a.isNumber(b) ? b : this.thread.get('userRating'),
      this.$('[data-role=ratings-container]').html(this.rateTemplate({
        selected: a.isNumber(this.rating),
        submitted: Boolean(this.thread.get('userRating')),
        selectedValue: this.rating
      }))
    },
    rateThread: function (a) {
      var b = this,
      c = parseInt(a.currentTarget.getAttribute('data-tag'), 10);
      Promise.resolve(this.initStarRatings(c)).then(function () {
        var a = b.$('.animation-star-container'),
        d = b.$('.animation-star-container > .animation-star');
        d.children().slice(c).remove(),
        a.addClass('animate-star'),
        d.css({
          position: 'absolute',
          left: '0',
          width: 20 * c + '%'
        }),
        setTimeout(function () {
          a.removeClass('animate-star')
        }, 500)
      }).then(function () {
        return b.textarea.focus()
      }).then(function () {
        return !b.postEditMode && b.alert(e('Please post a comment to submit your rating.'), {
          type: 'info',
          target: b.postboxAlertSelector
        })
      })
    },
    highlightRating: function (a) {
      this.$(a.currentTarget).addClass('selected-star'),
      this.$(a.currentTarget).prevAll().addClass('selected-star')
    },
    unhighlightRating: function (a) {
      this.$(a.currentTarget).removeClass('selected-star'),
      this.$(a.currentTarget).prevAll().removeClass('selected-star')
    }
  };
  return function () {
    this.events = a.defaults({
    }, this.events, g.events),
    this.initialize = a.wrap(this.initialize, g.initialize),
    a.extend(this, a.pick(g, [
      'initStarRatings',
      'rateThread',
      'highlightRating',
      'unhighlightRating'
    ]))
  }
}),
define('lounge/mixins/post-reply', [
  'underscore',
  'common/models',
  'lounge/common'
], function (a, b, c) {
  'use strict';
  var d = {
    initialize: function () {
      this.canBindTypingHandlers() && this.bindTypingHandlers()
    },
    canBindTypingHandlers: function () {
      return this.parent && c.getLounge().isRealtimeEnabled() && this.session && this.thread && this.thread.forum
    },
    bindTypingHandlers: function () {
      return a.map([[this,
      'show',
      this.typingStart],
      [
        this,
        'hide',
        this.typingStop
      ]], function (a) {
        return this.listenTo.apply(this, a),
        a
      }, this)
    },
    syncTyping: function (a) {
      this.typingUser && (void 0 !== a && this.typingUser.set('typing', a), this.typingUser.sync())
    },
    typingStart: function () {
      var a = this.parent;
      this.typingUser || (this.typingUser = b.TypingUser.make({
        user: this.session.user.id,
        post: a.id,
        thread: this.thread.id,
        forum: this.thread.forum.id
      }), a.usersTyping.add(this.typingUser)),
      this.syncTyping(!0)
    },
    typingStop: function () {
      this.syncTyping(!1)
    }
  },
  e = function (b) {
    var c = b.initialize,
    e = b.remove;
    a.extend(b, d),
    b.initialize = function () {
      c.apply(this, arguments),
      d.initialize.call(this)
    },
    b.remove = function () {
      return this.parent && this.typingStop(),
      e.call(this)
    }
  };
  return {
    asRealtimeTyping: e
  }
}),
define('templates/lounge/suggestions', [
  'react',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.gettext,
  d = function () {
    return a.createElement('ul', {
      className: 'user-mention__list',
      id: 'user-mention-list'
    }, a.createElement('li', {
      className: 'header user-mention__header'
    }, a.createElement('h5', null, c('in this conversation'))))
  };
  return d
}),
define('templates/lounge/suggestedUser', [
  'react',
  'core/strings',
  'core/utils/object/get'
], function (a, b, c) {
  'use strict';
  var d = b.gettext,
  e = function (b) {
    return a.createElement('li', {
      className: 'user-mention__item',
      'data-cid': b.cid || ''
    }, a.createElement('img', {
      src: c(b.avatar, [
        'cache'
      ], ''),
      className: 'avatar',
      alt: d('Avatar')
    }), a.createElement('span', null, b.name || b.username || null))
  };
  return e
}),
define('lounge/views/posts/SuggestionView', [
  'jquery',
  'underscore',
  'backbone',
  'templates/lounge/suggestions',
  'templates/lounge/suggestedUser'
], function (a, b, c, d, e) {
  'use strict';
  var f = c.View.extend({
    events: {
      'click li': 'handleClick'
    },
    initialize: function (a) {
      this.active = !1,
      this.userSuggestions = a.userSuggestions,
      this.scrollListener = null,
      this.userHtmlCache = {
      },
      this.userSuggestions && this.userSuggestions.userCollection && this.listenTo(this.userSuggestions.userCollection, 'sync', this.syncUserCollection)
    },
    syncUserCollection: function () {
      this.active && (this.userSuggestions.userCollection.models.length ? this.renderUsers(this.userSuggestions.userCollection.models) : this.clear())
    },
    suggest: function (a, b) {
      return a ? (this.userSuggestions.find(a, b), this.currTerms = a, this.active = !0, void this.$el.show()) : void this.clear()
    },
    throttledSuggestMore: b.throttle(function () {
      this.suggest(this.currTerms, !0)
    }, 200, {
      trailing: !1
    }),
    render: function () {
      var a = this;
      return this.$el.html(d()),
      this.active || this.$el.hide(),
      this.scrollListener || (this.scrollListener = this.$el.find('#user-mention-list') [0].onscroll = function (b) {
        b.target.scrollHeight - b.target.scrollTop === b.target.clientHeight && a.throttledSuggestMore()
      }),
      this
    },
    renderUsers: function (c) {
      var d = b.reduce(c, function (b, c) {
        var d = this.userHtmlCache[c.cid];
        return void 0 === d && (this.userHtmlCache[c.cid] = d = a(this.renderSingleUser(c))),
        b.appendChild(d[0]),
        b
      }, window.document.createDocumentFragment(), this);
      this.$('.header').siblings().remove().end().after(d).siblings().removeClass('active').first().addClass('active')
    },
    renderSingleUser: function (a) {
      var b = a.toJSON();
      return b.cid = a.cid,
      e(b)
    },
    clear: function () {
      this.active = !1,
      this.$el.hide()
    },
    handleClick: function (b) {
      var c = a(b.currentTarget);
      this.select(c.attr('data-cid'))
    },
    select: function (a) {
      this.active && (a || (a = this.$el.find('.active').attr('data-cid')), this.trigger('select', a), this.clear())
    },
    move: function (a) {
      if (this.active) {
        var b = this.$el.find('.active'),
        c = 'up' === a ? 'prev' : 'next',
        d = b[c]();
        d.length && d.attr('data-cid') && (b.removeClass('active'), d.addClass('active'))
      }
    }
  }, {
    MAX_SUGGESTIONS: 5
  });
  return f
}),
define('lounge/views/posts/ContentEditableView', [
  'jquery',
  'underscore',
  'core/editable',
  'core/views/ContentEditableView',
  'common/collections',
  'lounge/common',
  'lounge/views/posts/SuggestionView'
], function (a, b, c, d, e, f, g) {
  'use strict';
  var h = window.document,
  i = d,
  j = i.prototype,
  k = i.extend({
    initialize: function (a) {
      j.initialize.call(this, a),
      a = a || {
      },
      this.userSuggestions = a.userSuggestions,
      this.mentionsCache = new e.UserCollection,
      this.restoreMentionedUsers(),
      this.suggestions = new g({
        userSuggestions: this.userSuggestions,
        mentions: this.mentionsCache
      }),
      this.listenTo(this.suggestions, 'select', this.insertMention),
      this.reset(),
      this.$input = null
    },
    restoreMentionedUsers: function () {
      var a = this.getDraft() [2];
      a && !b.isEmpty(a) && this.userSuggestions.addRemote(new e.UserCollection(a))
    },
    reset: function () {
      this.anchorNode = null,
      this.anchorOffset = null,
      this.anchorLength = 0,
      this.suggestions.clear()
    },
    render: function () {
      return d.prototype.render.call(this),
      this.$el.append(this.suggestions.render().el),
      this
    },
    createInput: function () {
      var a = d.prototype.createInput.call(this);
      return this.content.getHtmlElements = b.bind(this.getHtmlElements, this),
      a
    },
    getHtmlElements: function (a) {
      if (!a) return a;
      var c = [
        a
      ],
      d = this.getMentionNodes(a);
      return b.each(d, function (a, d) {
        for (var e = 0; e < c.length; e++) {
          var f,
          g = c[e],
          h = e;
          if (b.isString(g)) {
            for (; (f = g.indexOf(d)) > - 1; ) f > 0 && (c.splice(e, 0, g.substring(0, f)), e += 1),
            c.splice(e, 0, a.cloneNode(!0)),
            e += 1,
            g = g.substring(f + d.length);
            g && g !== c[h] && (c.splice(e, 0, g), e += 1),
            h !== e && c.splice(e, 1)
          }
        }
      }),
      c = b.map(c, function (a) {
        return b.isString(a) ? h.createTextNode(a) : a
      })
    },
    getMentionNodes: function (a) {
      var b = k.MENTIONS_RE_GROUPED,
      c = {
      };
      b.lastIndex = 0;
      for (var d = b.exec(a); d; ) {
        var e = d[1],
        f = this.userSuggestions.all().findWhere({
          username: e
        });
        if (f) {
          var g = k.getMentionDom(f),
          h = d[0];
          c[h] = g,
          this.updateCache(f, f.cid)
        }
        d = b.exec(a)
      }
      return c
    },
    handleKeyDown: function (a) {
      switch (d.prototype.handleKeyDown.call(this, a), a.keyCode) {
        case 9:
          this.suggestions.active && (this.suggestions.select(), a.preventDefault(), a.stopPropagation());
          break;
        case 10:
        case 13:
        case 38:
        case 40:
          this.suggestions.active && (a.preventDefault(), a.stopPropagation())
      }
    },
    handleKeyUp: function (a) {
      switch (d.prototype.handleKeyUp.call(this, a), a.preventDefault(), a.stopPropagation(), this.setSelection(), this.checkExistingMentions(), a.keyCode) {
        case 10:
        case 13:
          this.suggestions.select();
          break;
        case 27:
          this.reset(a);
          break;
        case 38:
          this.suggestions.move('up');
          break;
        case 40:
          this.suggestions.move('down');
          break;
        default:
          this.throttledSuggest(a)
      }
    },
    handleFocusIn: function () {
      var a = f.getLounge();
      a && this.$input && this.$input.on('transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd resize', function () {
        a.resize()
      }),
      j.handleFocusIn.call(this)
    },
    suggest: function () {
      var a = this.parseSearchTerms();
      this.suggestions.suggest(a)
    },
    throttledSuggest: b.throttle(function () {
      this.suggest()
    }, 250),
    insertMention: function (a) {
      var c = this.userSuggestions.get(a);
      if (c) {
        this.selectSearchString(c),
        this.updateCache(c, a);
        var d = k.getMentionDom(c);
        this.content.insertNode(d);
        var e = this.$el.find('span[data-cid]');
        b.each(e, function (a) {
          a.contentEditable !== !1 && (a.contentEditable = !1)
        })
      }
    },
    updateCache: function (a, b) {
      this.mentionsCache.get(b) || this.mentionsCache.add(a)
    },
    selectSearchString: function () {
      this.content.selectNodeText(this.anchorNode, this.anchorOffset - 1, this.anchorOffset + this.anchorLength)
    },
    get: function () {
      function a(a) {
        return c(a, !0) ? b.mentionToText(a) : null
      }
      var b = this,
      c = k.isMention;
      return this.content.text(a)
    },
    parseSearchTerms: function () {
      var a = this.content.selectedTextNode(),
      b = a ? a.nodeValue : '',
      d = c.normalizeSpace;
      if (b) {
        var e = this.content.selectedTextNodeOffset(a),
        f = c.normalizeSpace(b.slice(0, e).split('').reverse().join('')),
        g = f.indexOf('@');
        if (g === - 1) return null;
        this.anchorNode = a,
        this.anchorOffset = e - g,
        this.anchorLength = g;
        var h = d(b.slice(this.anchorOffset - 1, e)).match(k.MENTIONS_RE);
        return h ? h[0].slice(1).split(' ') : 0 === g ? [
          ''
        ] : void 0
      }
    },
    checkExistingMentions: function () {
      var d = c.normalizeSpace,
      e = this.$el.find('span'),
      f = b.filter(e, k.isMention),
      g = this.mentionsCache,
      h = {
      };
      b.each(f, function (c) {
        var e = a(c).attr('data-cid'),
        f = b.reduce(this.content.getTextNodes(c), function (a, b) {
          return a + d(b.nodeValue)
        }, ''),
        i = g.get(e);
        i && i.get('name') !== f ? (this.mentionsCache.remove(i), this.content.removeNode(c), this.content.insertHTML(' '), this.reset()) : h[e] = c
      }, this),
      g.each(function (a) {
        h[a.cid] || g.remove(a)
      })
    },
    mentionToText: function (b) {
      var c = a(b).attr('data-cid'),
      d = this.mentionsCache.get(c),
      e = b.innerText || b.textContent;
      return d && d.get('username') && (e = d.get('username')),
      [
        '@',
        e,
        ':',
        'disqus'
      ].join('')
    },
    toJSON: function () {
      var a = d.prototype.toJSON.call(this);
      return a.push(this.mentionsCache.models),
      a
    }
  }, {
    MENTIONS_RE: new RegExp('@\\w+\\s?(?:\\w+\\s?){0,5}(?:\\w+)?$'),
    MENTIONS_RE_GROUPED: /@([\d\w]+)\s?(:\s?(\w+))?/gi,
    isMention: function (b, c) {
      var d;
      do {
        if (d = a(b), d.hasClass('mention') && d.attr('data-cid')) return !0;
        b = b.parentElement
      } while (c && b);
      return !1
    },
    getMentionDom: function (a) {
      var b = h.createDocumentFragment(),
      c = h.createElement('span'),
      d = h.createElement('span'),
      e = h.createTextNode(a.get('name') || a.get('username'));
      return c.setAttribute('contenteditable', !0),
      d.setAttribute('contenteditable', !1),
      d.setAttribute('data-cid', a.cid),
      d.className = 'mention',
      d.appendChild(e),
      c.appendChild(d),
      b.appendChild(c),
      b.appendChild(h.createTextNode(' ')),
      b
    }
  });
  return k
}),
define('lounge/views/posts/DummyTextareaView', [
  'backbone',
  'core/CappedStorage',
  'core/extensions/jquery.autoresize'
], function (a, b) {
  'use strict';
  var c = a.View.extend({
    initialize: function (a) {
      a = a || {
      },
      this.storageKey = a.storageKey,
      this.value = a.value,
      this.history = [
        this.value
      ],
      this.historyPosition = 0,
      this.placeholder = a.placeholder,
      this.selectionIndices = {
        start: 0,
        end: 0,
        endElemInd: 0,
        endElemSelectionInd: 0,
        startElemInd: 0,
        startElemSelectionInd: 0
      },
      this.inputFixed = !1
    },
    render: function () {
      return this
    },
    createInput: function () {
    },
    resize: function () {
    },
    get: function () {
    },
    getSelected: function () {
    },
    offset: function () {
    },
    insertAtCursor: function () {
    },
    insertAroundSelection: function () {
    },
    set: function () {
    },
    clear: function () {
    },
    focus: function () {
    },
    handleKeyDown: function () {
    },
    handleKeyUp: function () {
    },
    handlePaste: function () {
    },
    handleFocusIn: function () {
    },
    handleBlur: function () {
    },
    saveDraft: function () {
    },
    toJSON: function () {
    },
    getDraft: function () {
    },
    removeDraft: function () {
    },
    fixInputStructure: function () {
    },
    focusEndOfText: function () {
    },
    getWhichChildIndex: function () {
    },
    getNodeLength: function () {
    },
    placeholderSetSelection: function () {
    },
    setSelection: function () {
    },
    addTagTextarea: function () {
    },
    addTag: function () {
    },
    selectText: function () {
    },
    debouncedSaveHistory: function () {
    },
    undoTextarea: function () {
    },
    redoTextarea: function () {
    }
  }, {
    MAX_TEXTAREA_HEIGHT: 350,
    SAVE_DRAFT_INTERVAL: 500,
    DRAFT_MAX_AGE: 86400000,
    storage: new b(5, 'drafts.queue')
  });
  return c
}),
define('core/views/common/LoginFormView', [
  'underscore',
  'backbone',
  'core/strings'
], function (a, b, c) {
  'use strict';
  var d = c.get,
  e = b.View.extend({
    initialize: function () {
      this.model = new this.User
    },
    parseRegistrationErrorResponse: function (a) {
      if (a.responseJSON) {
        var b = a.responseJSON.response;
        return window.grecaptcha && window.grecaptcha.reset(),
        /Unable to create user/i.test(b) ? {
          email: [
            d('That email address is already registered with a Disqus account. Log in or enter another email.')
          ]
        }
         : /The e-mail address you specified is already in use./i.test(b) ? {
          email: [
            d('The e-mail address you specified is already in use.') + '<br><a class="link" href="#" data-action="auth:disqus">' + d('Try logging in.') + '</a>'
          ]
        }
         : (/You must re-submit this request with a response to the captcha challenge/i.test(b) && this.showCaptcha && this.showCaptcha(null, !0), {
          all: [
            b
          ]
        })
      }
    },
    getPassword: function () {
      var a = this.$el.find('input[name=password]');
      return a.length ? a.val() : null
    },
    getDisplayName: function () {
      return this.$el.find('input[name=display_name]').val()
    },
    getEmail: function () {
      return this.$el.find('input[name=email]').val()
    },
    disableForm: function () {
      this.$('[data-role=submit-btn-container]').addClass('is-submitting')
    },
    enableForm: function () {
      this.$('[data-role=submit-btn-container]').removeClass('is-submitting')
    },
    handleRegistrationErrorResponse: function (a) {
      this.handleRegistrationError(this.parseRegistrationErrorResponse(a))
    },
    registerUser: function () {
      return this.model.set({
        display_name: this.$el.find('input[name=display_name]').val(),
        email: this.$el.find('input[name=email]').val(),
        password: this.getPassword()
      }),
      this.model.isValid() ? (this.disableForm(), void this.model.register({
        gRecaptchaResponse: this.captchaShown && window.grecaptcha && window.grecaptcha.getResponse(),
        error: a.bind(this.handleRegistrationErrorResponse, this),
        success: a.bind(this.handleRegistrationSuccess, this)
      }).always(a.bind(this.enableForm, this))) : void this.handleRegistrationError(this.model.validationError)
    }
  });
  return e
}),
define('templates/lounge/partials/audienceSync', [
  'react',
  'core/config/urls',
  'core/strings'
], function (a, b, c) {
  'use strict';
  var d = c.gettext,
  e = function (c) {
    return a.createElement('div', {
      className: 'audiencesync'
    }, a.createElement('h6', null, d('Connect with %(forumName)s', {
      forumName: c.forumName
    })), a.createElement('div', {
      className: 'services'
    }, a.createElement('div', {
      className: 'audiencesync__icons'
    }, a.createElement('img', {
      className: 'icon',
      alt: 'Disqus',
      src: 'https://c.disquscdn.com/next/embed/assets/img/audiencesync/sync-icon.74333606cf6b545eb92a69a61b112481.png'
    }), a.createElement('i', {
      className: 'icon icon-proceed'
    }), a.createElement('img', {
      className: 'icon',
      alt: c.forumName,
      src: (b.root || '') + '/api/applications/icons/' + (c.apiKey || '') + '.png'
    })), a.createElement('p', null, d('%(forumName)s needs permission to access your account.', {
      forumName: c.forumName
    }))), a.createElement('button', {
      type: 'button',
      'data-action': 'audiencesync',
      className: 'proceed btn submit'
    }, d('Next')))
  };
  return e
}),
define('templates/lounge/partials/guestForm', [
  'react',
  'core/strings',
  'core/utils/object/get'
], function (a, b, c) {
  'use strict';
  var d = b.gettext,
  e = function () {
    return a.createElement('div', {
      className: 'acceptance-wrapper'
    }, a.createElement('label', null, a.createElement('input', {
      type: 'checkbox',
      name: 'tos'
    }), a.createElement('span', {
      className: 'spacing-left-small'
    }, d('I agree to Disqus\' %(terms)s', {
      terms: a.createElement('a', {
        href: 'https://help.disqus.com/customer/portal/articles/466260-terms-of-service',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, d('Terms of Service'))
    }))), a.createElement('label', null, a.createElement('input', {
      type: 'checkbox',
      name: 'privacy-policy'
    }), a.createElement('span', {
      className: 'spacing-left-small'
    }, d('I consent to Disqus’ processing of my personal data, in accordance with its %(policy)s and %(terms)s, (including the use of strictly necessary cookies) to the extent needed to authenticate me and enable me to post comments or use other Disqus services. I acknowledge that my personal data will be processed in the United States', {
      policy: a.createElement('a', {
        href: 'https://disqus.com/privacy-policy',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, d('Privacy Policy')),
      terms: a.createElement('a', {
        href: 'https://help.disqus.com/customer/portal/articles/466260-terms-of-service',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, d('Terms of Service'))
    }))), a.createElement('label', null, a.createElement('input', {
      type: 'checkbox',
      name: 'data-sharing'
    }), a.createElement('span', {
      className: 'spacing-left-small'
    }, d('I consent to Disqus collecting, using, and disclosing my personal data for marketing purposes, including the use of tracking cookies for cross context behavioral advertising. My personal data may be transferred to the companies listed %(dataRecipients)s. I may withdraw my consent at any time by clicking %(policy)s', {
      policy: a.createElement('a', {
        href: 'https://disqus.com/data-sharing-settings/',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, d('here')),
      dataRecipients: a.createElement('a', {
        href: 'https://help.disqus.com/en/articles/1944034-cookies-and-data-recipients',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, d('here'))
    }))))
  },
  f = function (b) {
    var f = b.isRefreshEnabled,
    g = f ? 'sign-up-wrapper-refresh' : '',
    h = f ? 'guest guest--refresh' : 'guest',
    i = f ? 'guest-form-title guest-form-title--refresh' : 'guest-form-title';
    return a.createElement('div', {
      className: h
    }, a.createElement('div', {
      className: g
    }, a.createElement('h6', {
      className: i
    }, a.createElement('span', {
      className: 'register-text'
    }, ' ', d('or sign up with Disqus'), ' '), a.createElement('span', {
      className: 'guest-text'
    }, ' ', d('or pick a name'), ' ')), ' ', a.createElement('button', {
      type: 'button',
      className: 'help-tooltip__wrapper help-icon',
      name: 'guest_tooltip',
      tabIndex: 0
    }, a.createElement('div', {
      id: 'rules',
      className: 'help-tooltip__container',
      'data-role': 'guest-form-tooltip'
    }, a.createElement('div', {
      className: 'tooltip show help-tooltip'
    }, a.createElement('h3', {
      className: 'help-tooltip__heading'
    }, d('Disqus is a discussion network')), a.createElement('ul', {
      className: 'help-tooltip__list'
    }, a.createElement('li', null, a.createElement('span', null, d('Don\'t be a jerk or do anything illegal. Everything is easier that way.')))), a.createElement('p', {
      className: 'clearfix'
    }, a.createElement('a', {
      href: 'https://docs.disqus.com/kb/terms-and-policies/',
      className: 'btn btn-small help-tooltip__button',
      rel: 'noopener noreferrer',
      target: '_blank'
    }, d('Read full terms and conditions'))))))), a.createElement('p', {
      className: 'input-wrapper'
    }, a.createElement('input', {
      dir: 'auto',
      type: 'text',
      placeholder: d('Name'),
      name: 'display_name',
      id: (b.cid || '') + '_display_name',
      maxLength: '30',
      className: 'input--text',
      'aria-label': 'name'
    })), a.createElement('div', {
      className: 'guest-details ' + (c(b.sso, [
        'url'
      ]) ? 'expanded' : ''),
      'data-role': 'guest-details'
    }, a.createElement('p', {
      className: 'input-wrapper'
    }, a.createElement('input', {
      dir: 'auto',
      type: 'email',
      placeholder: d('Email'),
      name: 'email',
      id: (b.cid || '') + '_email',
      className: 'input--text',
      'aria-label': 'email'
    })), a.createElement('p', {
      className: 'input-wrapper'
    }, a.createElement('input', {
      dir: 'auto',
      disabled: !c(b.sso, [
        'url'
      ]),
      type: c(b.sso, [
        'url'
      ]) ? 'password' : 'text',
      className: 'register-text input--text',
      placeholder: d('Password'),
      name: 'password',
      'aria-label': 'password',
      id: (b.cid || '') + '_password'
    })), b.isPrivate ? a.createElement(e, null) : a.createElement('p', {
      className: 'privacy-info'
    }, a.createElement('div', null, d('By clicking submit, I authorize Disqus, Inc. and its affiliated companies to'), ':'), a.createElement('div', null, a.createElement('ul', {
      className: 'privacy-info-list'
    }, a.createElement('li', null, d('Use, sell, and share my information to enable me to use its comment services and for marketing purposes, including cross-context behavioral advertising, as described in our %(terms)s and %(policy)s', {
      policy: a.createElement('a', {
        href: 'https://disqus.com/privacy-policy',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, d('Privacy Policy')),
      terms: a.createElement('a', {
        href: 'https://help.disqus.com/customer/portal/articles/466260-terms-of-service',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, d('Terms of Service'))
    })), a.createElement('li', null, d('Supplement the information that I provide with additional information lawfully obtained from other sources, like demographic data from public sources, interests inferred from web page views, or other data relevant to what might interest me, like past purchase or location data')), a.createElement('li', null, d('Contact me or enable others to contact me by email with offers for goods and services (from any category) at the email address provided')), a.createElement('li', null, d('Process any sensitive personal information that I submit in a comment for the purpose of displaying the comment')), a.createElement('li', null, d('Retain my information while I am engaging with marketing messages that I receive and for a reasonable amount of time thereafter. I understand I can opt out at any time through an email that I receive.  Companies that we share data with are listed %(dataRecipients)s.', {
      dataRecipients: a.createElement('a', {
        href: 'https://help.disqus.com/en/articles/1944034-cookies-and-data-recipients',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, d('here'))
    }))))), b.allowAnonPost ? a.createElement('div', {
      className: 'guest-checkbox'
    }, a.createElement('label', null, a.createElement('input', {
      type: 'checkbox',
      name: 'author-guest'
    }), ' ', d('I\'d rather post as a guest'))) : a.createElement('input', {
      type: 'checkbox',
      name: 'author-guest',
      style: {
        display: 'none'
      }
    }), a.createElement('div', {
      className: 'g-recaptcha',
      'data-role': 'grecaptcha-container'
    }), a.createElement('div', {
      className: 'proceed',
      'data-role': 'submit-btn-container'
    }, b.allowAnonPost ? a.createElement('div', null, a.createElement('button', {
      type: 'submit',
      className: 'proceed__button btn submit',
      'aria-label': d('Post')
    }, a.createElement('span', {
      className: 'icon-proceed'
    }), a.createElement('div', {
      className: 'spinner'
    })), a.createElement('button', {
      type: 'submit',
      className: 'proceed__button btn next',
      'aria-label': d('Next')
    }, a.createElement('span', {
      className: 'icon-proceed'
    }), a.createElement('div', {
      className: 'spinner'
    }))) : a.createElement('button', {
      type: 'submit',
      className: 'proceed__button btn submit',
      'aria-label': d('Next')
    }, a.createElement('span', {
      className: 'icon-proceed'
    }), a.createElement('div', {
      className: 'spinner'
    })))))
  };
  return f
}),
define('templates/lounge/partials/loginButtons', [
  'react',
  'core/utils/object/get'
], function (a, b) {
  'use strict';
  var c = function (c) {
    return a.createElement('ul', {
      'data-role': 'login-menu',
      className: 'services login-buttons'
    }, b(c.sso, [
      'url'
    ]) ? a.createElement('li', {
      className: 'sso'
    }, a.createElement('button', {
      type: 'button',
      'data-action': 'auth:sso',
      title: b(c.sso, [
        'name'
      ], ''),
      className: 'sso__button ' + (b(c.sso, [
        'button'
      ]) ? 'image' : 'no-image')
    }, b(c.sso, [
      'button'
    ]) ? a.createElement('img', {
      alt: b(c.sso, [
        'name'
      ], ''),
      src: b(c.sso, [
        'button'
      ], '')
    }) : b(c.sso, [
      'name'
    ], null))) : null, a.createElement('li', {
      className: 'auth-disqus'
    }, a.createElement('button', {
      type: 'button',
      'data-action': 'auth:disqus',
      title: 'Disqus',
      className: 'connect__button',
      'aria-label': 'Login with Disqus'
    }, a.createElement('i', {
      className: 'icon-disqus'
    }))), a.createElement('li', {
      className: 'auth-facebook'
    }, a.createElement('button', {
      type: 'button',
      'data-action': 'auth:facebook',
      title: 'Facebook',
      className: 'connect__button',
      'aria-label': 'Login with Facebook'
    }, a.createElement('i', {
      className: 'icon-facebook-circle'
    }))), a.createElement('li', {
      className: 'auth-twitter'
    }, a.createElement('button', {
      type: 'button',
      'data-action': 'auth:twitter',
      title: 'X (Twitter)',
      className: 'connect__button',
      'aria-label': 'Login with X (Twitter)'
    }, a.createElement('i', {
      className: 'icon-twitter-x'
    }))), a.createElement('li', {
      className: 'auth-google'
    }, a.createElement('button', {
      type: 'button',
      'data-action': 'auth:google',
      title: 'Google',
      className: 'connect__button',
      'aria-label': 'Login with Google'
    }, a.createElement('i', {
      className: 'icon-google-plus-circle'
    }))), a.createElement('li', {
      className: 'auth-microsoft'
    }, a.createElement('button', {
      type: 'button',
      'data-action': 'auth:microsoft',
      title: 'Microsoft',
      className: 'connect__button',
      'aria-label': 'Login with Microsoft'
    })), a.createElement('li', {
      className: 'auth-apple'
    }, a.createElement('button', {
      type: 'button',
      'data-action': 'auth:apple',
      title: 'Apple',
      className: 'connect__button',
      'aria-label': 'Login with Apple'
    })))
  };
  return c
}),
define('templates/lounge/loginForm', [
  'react',
  'core/strings',
  'core/switches',
  'core/utils/object/get',
  'templates/lounge/partials/audienceSync',
  'templates/lounge/partials/guestForm',
  'templates/lounge/partials/loginButtons'
], function (a, b, c, d, e, f, g) {
  'use strict';
  var h = b.gettext,
  i = function (b) {
    var i = b.forumName,
    j = c.isFeatureActive('embed_refresh', {
      forum: i
    }),
    k = j ? 'connect__heading' : '';
    return a.createElement('div', null, d(b.user, [
      'isAnonymous'
    ]) ? a.createElement('section', {
      className: 'auth-section logged-out__display'
    }, a.createElement('div', {
      className: 'connect'
    }, a.createElement('h6', {
      className: k
    }, h('Log in with')), a.createElement(g, {
      sso: b.sso
    })), a.createElement(f, {
      cid: b.cid,
      sso: b.sso,
      allowAnonPost: b.allowAnonPost,
      isPrivate: b.isPrivate,
      captcha_site_key: b.captcha_site_key,
      isRefreshEnabled: j
    })) : null, b.audienceSyncRequired ? a.createElement('section', {
      className: 'auth-section'
    }, a.createElement(e, {
      apiKey: b.apiKey,
      forumName: b.forumName
    })) : null)
  };
  return i
}),
define('lounge/views/posts/LoginFormView', [
  'underscore',
  'jquery',
  'remote/config',
  'core/bus',
  'core/api',
  'core/views/common/LoginFormView',
  'common/models',
  'lounge/common',
  'templates/lounge/loginForm'
], function (a, b, c, d, e, f, g, h, i) {
  'use strict';
  var j = f.extend({
    events: {
      'click input[name=author-guest]': 'updateLoginForm',
      'focusin input[name=display_name]': 'expandGuestForm',
      'change input[name=tos], input[name=privacy-policy]': 'updateEnabled',
      'keyup input[name=display_name]': 'showCaptcha',
      'click button[name=guest_tooltip]': 'toggleGuestFormTooltip'
    },
    User: g.User,
    initialize: function (b) {
      f.prototype.initialize.call(this, b),
      this.thread = b.thread,
      this.session = b.session,
      this.alert = b.alert,
      this.config = a.property('config') (h.getLounge()) || {
      }
    },
    expandGuestForm: function () {
      this.$('[data-role=guest-details]').hasClass('expanded') || (this.$('[data-role=guest-details]').addClass('expanded'), this.$('input[name=password]').attr('type', 'password').removeAttr('disabled'), this.$('[name=display_name]').focus())
    },
    retractGuestForm: function () {
      this.$('[data-role=guest-details]').hasClass('expanded') && this.$('[data-role=guest-details]').removeClass('expanded')
    },
    toggleGuestFormTooltip: function () {
      this.$('[data-role=guest-form-tooltip]').hasClass('expanded') ? this.$('[data-role=guest-form-tooltip]').removeClass('expanded') : this.$('[data-role=guest-form-tooltip]').addClass('expanded')
    },
    showCaptcha: function (d, e) {
      !this.captchaShown && this.$('input[name=display_name]').val().trim().length && (c.register.ENABLE_CAPTCHA || e) && (window.onCaptchaChange = a.bind(this.updateEnabled, this), window.onCaptchaLoad = a.bind(function () {
        window.grecaptcha && (this.captchaId = window.grecaptcha.render(this.$('[data-role=grecaptcha-container]') [0], {
          sitekey: this.session.getRecaptchaKey(),
          callback: 'onCaptchaChange',
          'expired-callback': 'onCaptchaChange'
        }), this.updateEnabled(), a.delay(function () {
          b('iframe[title^="recaptcha challenge"]').parent().parent().addClass('recaptcha-challenge-container')
        }, 1000))
      }, this), b('<script>').attr('src', 'https://www.google.com/recaptcha/api.js?onload=onCaptchaLoad&render=explicit').appendTo(b('head')), this.captchaShown = !0)
    },
    shouldRegisterUser: function () {
      return this.session.isLoggedOut() && !this.$('input[name=author-guest]').is(':checked')
    },
    render: function () {
      return this.$el.html(i({
        user: this.session.toJSON(),
        forumName: this.thread.forum.get('name'),
        audienceSyncRequired: this.session.needsAudienceSyncAuth(this.thread.forum),
        allowAnonPost: this.thread.forum.get('settings').allowAnonPost,
        apiKey: this.config.apiKey || '',
        sso: this.session.get('sso'),
        cid: this.cid,
        isPrivate: Boolean(this.config.isPrivate)
      })),
      this.updateEnabled(),
      this
    },
    updateEnabled: function () {
      this.$el.closest('form').find('button[type=submit]').attr('disabled', Boolean(this.config.isPrivate) && (!this.$('input[name=tos]').prop('checked') || !this.$('input[name=privacy-policy]').prop('checked')) || Boolean(this.captchaShown && window.grecaptcha && !window.grecaptcha.getResponse(this.captchaId)))
    },
    handleRegistrationSuccess: function () {
      var a = this.$('input[name=data-sharing]');
      a.length && e.call('internal/users/setDNT', {
        method: 'POST',
        data: {
          value: a.prop('checked') ? 0 : 1
        }
      }),
      this.session.setUser(this.model),
      d.frame.trigger('onboardAlert.show'),
      this.retractGuestForm()
    },
    handleRegistrationError: function (b) {
      var c = this;
      c.clearRegistrationErrors(),
      a.isString(b) && (b = {
        all: [
          b
        ]
      }),
      a.has(b, 'all') && (c.alert && c.alert(b.all[0], {
        type: 'error'
      }), b = a.omit(b, 'all')),
      a.each(b, function (a, b) {
        var d = c.$('input[name=' + b + ']');
        d.attr('aria-invalid', 'true').attr('aria-labelledby', 'label-for-' + d.attr('id')).after('<label for="' + d.attr('id') + '" id="label-for-' + d.attr('id') + '" class="input-label">' + a[0] + '</label>').parent('.input-wrapper').addClass('has-error')
      }),
      c.$('[aria-invalid]').first().focus()
    },
    updateLoginForm: function () {
      var a = this.$el,
      b = a.find('input[name=author-guest]').is(':checked'),
      c = a.find('.guest'),
      d = a.find('input[name=password]');
      d.val(''),
      c.toggleClass('is-guest', b),
      this.clearRegistrationErrors()
    },
    clearRegistrationErrors: function () {
      this.$('.input-wrapper.has-error').removeClass('has-error').find('.input-label').remove(),
      this.$('[aria-invalid]').removeAttr('aria-invalid')
    }
  });
  return j
});
var _extends = Object.assign || function (a) {
  for (var b = 1; b < arguments.length; b++) {
    var c = arguments[b];
    for (var d in c) Object.prototype.hasOwnProperty.call(c, d) && (a[d] = c[d])
  }
  return a
};
define('templates/lounge/partials/profileLink', [
  'react',
  'core/switches',
  'core/utils/object/get'
], function (a, b, c) {
  'use strict';
  var d = function (d) {
    var e = d.children,
    f = d.user,
    g = d.forumId,
    h = d.profileTab,
    i = _objectWithoutProperties(d, [
      'children',
      'user',
      'forumId',
      'profileTab'
    ]),
    j = c(f, [
      'isSSOProfileUrl'
    ]);
    if (!j && b.isFeatureActive('sso_less_branding', {
      forum: g
    })) return a.createElement('span', i, e);
    var k = c(f, [
      'profileUrl'
    ], ''),
    l = 'profile';
    return j ? l = null : k && h && (k = '' + k + h),
    a.createElement('a', _extends({
      href: k,
      'data-action': l,
      'data-tab': h || '',
      'data-username': c(f, [
        'username'
      ], ''),
      target: '_blank',
      rel: 'noopener noreferrer'
    }, i), e)
  };
  return d
}),
define('templates/lounge/partials/userAvatar', [
  'react',
  'core/strings',
  'core/switches',
  'core/utils',
  'core/utils/object/get',
  'templates/lounge/partials/profileLink'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = b.gettext,
  h = d.getInitials,
  i = function (b) {
    var d = b.defaultAvatarUrl,
    i = b.forum,
    j = b.user,
    k = b.hasForumAvatar,
    l = c.isFeatureActive('embed_refresh', {
      forum: i.id
    }),
    m = l && c.isFeatureActive('embed_refresh_v2', {
      forum: i.id
    }),
    n = l ? 'user user--refresh' : 'user',
    o = void 0,
    p = e(i, [
      'avatar',
      'large',
      'cache'
    ], '');
    return void 0 === j.avatar.isCustom || j.avatar.isCustom === !0 ? o = e(j, [
      'avatar',
      'cache'
    ], '') : l ? l && k && (o = p) : o = p ? p : d,
    a.createElement(f, {
      user: j,
      forumId: i.id,
      className: n
    }, o ? a.createElement('img', {
      'data-role': 'user-avatar',
      'data-user': e(j, [
        'id'
      ], ''),
      src: d || o,
      'data-src': d ? o : null,
      alt: g('Avatar'),
      className: l ? 'image-refresh' : null
    }) : a.createElement('div', null, m ? h(j.name) [0] : h(j.name)))
  };
  return i
}),
define('templates/lounge/form', [
  'react',
  'core/strings',
  'core/switches',
  'core/utils',
  'core/utils/object/get',
  'templates/lounge/partials/userAvatar'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = b.gettext,
  h = function (b) {
    var h = b.forum.id,
    i = c.isFeatureActive('embed_refresh', {
      forum: h
    }),
    j = c.isFeatureActive('embed_v2', {
      forum: h
    }),
    k = i ? 'textarea-outer-wrapper textarea-outer-wrapper--refresh' : 'textarea-outer-wrapper',
    l = i ? 'user user--refresh' : 'user',
    m = i ? 'image-refresh' : '',
    n = !d.isDefaultAvatar(e(b.forum, [
      'avatar',
      'large',
      'cache'
    ], ''));
    return a.createElement('div', {
      className: 'postbox'
    }, a.createElement('div', {
      role: 'alert'
    }), a.createElement('div', {
      className: 'ratings-wrapper',
      'data-role': 'ratings-container'
    }), a.createElement('div', {
      className: 'compose-wrapper'
    }, a.createElement('div', {
      className: 'avatar'
    }, e(b.user, [
      'isRegistered'
    ]) ? a.createElement(f, {
      forum: b.forum,
      user: b.user,
      hasForumAvatar: n
    }) : a.createElement('span', {
      className: l
    }, i && !n ? a.createElement('div', null, 'G') : a.createElement('img', {
      'data-role': 'user-avatar',
      src: e(b.forum, [
        'avatar',
        'large',
        'cache'
      ], ''),
      alt: g('Avatar'),
      className: m
    }))), a.createElement('div', {
      className: k
    }, j ? a.createElement('div', {
      className: 'textarea-wrapper textarea-wrapper--embedv2',
      'data-role': 'textarea',
      dir: 'auto'
    }, a.createElement('div', {
      className: 'textarea-skeleton'
    })) : a.createElement('div', {
      className: 'textarea-wrapper',
      'data-role': 'textarea',
      dir: 'auto'
    }, a.createElement('div', {
      'data-role': 'drag-drop-placeholder',
      className: 'media-drag-hover',
      style: {
        display: 'none'
      }
    }, a.createElement('div', {
      className: 'drag-text'
    }, '⬇ ', g('Drag and drop your images here to upload them.'))), b.displayMediaPreviews ? a.createElement('div', {
      className: 'media-preview empty',
      'data-role': 'media-preview'
    }) : null, a.createElement('div', {
      className: 'edit-alert',
      role: 'postbox-alert'
    }), a.createElement('div', {
      className: 'text-editor-container'
    })))), a.createElement('div', {
      'data-role': 'login-form'
    }))
  };
  return h
}),
define('templates/lounge/textEditor', [
  'react',
  'core/constants/textEditorConstants',
  'core/strings',
  'core/switches',
  'core/utils/object/get'
], function (a, b, c, d, e) {
  'use strict';
  var f = c.gettext,
  g = function (b) {
    var c = b.forum,
    g = d.isFeatureActive('embed_refresh', {
      forum: c
    }),
    h = function () {
      return g ? b.useSmallPostButton ? 'hidden' : '' : e(b.user, [
        'isRegistered'
      ]) && !b.useSmallPostButton ? '' : 'hidden'
    };
    return a.createElement('div', {
      className: 'temp-post'
    }, a.createElement('button', {
      type: 'submit',
      className: 'btn post-action__button full-size-button ' + h()
    }, g ? f('Comment') : f('Post as %(name)s', {
      name: a.createElement('span', {
        'data-username': e(b.user, [
          'username'
        ], ''),
        'data-role': 'username'
      }, e(b.user, [
        'name'
      ], null))
    })), a.createElement('button', {
      type: 'submit',
      className: 'btn post-action__button small-size-button' + (e(b.user, [
        'isRegistered'
      ]) && b.useSmallPostButton ? '' : ' hidden')
    }, f(g ? 'Comment' : 'Post')))
  },
  h = function (b) {
    return a.createElement('div', {
      className: 'logged-in'
    }, a.createElement('section', null, b.edit ? a.createElement('div', {
      className: 'temp-post'
    }, a.createElement('button', {
      className: 'btn post-action__button edit-button',
      type: 'submit'
    }, f('Save Edit')), a.createElement('a', {
      className: 'cancel post-action__cancel',
      href: '#',
      'data-action': 'edit'
    }, f('Cancel'))) : a.createElement(g, b)))
  },
  i = function (c) {
    return a.createElement('div', {
      className: 'wysiwyg'
    }, c.buttonsToShow.indexOf(b.GIF_PICKER_BUTTON) > - 1 ? a.createElement('div', {
      className: 'gif-picker'
    }, a.createElement('div', {
      className: 'wysiwyg__item',
      'data-role': 'gif-picker-toggle',
      title: f('GIF'),
      'aria-label': 'Open GIF menu',
      tabIndex: '0'
    }, a.createElement('div', {
      className: 'wysiwyg__gif',
      title: f('GIF'),
      role: 'img'
    })), a.createElement('div', {
      className: 'hidden gif-picker__popout-container',
      'data-role': 'gif-picker-popout-container'
    }), a.createElement('div', {
      className: 'new-feature-badge-star',
      title: f('New')
    }, a.createElement('div', {
      className: 'wysiwyg__star-badge wysiwyg__star-badge-dims'
    }))) : null, c.buttonsToShow.indexOf(b.MEDIA_UPLOADER_BUTTON) > - 1 ? a.createElement('div', {
      className: 'media-uploader'
    }, a.createElement('li', {
      className: 'wysiwyg__item',
      'data-role': 'media-uploader',
      tabIndex: '-1'
    })) : null, (c.buttonsToShow.indexOf(b.GIF_PICKER_BUTTON) > - 1 || c.buttonsToShow.indexOf(b.MEDIA_UPLOADER_BUTTON) > - 1) && c.buttonsToShow.length > 1 ? a.createElement('div', {
      className: 'vertical-separator'
    }) : null, a.createElement('div', {
      'data-action': 'text-editor-buttons'
    }, a.createElement('div', {
      className: 'wysiwyg__item' + (c.buttonsToShow.indexOf('b') > - 1 ? '' : ' hidden'),
      'data-action': 'text-editor-tag',
      'data-tag': 'b',
      tabIndex: '0',
      'aria-label': 'Add bold tags to text editor'
    }, a.createElement('div', {
      className: 'wysiwyg__bold',
      title: f('Bold'),
      role: 'img'
    })), a.createElement('div', {
      className: 'wysiwyg__item' + (c.buttonsToShow.indexOf('i') > - 1 ? '' : ' hidden'),
      'data-action': 'text-editor-tag',
      'data-tag': 'i',
      tabIndex: '0',
      'aria-label': 'Add italics tags to text editor'
    }, a.createElement('div', {
      className: 'wysiwyg__italic',
      title: f('Italic'),
      role: 'img'
    })), a.createElement('div', {
      className: 'wysiwyg__item' + (c.buttonsToShow.indexOf('u') > - 1 ? '' : ' hidden'),
      'data-action': 'text-editor-tag',
      'data-tag': 'u',
      tabIndex: '0',
      'aria-label': 'Add underline tags to text editor'
    }, a.createElement('div', {
      className: 'wysiwyg__underline',
      title: f('Underline'),
      role: 'img'
    })), a.createElement('div', {
      className: 'wysiwyg__item' + (c.buttonsToShow.indexOf('s') > - 1 ? '' : ' hidden'),
      'data-action': 'text-editor-tag',
      'data-tag': 's',
      tabIndex: '0',
      'aria-label': 'Add strikethrough tags to text editor'
    }, a.createElement('div', {
      className: 'wysiwyg__strikethrough',
      title: f('Strikethrough'),
      role: 'img'
    })), a.createElement('div', {
      className: 'wysiwyg__item' + (c.buttonsToShow.indexOf('a') > - 1 ? '' : ' hidden'),
      'data-action': 'text-editor-tag',
      'data-tag': 'a',
      tabIndex: '0',
      'aria-label': 'Add link tags to text editor'
    }, a.createElement('div', {
      className: 'wysiwyg__link',
      title: f('Link'),
      role: 'img'
    })), a.createElement('div', {
      className: 'wysiwyg__item' + (c.buttonsToShow.indexOf('spoiler') > - 1 ? '' : ' hidden'),
      'data-action': 'text-editor-tag',
      'data-tag': 'spoiler',
      tabIndex: '0',
      'aria-label': 'Add spoiler tags to text editor'
    }, a.createElement('div', {
      className: 'wysiwyg__spoiler',
      title: f('Spoiler'),
      role: 'img'
    })), a.createElement('div', {
      className: 'wysiwyg__item' + (c.buttonsToShow.indexOf('code') > - 1 ? '' : ' hidden'),
      'data-action': 'text-editor-tag',
      'data-tag': 'code',
      tabIndex: '0',
      'aria-label': 'Add code tags to text editor'
    }, a.createElement('div', {
      className: 'wysiwyg__code',
      title: f('Code'),
      role: 'img'
    })), a.createElement('div', {
      className: 'wysiwyg__item' + (c.buttonsToShow.indexOf('blockquote') > - 1 ? '' : ' hidden'),
      'data-action': 'text-editor-tag',
      'data-tag': 'blockquote',
      tabIndex: '0',
      'aria-label': 'Add block quote tags to text editor'
    }, a.createElement('div', {
      className: 'wysiwyg__blockquote',
      title: f('Quote'),
      role: 'img'
    }))))
  },
  j = function (b) {
    return a.createElement('div', {
      className: 'post-actions'
    }, a.createElement(i, b), a.createElement(h, b))
  };
  return j
}),
define('templates/lounge/blacklistErrorMessage', [
  'react',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.gettext,
  d = function (b) {
    return [b.expirationRelative ? c('We are unable to post your comment because %(blocker)s has placed your account in a timeout. You will be able to comment again when your timeout expires %(expirationRelative)s.', {
      blocker: b.blocker,
      expirationRelative: b.expirationRelative
    }) : c('We are unable to post your comment because you have been banned by %(blocker)s.', {
      blocker: b.blocker
    }),
    ' ',
    a.createElement('a', {
      key: 'error-link',
      target: '_blank',
      href: 'https://help.disqus.com/customer/portal/articles/466223-who-deleted-or-removed-my-comment-'
    }, c('Find out more.'))]
  };
  return d
}),
define('templates/lounge/emailVerifyAlert', [
  'react',
  'core/strings',
  'core/utils/object/get'
], function (a, b, c) {
  'use strict';
  var d = b.gettext,
  e = function (b) {
    return [d('%(forumName)s requires you to verify your email address before posting.', {
      forumName: b.forumName
    }),
    ' ',
    a.createElement('a', {
      key: 'alert-link',
      'data-action': 'verify-email',
      'data-forum': b.forumId,
      title: d('Verify Email'),
      href: '/verify'
    }, d('Send verification email to %(email)s', {
      email: c(b.user, [
        'email'
      ], '')
    }))]
  };
  return e
}),
define('lounge/views/posts/PostReplyView', [
  'jquery',
  'underscore',
  'react',
  'react-dom/server',
  'core/utils',
  'core/bus',
  'core/switches',
  'core/views/PostReplyView',
  'common/models',
  'lounge/mixins/asGifPicker',
  'lounge/mixins/asTextEditor',
  'lounge/mixins/asTextEditorV2',
  'lounge/mixins/withStarRatings',
  'lounge/mixins/post-reply',
  'lounge/common',
  'lounge/views/posts/ContentEditableView',
  'lounge/views/posts/DummyTextareaView',
  'lounge/views/posts/LoginFormView',
  'templates/lounge/form',
  'templates/lounge/textEditor',
  'templates/lounge/blacklistErrorMessage',
  'templates/lounge/emailVerifyAlert'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u, v) {
  'use strict';
  var w = e.preventDefaultHandler,
  x = h,
  y = x.prototype,
  z = x.extend({
    initialize: function (a) {
      y.initialize.call(this, a),
      this.listenTo(this.session, 'change:audienceSyncVerified', this.redraw),
      this.userSuggestions = a.userSuggestions,
      this.loginFormView = new r({
        thread: this.thread,
        session: this.session,
        alert: b.bind(this.alert, this)
      });
      var e = o.getLounge();
      b.each(['uiCallback:postCreated',
      'domReflow'], function (a) {
        this.listenTo(this, a, b.bind(e.trigger, e, a))
      }, this),
      this.template = s,
      this.textEditorTemplate = t,
      this.blacklistErrorMessageTemplate = function (a) {
        return d.renderToStaticMarkup(c.createElement(u, a))
      },
      this.emailVerifyAlertTemplate = function (a) {
        return d.renderToStaticMarkup(c.createElement(v, a))
      },
      this.postEditMode = !1
    },
    getTemplateData: function () {
      var a = y.getTemplateData.call(this);
      return a.audienceSyncRequired = this.session.needsAudienceSyncAuth(this.thread.forum),
      a.forum = this.thread.forum.toJSON(),
      a
    },
    getEditorProps: function () {
      return {
        placeholder: this.getPlaceholderText(),
        allowUploads: this.allowUploads,
        gifPickerEnabled: this.gifPickerEnabled,
        focusOnLoad: Boolean(this.parent),
        onSubmit: this.submitForm.bind(this, null),
        draftKey: 'v2:' + this.post.storageKey()
      }
    },
    render: function () {
      return this.loginFormView.$el.detach(),
      this.isEmbedV2Enabled ? (this.$el.html(this.template(this.getTemplateData())), this.loadEditorV2(this.getEditorProps()), this.textarea = new q, this.constructor.mustVerifyEmailToPost(this.session.user, this.thread.forum) && this._alertMustVerify(this.shouldShowEmailAlertInForm), this._isHidden && this.$el.addClass('hidden'), this.initStarRatings()) : y.render.call(this),
      this.loginFormView.render(),
      this.loginFormView.$el.appendTo(this.$('[data-role=login-form]')),
      this.session.user.id ? this.$el.addClass('authenticated') : this.$el.removeClass('authenticated'),
      this
    },
    createTextarea: function () {
      var a = {
        placeholder: this.getPlaceholderText(),
        storageKey: this.post.storageKey()
      };
      return this.constructor.canUseContentEditable ? (a.userSuggestions = this.userSuggestions, new this.constructor.ContentEditableView(a)) : new this.constructor.TextareaView(a)
    },
    getPostParams: function (c) {
      var d = a.Deferred(),
      e = y.getPostParams.call(this);
      return b.isString(c) && (e.raw_message = c),
      g.isFeatureActive('before_comment_callback', {
        forum: this.thread.forum.id
      }) ? (f.frame.sendHostMessage('posts.beforeCreate', {
        raw_message: e.raw_message
      }), this.listenToOnce(f.frame, 'posts.beforeCreate.response', function (a) {
        a && (e.raw_message = a),
        d.resolve(e)
      })) : d.resolve(e),
      d.promise()
    },
    getAuthorParams: function () {
      return this.session.isLoggedIn() ? {
        author_id: this.session.user.id
      }
       : {
        author_name: this.loginFormView.getDisplayName(),
        author_email: this.loginFormView.getEmail()
      }
    },
    initiatePost: function (a) {
      var c = b.bind(this.createPost, this);
      this.getPostParams(a).done(c)
    },
    shouldAbortCreatePost: function (a, c) {
      return this.constructor.mustVerifyEmailToPost(this.session.user, this.thread.forum) ? (this.session.fetch().always(b.bind(function () {
        this.constructor.mustVerifyEmailToPost(this.session.user, this.thread.forum) ? this._alertMustVerify(!0) : this.createPost(c)
      }, this)), !0) : y.shouldAbortCreatePost.call(this, a, c)
    },
    _onCreateError: function (a, b) {
      y._onCreateError.call(this, a, b),
      this.thread.incrementPostCount( - 1)
    },
    _onCreateSync: function (a, c) {
      y._onCreateSync.call(this, a, c),
      this.thread.posts.saveToCache(c),
      this.isEmbedV2Enabled && this.loadEditorV2(b.extend({
        clearDraft: !0
      }, this.getEditorProps()))
    },
    addPostToThread: function (a) {
      this.thread.incrementPostCount(1),
      this.thread.posts.add(a)
    },
    remove: function () {
      return this.loginFormView && (this.loginFormView.remove(), this.loginFormView = null),
      y.remove.call(this)
    },
    _submitForm: function (a, b) {
      return this.dismissAlert(),
      this.loginFormView.shouldRegisterUser() ? void this.loginFormView.registerUser() : this.initiatePost(b)
    },
    submitForm: w(function (a, c) {
      if (this.isEmbedV2Enabled && !b.isString(c)) {
        var d = this.$el.find('[data-role=textarea] button[type=button]');
        return void d.trigger('click')
      }
      return this._submitForm(a, c)
    })
  }, {
    ContentEditableView: p,
    User: i.User,
    Post: i.Post
  });
  return n.asRealtimeTyping(z.prototype),
  m.call(z.prototype),
  k.call(z.prototype),
  l.call(z.prototype),
  j.call(z.prototype),
  z
}),
define('core/constants/badgesConstants', [
  'exports'
], function (a) {
  'use strict';
  a.ACTION_TYPES = {
    AWARD: 'award',
    REMOVE: 'remove'
  },
  a.BADGES_CRITERIA = {
    MANUAL: 'MANUAL',
    COMMENTS: 'COMMENTS',
    FEATURED_COMMENTS: 'FEATURED_COMMENTS',
    COMMENT_UPVOTES: 'COMMENT_UPVOTES'
  },
  a.MAX_BADGE_COUNT = 8
}),
define('core/models/RichMediaViewModel', [
  'backbone'
], function (a) {
  'use strict';
  return a.Model.extend({
    defaults: {
      deferred: !0,
      showButtons: !0,
      activated: !1,
      kind: 'image',
      deferredHeight: 0,
      providerExpandMessage: '',
      providerCollapseMessage: '',
      providerIcon: 'icon-proceed',
      respectSettings: !0
    }
  })
}),
define('core/templates/postMediaInlineLink', [
  'handlebars',
  'core/templates/handlebars.partials',
  'core/extensions/handlebars.helpers'
], function (a) {
  return a.template({
    1: function (a, b, c, d, e) {
      var f;
      return null != (f = c['if'].call(null != b ? b : a.nullContext || {
      }, null != b ? b.hasUserText : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(2, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 2,
            column: 0
          },
          end: {
            line: 5,
            column: 7
          }
        }
      })) ? f : ''
    },
    2: function (a, b, c, d, e) {
      var f = a.lambda,
      g = a.escapeExpression;
      return '<a href="' + g(f(null != b ? b.href : b, b)) + '" rel="nofollow">' + g(f(null != b ? b.text : b, b)) + '</a>\n'
    },
    4: function (a, b, c, d, e) {
      var f,
      g = a.lambda,
      h = a.escapeExpression,
      i = null != b ? b : a.nullContext || {
      };
      return '<a href="' + h(g(null != b ? b.href : b, b)) + '" class="post-media-link" data-action="expand-collapse-media" rel="nofollow">' + (null != (f = c['if'].call(i, null != (f = null != b ? b.model : b) ? f.providerIcon : f, {
        name: 'if',
        hash: {
        },
        fn: a.program(5, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 10,
            column: 3
          },
          end: {
            line: 10,
            column: 74
          }
        }
      })) ? f : '') + h(g(null != b ? b.mediaLinkText : b, b)) + (null != (f = c['if'].call(i, null != b ? b.domain : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(7, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 14,
            column: 3
          },
          end: {
            line: 14,
            column: 87
          }
        }
      })) ? f : '') + '</a>\n'
    },
    5: function (a, b, c, d, e) {
      var f;
      return '<i class="' + a.escapeExpression(a.lambda(null != (f = null != b ? b.model : b) ? f.providerIcon : f, b)) + '"></i>'
    },
    7: function (a, b, c, d, e) {
      return '<span class="post-media-link-domain"> &mdash; ' + a.escapeExpression(a.lambda(null != b ? b.domain : b, b)) + '</span>'
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f;
      return null != (f = c['if'].call(null != b ? b : a.nullContext || {
      }, null != (f = null != b ? b.model : b) ? f.deferred : f, {
        name: 'if',
        hash: {
        },
        fn: a.program(1, e, 0),
        inverse: a.program(4, e, 0),
        data: e,
        loc: {
          start: {
            line: 1,
            column: 0
          },
          end: {
            line: 16,
            column: 7
          }
        }
      })) ? f : ''
    },
    useData: !0
  })
}),
define('core/views/RichMediaLinkView', [
  'backbone',
  'core/utils',
  'core/templates/postMediaInlineLink'
], function (a, b, c) {
  'use strict';
  return a.View.extend({
    tagName: 'span',
    events: {
      'click [data-action=expand-collapse-media]': 'handleToggle'
    },
    initialize: function (a) {
      this.media = a.media;
      var c = a.$link;
      this.linkText = c.text(),
      this.linkHref = c.attr('href'),
      this.linkDomain = b.getDomain(this.linkHref),
      this.linkHasUserText = this.isUserText(c),
      this.hasGenericMessage = !1,
      this.linkHasUserText ? this.mediaLinkText = this.linkText : this.media.get('title') ? this.mediaLinkText = b.niceTruncate(this.media.get('title'), 60) : (this.hasGenericMessage = !0, this.mediaLinkText = this.model.get('providerExpandMessage')),
      this.listenTo(this.model, 'change:deferred', this.render),
      this.listenTo(this.model, 'change:activated', this.onChangeActivated)
    },
    isUserText: function (a) {
      if ('A' !== a[0].nodeName) return !1;
      var b = (a.text() || '').toLowerCase();
      if (!b) return !1;
      if (0 === b.indexOf('http') || 0 === b.indexOf('www')) return !1;
      b = b.replace(/\.\.\.$/, '');
      var c = (a.attr('href') || '').toLowerCase();
      return c.indexOf(b) === - 1
    },
    render: function () {
      var a = this.mediaLinkText;
      return this.hasGenericMessage && this.model.get('activated') && (a = this.model.get('providerCollapseMessage')),
      this.$el.html(c({
        model: this.model.toJSON(),
        text: this.linkText,
        href: this.linkHref,
        mediaLinkText: a,
        domain: this.linkDomain,
        hasUserText: this.linkHasUserText
      })),
      this
    },
    onChangeActivated: function () {
      this.hasGenericMessage && this.render()
    },
    handleToggle: function (a) {
      this.model.get('deferred') || (this.model.set('activated', !this.model.get('activated')), a && a.preventDefault && a.preventDefault())
    }
  })
}),
define('core/templates/postMedia', [
  'handlebars',
  'core/templates/handlebars.partials',
  'core/extensions/handlebars.helpers'
], function (a) {
  return a.template({
    1: function (a, b, c, d, e) {
      var f;
      return (null != (f = c['if'].call(null != b ? b : a.nullContext || {
      }, null != (f = null != b ? b.media : b) ? f.providerName : f, {
        name: 'if',
        hash: {
        },
        fn: a.program(2, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 5,
            column: 26
          },
          end: {
            line: 5,
            column: 90
          }
        }
      })) ? f : '') + a.escapeExpression(a.lambda(null != (f = null != b ? b.media : b) ? f.title : f, b))
    },
    2: function (a, b, c, d, e) {
      var f;
      return a.escapeExpression(a.lambda(null != (f = null != b ? b.media : b) ? f.providerName : f, b)) + ' &ndash; '
    },
    4: function (a, b, c, d, e) {
      var f;
      return '<i class="' + a.escapeExpression(a.lambda(null != (f = null != b ? b.model : b) ? f.providerIcon : f, b)) + ' publisher-background-color"></i>'
    },
    6: function (a, b, c, d, e) {
      return 'media-video'
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f,
      g = a.lambda,
      h = a.escapeExpression,
      i = null != b ? b : a.nullContext || {
      };
      return '\n<a class="media-button media-button-expand publisher-color publisher-border-color" href="' + h(g(null != (f = null != b ? b.media : b) ? f.url : f, b)) + '" rel="nofollow" target="_blank" data-action="expand"\ntitle="' + (null != (f = c['if'].call(i, null != (f = null != b ? b.media : b) ? f.title : f, {
        name: 'if',
        hash: {
        },
        fn: a.program(1, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 5,
            column: 7
          },
          end: {
            line: 5,
            column: 112
          }
        }
      })) ? f : '') + '">\n' + (null != (f = c['if'].call(i, null != (f = null != b ? b.model : b) ? f.providerIcon : f, {
        name: 'if',
        hash: {
        },
        fn: a.program(4, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 6,
            column: 0
          },
          end: {
            line: 6,
            column: 98
          }
        }
      })) ? f : '') + '\n' + h(g(null != (f = null != b ? b.model : b) ? f.providerExpandMessage : f, b)) + '\n</a>\n<a class="media-button media-button-contract publisher-color publisher-border-color" href="#" target="_blank" data-action="contract">\n<i class="icon-cancel publisher-background-color"></i> ' + h(g(null != (f = null != b ? b.model : b) ? f.providerCollapseMessage : f, b)) + '\n</a>\n<div class="media-content-loader" data-role="content-loader"></div>\n<div data-role="content-placeholder" class="media-content-placeholder media-' + h(g(null != (f = null != b ? b.media : b) ? f.providerName : f, b)) + ' ' + (null != (f = c['if'].call(i, null != b ? b.isVideo : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(6, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 15,
            column: 99
          },
          end: {
            line: 15,
            column: 132
          }
        }
      })) ? f : '') + '"></div>\n'
    },
    useData: !0
  })
}),
define('core/templates/postMediaPlaceholder', [
  'handlebars',
  'core/templates/handlebars.partials',
  'core/extensions/handlebars.helpers'
], function (a) {
  return a.template({
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f;
      return '<a href="#" class="media-force-load" data-action="force-load"><i class="' + a.escapeExpression(a.lambda(null != (f = null != b ? b.model : b) ? f.providerIcon : f, b)) + '"></i></a>\n'
    },
    useData: !0
  })
}),
define('core/constants/mediaTypeConstants', [
  'exports'
], function (a) {
  'use strict';
  a.VIDEO_CODES = [
    '3',
    '9',
    '12',
    '14'
  ]
}),
define('core/views/RichMediaView', [
  'jquery',
  'underscore',
  'backbone',
  'core/utils',
  'core/mediaConfig',
  'core/views/RichMediaLinkView',
  'core/templates/postMedia',
  'core/templates/postMediaPlaceholder',
  'core/constants/mediaTypeConstants'
], function (a, b, c, d, e, f, g, h, i) {
  'use strict';
  var j = d.preventDefaultHandler,
  k = function (a, b, c, d) {
    a[b.get(c) ? 'addClass' : 'removeClass'](d)
  };
  return c.View.extend({
    className: 'media-container',
    events: {
      'click [data-action=expand]': 'handleExpand',
      'click [data-action=contract]': 'handleContract',
      'click [data-action=force-load]': 'handleForceLoad'
    },
    template: g,
    initialize: function (a) {
      this.options = a,
      this.media = a.media,
      this.template = a.template || this.template,
      this.$linkEl = null,
      this.setupMode(),
      this.listenTo(this.model, 'change:activated', this.applyState),
      this.listenTo(this.model, 'change:deferredHeight', this.onChangeDeferredHeight),
      this.listenTo(this.model, 'change:showButtons', this.updateElementClass),
      this.listenTo(this.model, 'change:deferred', this.render),
      this.listenTo(e, 'change:collapsed', this.setupMode)
    },
    getMediaDimensions: function () {
      return {
        width: null,
        height: null
      }
    },
    getAvailableWidth: function () {
      return this.$el.parent().width() || e.get('loadedThumbnailWidth')
    },
    updateDeferredHeight: function () {
      this.model.set('deferredHeight', this.calculateDeferredHeight())
    },
    calculateDeferredHeight: function () {
      var a = this.getMediaDimensions(),
      b = a.width,
      c = a.height;
      if (!b || !c) return c;
      var d = this.getAvailableWidth(),
      e = d * c / b;
      return e
    },
    convertToButton: function (a) {
      this.model.set('showButtons', !1),
      this.linkSubview && this.linkSubview.remove(),
      this.linkSubview = new f({
        model: this.model,
        media: this.media,
        $link: a
      }),
      a.replaceWith(this.linkSubview.$el),
      this.linkSubview.render()
    },
    applyContentNodeHeight: function (a) {
      this.contentNode.height(a || 'auto')
    },
    shouldAutoplay: function () {
      return !this.model.get('deferred')
    },
    generateContentHtml: function () {
      return this.media.get('html')
    },
    createContentNode: function (b) {
      return a(b)
    },
    insertContentNode: function (a) {
      this.contentNode.html(a)
    },
    prepareElementEvents: function () {
    },
    displayContent: function () {
      this.updateDeferredHeight();
      var a = this.generateContentHtml(),
      b = this.createContentNode(a);
      this.prepareElementEvents(b),
      this.insertContentNode(b),
      this.applyContentNodeHeight(null)
    },
    configureDeferred: function () {
      this.enterViewport()
    },
    configureContentFromActivated: function () {
      this.model.get('activated') ? this.displayContent() : this.displayPlaceholder()
    },
    displayPlaceholder: function () {
      this.contentNode.html(h({
        model: this.model.toJSON()
      }))
    },
    updateElementClass: function () {
      var a = this.$el,
      b = this.model;
      k(a, b, 'deferred', 'media-mode-deferred'),
      k(a, b, 'activated', 'media-activated'),
      k(a, b, 'showButtons', 'media-show-buttons')
    },
    applyState: function () {
      this.configureDeferred(),
      this.configureContentFromActivated(),
      this.updateElementClass()
    },
    render: function () {
      return this.$el.html(this.template({
        model: this.model.toJSON(),
        media: this.media.toJSON(),
        isVideo: b.contains(i.VIDEO_CODES, this.media.get('mediaType'))
      })),
      this.contentNode = this.$el.find('[data-role=content-placeholder]'),
      this.applyState(),
      this
    },
    remove: function () {
      this.linkSubview && this.linkSubview.remove(),
      c.View.prototype.remove.apply(this, arguments)
    },
    enterViewport: function () {
      this.model.get('deferred') && this.activate()
    },
    activate: function () {
      this.model.set('activated', !0)
    },
    setupMode: function () {
      if (this.model.get('respectSettings')) {
        this.model.set('activated', !1);
        var a = e.get('collapsed');
        a ? this.model.set('deferred', !1) : this.model.set('deferred', !0)
      }
    },
    onChangeDeferredHeight: function () {
      this.model.get('deferred') && !this.model.get('activated') && this.applyContentNodeHeight(this.model.get('deferredHeight'))
    },
    handleExpand: j(function () {
      this.model.set('activated', !0)
    }),
    handleContract: j(function () {
      this.model.set('activated', !1)
    }),
    handleForceLoad: j(function () {
      this.model.get('deferred') && this.model.set('activated', !0)
    })
  })
}),
define('core/templates/postMediaImage', [
  'handlebars',
  'core/templates/handlebars.partials',
  'core/extensions/handlebars.helpers'
], function (a) {
  return a.template({
    1: function (a, b, c, d, e) {
      return '<video src="' + a.escapeExpression(a.lambda(null != b ? b.thumbnailUrl : b, b)) + '" autoplay muted loop></video>\n'
    },
    3: function (a, b, c, d, e) {
      var f,
      g = a.escapeExpression,
      h = null != b ? b : a.nullContext || {
      };
      return '<img src="' + g(a.lambda(null != b ? b.thumbnailUrl : b, b)) + '" alt="' + g(c.gettext.call(h, 'Thumbnail', {
        name: 'gettext',
        hash: {
        },
        data: e,
        loc: {
          start: {
            line: 6,
            column: 33
          },
          end: {
            line: 6,
            column: 56
          }
        }
      })) + '" ' + (null != (f = c['if'].call(h, null != (f = null != b ? b.model : b) ? f.deferredHeight : f, {
        name: 'if',
        hash: {
        },
        fn: a.program(4, e, 0),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 6,
            column: 58
          },
          end: {
            line: 6,
            column: 128
          }
        }
      })) ? f : '') + '>\n'
    },
    4: function (a, b, c, d, e) {
      var f;
      return ' height="' + a.escapeExpression(a.lambda(null != (f = null != b ? b.model : b) ? f.deferredHeight : f, b)) + '" '
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f;
      return '<a href="' + a.escapeExpression(a.lambda(null != b ? b.imageUrl : b, b)) + '" target="_blank" rel="nofollow">\n' + (null != (f = c['if'].call(null != b ? b : a.nullContext || {
      }, null != b ? b.isVideo : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(1, e, 0),
        inverse: a.program(3, e, 0),
        data: e,
        loc: {
          start: {
            line: 3,
            column: 0
          },
          end: {
            line: 7,
            column: 8
          }
        }
      })) ? f : '') + '</a>\n'
    },
    useData: !0
  })
}),
define('core/views/ImageRichMediaView', [
  'core/views/RichMediaView',
  'core/models/Media',
  'core/utils',
  'core/config',
  'core/mediaConfig',
  'core/templates/postMediaImage'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = new RegExp('(^|\\.)' + c.getDomain(d.urls.media).split('.').slice( - 2).join('\\.') + '$');
  return a.extend({
    getMediaDimensions: function () {
      return {
        width: this.media.get('thumbnailWidth'),
        height: this.media.get('thumbnailHeight')
      }
    },
    getImageUrl: function () {
      return this.media.get('resolvedUrlRedirect') || this.media.get('urlRedirect') || this.media.get('thumbnailUrl')
    },
    getImageThumbnailUrl: function () {
      var a = this.media.get('thumbnailUrl');
      return this.constructor.isOnDisqusCDN(a) && !this.isVideo() && (a = c.serialize(a, {
        w: e.get('loadedThumbnailWidth'),
        h: this.model.get('deferredHeight')
      })),
      a
    },
    isVideo: function () {
      return this.media.get('mediaType') === b.MEDIA_TYPES.MP4_VIDEO
    },
    generateContentHtml: function () {
      return f({
        model: this.model.toJSON(),
        media: this.media.toJSON(),
        thumbnailUrl: this.getImageThumbnailUrl(),
        imageUrl: this.getImageUrl(),
        isVideo: this.isVideo()
      })
    },
    prepareElementEvents: function (a) {
      var b = this,
      c = a.find('img');
      c.on('load.richMediaView error.richMediaView', function (a) {
        b.trigger(a.type),
        c.off('.richMediaView')
      })
    },
    calculateDeferredHeight: function () {
      var b = Math.floor(a.prototype.calculateDeferredHeight.apply(this, arguments)),
      c = this.getMediaDimensions().height;
      return Math.min(c, b) || null
    }
  }, {
    isOnDisqusCDN: function (a) {
      var b = c.getDomain(a);
      return g.test(b)
    }
  })
}),
define('core/views/IframeRichMediaView', [
  'underscore',
  'core/mediaConfig',
  'core/views/RichMediaView'
], function (a, b, c) {
  'use strict';
  return c.extend({
    getMediaDimensions: function () {
      return {
        width: this.media.get('htmlWidth'),
        height: this.media.get('htmlHeight')
      }
    },
    _findIframe: function (a) {
      return a.is('iframe') ? a : a.find('iframe')
    },
    configureContentFromActivated: function () {
      c.prototype.configureContentFromActivated.apply(this, arguments),
      this.model.get('activated') || this.$el.removeClass('media-loading')
    },
    createContentNode: function () {
      var a = c.prototype.createContentNode.apply(this, arguments);
      return a.attr({
        width: '100%',
        height: this.model.get('deferredHeight')
      }),
      a
    },
    insertContentNode: function (a) {
      this.loaderNode = this.$el.find('[data-role=content-loader]'),
      this.loaderHeight = this.model.get('deferredHeight') || b.get('defaultIframeHeight'),
      this.loaderNode.height(this.loaderHeight),
      this.$el.addClass('media-loading'),
      c.prototype.insertContentNode.call(this, a)
    },
    prepareElementEvents: function (b) {
      var c = this._findIframe(b);
      c.one('load', a.bind(this.finishLoad, this, c))
    },
    finishLoad: function (a) {
      this.$el.removeClass('media-loading'),
      a.height(this.loaderHeight),
      this.trigger('load')
    }
  })
}),
define('core/views/FacebookPhotoRichMediaView', [
  'core/views/ImageRichMediaView'
], function (a) {
  'use strict';
  return a.extend({
    getImageThumbnailUrl: function () {
      return this.media.get('metadata').imageUrl || a.prototype.getImageThumbnailUrl.call(this)
    }
  })
}),
define('core/views/AutoplayRichMediaView', [
  'underscore',
  'jquery',
  'core/utils',
  'core/views/IframeRichMediaView'
], function (a, b, c, d) {
  'use strict';
  return d.extend({
    createContentNode: function () {
      var a = d.prototype.createContentNode.apply(this, arguments),
      b = a.attr('src');
      return this.shouldAutoplay() && b && !this.model.get('playerjs') && (b = c.serialize(b, {
        auto_play: !0,
        autoplay: 1
      }), a.attr('src', b)),
      a
    },
    insertContentNode: function (c) {
      if (this.model.get('playerjs')) {
        var e = this._findIframe(c),
        f = e.attr('src');
        '//' === f.substr(0, 2) && (f = window.location.protocol + f);
        var g = f.split('/');
        g = g[0] + '//' + g[2],
        this.playerjs = {
          ready: !1,
          queue: [
          ],
          origin: g,
          $iframe: e
        },
        this.model.get('mute') && this.send('mute'),
        this.shouldAutoplay() && this.send('play');
        var h = a.once(a.bind(function () {
          this.playerjs.ready = !0;
          var b = this.playerjs.queue;
          this.playerjs.queue = [
          ],
          a.each(b, this.send, this)
        }, this));
        b(window).on('message', function (a) {
          if (a = a.originalEvent, a.origin === g) {
            var b;
            try {
              b = JSON.parse(a.data)
            } catch (c) {
              return
            }
            'ready' === b.event && b.value && b.value.src === f && h()
          }
        })
      }
      return d.prototype.insertContentNode.apply(this, arguments)
    },
    send: function (a) {
      if (this.playerjs) {
        if (!this.playerjs.ready) return void this.playerjs.queue.push(a);
        var b = {
          context: 'player.js',
          version: '0.0.10',
          method: a
        };
        this.playerjs.$iframe[0].contentWindow.postMessage(JSON.stringify(b), this.playerjs.origin)
      }
    }
  })
}),
define('core/views/DynamicHeightRichMediaView', [
  'underscore',
  'core/views/RichMediaView'
], function (a, b) {
  'use strict';
  return b.extend({
    insertContentNode: function () {
      b.prototype.insertContentNode.apply(this, arguments),
      this.finishLoad()
    },
    finishLoad: function () {
      var b = this,
      c = 0,
      d = 150,
      e = 20,
      f = function () {
        c += 1,
        c < e ? a.delay(f, d) : b.trigger('load')
      };
      f()
    }
  })
}),
define('core/templates/postMediaTwitterContent', [
  'handlebars',
  'core/templates/handlebars.partials',
  'core/extensions/handlebars.helpers'
], function (a) {
  return a.template({
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e) {
      var f = a.lambda,
      g = a.escapeExpression;
      return '<meta name="twitter:widgets:csp" content="on">\n<blockquote class="twitter-tweet" data-theme="' + g(f(null != b ? b.theme : b, b)) + '" data-link-color="' + g(f(null != b ? b.linkColor : b, b)) + '" lang="' + g(f(null != b ? b.language : b, b)) + '">\n<a href="' + g(f(null != b ? b.url : b, b)) + '"></a>\n</blockquote>\n<script src="//platform.twitter.com/widgets.js"></script>\n'
    },
    useData: !0
  })
}),
define('core/views/TwitterRichMediaView', [
  'underscore',
  'core/views/DynamicHeightRichMediaView',
  'core/templates/postMediaTwitterContent'
], function (a, b, c) {
  'use strict';
  var d = b.extend({
    generateContentHtml: function () {
      var b = window.document.documentElement.lang;
      b = b && b.substring(0, 2);
      var e = this.media.get('url');
      return this.media.get('resolvedUrl').indexOf('/status') !== - 1 && (e = this.media.get('resolvedUrl')),
      c({
        url: e,
        theme: a.result(d, 'theme'),
        linkColor: a.result(d, 'linkColor'),
        language: b
      })
    }
  }, {
    theme: 'light',
    linkColor: '#2e9fff'
  });
  return d
}),
define('core/views/SoundCloudRichMediaView', [
  'core/views/AutoplayRichMediaView'
], function (a) {
  'use strict';
  return a.extend({
    getMediaDimensions: function () {
      return {
        width: null,
        height: this.media.get('htmlHeight')
      }
    }
  })
}),
define('core/views/VineRichMediaView', [
  'core/views/AutoplayRichMediaView',
  'core/utils'
], function (a, b) {
  'use strict';
  return a.extend({
    createContentNode: function () {
      var c = a.prototype.createContentNode.apply(this, arguments),
      d = c.attr('src');
      return this.shouldAutoplay() && d && (d = b.serialize(d, {
        audio: 1
      }), c.attr('src', d)),
      c
    }
  })
}),
define('core/views/IframeGifRichMediaView', [
  'core/views/IframeRichMediaView'
], function (a) {
  'use strict';
  return a.extend({
    insertContentNode: function (b) {
      a.prototype.insertContentNode.call(this, b),
      this.loaderNode.width(this.getMediaDimensions().width)
    },
    createContentNode: function () {
      var b = a.prototype.createContentNode.apply(this, arguments);
      return b.attr(this.getMediaDimensions()),
      b
    },
    calculateDeferredHeight: function () {
      return this.getMediaDimensions().height
    },
    displayPlaceholder: function () {
      a.prototype.displayPlaceholder.call(this);
      var b = this.getMediaDimensions();
      this.contentNode.height(b.height).width(b.width)
    }
  })
}),
define('core/media', [
  'underscore',
  'core/strings',
  'core/models/Media',
  'core/models/RichMediaViewModel',
  'core/views/ImageRichMediaView',
  'core/views/IframeRichMediaView',
  'core/views/FacebookPhotoRichMediaView',
  'core/views/AutoplayRichMediaView',
  'core/views/TwitterRichMediaView',
  'core/views/SoundCloudRichMediaView',
  'core/views/VineRichMediaView',
  'core/views/IframeGifRichMediaView'
], function (a, b, c, d, e, f, g, h, i, j, k, l) {
  'use strict';
  var m = b.get,
  n = {
    PLAY_HIDE: {
      kind: 'html',
      providerExpandMessage: m('Play'),
      providerCollapseMessage: m('Hide')
    },
    VIEW_HIDE: {
      kind: 'html',
      providerExpandMessage: m('View'),
      providerCollapseMessage: m('Hide')
    },
    VIEW_IMAGE: {
      kind: 'image',
      providerIcon: 'icon-images',
      providerExpandMessage: m('View'),
      providerCollapseMessage: m('Hide')
    }
  },
  o = function (b) {
    var m = function (b, c) {
      return a.defaults({
        providerIcon: c
      }, n[b])
    },
    o = null,
    p = null,
    q = c.MEDIA_TYPES;
    switch (b.get('mediaType')) {
      case q.IMAGE:
      case q.IMAGE_UPLOAD:
      case q.MP4_VIDEO:
        o = n.VIEW_IMAGE;
        break;
      case q.FACEBOOK_PHOTO:
        p = g,
        o = n.VIEW_IMAGE;
        break;
      case q.GIF_VIDEO:
        p = l,
        o = n.VIEW_HIDE;
        break;
      case q.VIMEO_VIDEO:
      case q.YOUTUBE_VIDEO:
        p = h,
        o = m('PLAY_HIDE', 'icon-video');
        break;
      case q.TWITTER_STATUS:
        p = i,
        o = m('VIEW_HIDE', 'icon-twitter-x');
        break;
      case q.VINE_VIDEO:
        p = k,
        o = m('PLAY_HIDE', 'icon-video');
        break;
      case q.FACEBOOK_VIDEO:
        o = m('VIEW_HIDE', 'icon-video');
        break;
      case q.SOUNDCLOUD_SOUND:
        p = j,
        o = m('PLAY_HIDE', 'icon-music');
        break;
      case q.GOOGLE_MAP:
        o = m('VIEW_HIDE', 'icon-map');
        break;
      default:
        return null
    }
    if (null === p) switch (o.kind) {
      case 'webpage':
        return null;
      case 'html':
        p = f;
        break;
      case 'image':
        p = e
    }
    var r = new d(o);
    return {
      Cls: p,
      mediaViewModel: r
    }
  },
  p = function (a) {
    var b = o(a);
    return b ? new b.Cls({
      model: b.mediaViewModel,
      media: a
    }) : null
  },
  q = function (a) {
    return new e({
      model: new d(n.VIEW_IMAGE),
      media: a
    })
  };
  return {
    instantiateRichMediaView: p,
    instantiateRichMediaThumbnail: q,
    getRichMediaViewConfig: o
  }
}),
define('core/mixins/withRichMedia', [
  'underscore',
  'jquery',
  'core/collections/MediaCollection',
  'core/media'
], function (a, b, c, d) {
  'use strict';
  function e(a) {
    var c = {
    };
    return a.length ? (a.find('a').each(function (a, d) {
      var e = d.href;
      c[e] || (c[e] = b(d))
    }), c) : c
  }
  function f() {
    a.extend(this, g)
  }
  var g = {
    renderRichMedia: function (a, f, g) {
      return g = g || {
      },
      a = a instanceof c ? a : new c(a),
      a.chain().map(function (a) {
        return d.instantiateRichMediaView(a)
      }).without(null).map(function (a) {
        var c = a.media.get('urlRedirect');
        g.normalize && (c = g.normalize.call(this, c));
        var d = e(this.$('[data-role=message]')),
        h = d[c];
        return g.beforeRender && g.beforeRender.call(this, a),
        a.render(),
        h ? g.convertLinkToButton ? (h.after(a.$el), a.convertToButton(h)) : h.replaceWith(a.$el) : (f = f || this.$('[data-role=post-media-list]'), f.append(b('<li>').append(a.$el))),
        a
      }, this).value()
    }
  };
  return f
}),
define('core/views/common/HoverCard', [
  'jquery',
  'underscore',
  'backbone',
  'core/bus'
], function (a, b, c, d) {
  'use strict';
  var e = c.View.extend({
    events: {
      mouseenter: 'enter',
      mouseleave: 'leave'
    },
    initialize: function () {
      this._id = b.uniqueId(),
      this._rendered = !1,
      this._hoverState = 'out',
      this._visible = !1,
      this._enterTimeout = null,
      this._leaveTimeout = null,
      e.open = {
      },
      this.events = this.events || {
      },
      this.events['click [data-action=profile]'] = 'handleShowProfile',
      this.listenTo(this, 'authenticating', this.keepOpen)
    },
    render: function () {
      return this.hide(),
      a('body').append(this.el),
      this
    },
    target: function (a) {
      a.on('mouseenter', b.bind(this.enter, this, a)),
      a.on('mouseleave', b.bind(this.leave, this))
    },
    enter: function (a) {
      var c = this;
      a.originalEvent && (a = null),
      a && (c.$target = a),
      c._leaveTimeout && clearTimeout(c._leaveTimeout),
      'in' !== c._hoverState && (c._hoverState = 'in', c._enterTimeout = b.delay(function () {
        'in' === c._hoverState && c.show(),
        c._enterTimeout = null
      }, e.DELAY_ENTER), e.open[this.uid] = this)
    },
    leave: function () {
      var a = this;
      a._enterTimeout && clearTimeout(a._enterTimeout),
      'out' !== a._hoverState && (a._hoverState = 'out', a._leaveTimeout = b.delay(function () {
        'out' === a._hoverState && a.hide(),
        a._leaveTimeout = null
      }, e.DELAY_LEAVE), e.open[this.uid] && delete e.open[this.uid])
    },
    show: function () {
      var a = this;
      a._rendered || (a._rendered = !0, a.render()),
      a.moveTo(a.$target),
      a.$el.show(),
      a._visible = !0,
      a.trigger('show')
    },
    moveTo: function (a) {
      if (a) {
        var b = e.POSITION_OFFSET,
        c = a.offset(),
        d = this.$el,
        f = d.height(),
        g = this.getContainerPosition();
        c.top -= b;
        var h = c.top + f + g.containerOffset.top,
        i = g.pageOffset + g.containerHeight;
        h <= i ? d.css('top', c.top) : d.css('top', c.top - f + 2 * b),
        d.css('left', c.left + b)
      }
    },
    getContainerPosition: function () {
      return {
        pageOffset: a(window).scrollTop(),
        containerOffset: {
          top: 0,
          height: a(window).height()
        },
        containerHeight: a(window).height()
      }
    },
    hide: function () {
      this._keepOpen || (this._enterTimeout && clearTimeout(this._enterTimeout), this.$el.hide(), this._visible = !1)
    },
    keepOpen: function () {
      this._keepOpen = !0,
      this.setupKeepOpenCanceler()
    },
    setupKeepOpenCanceler: function () {
      var c = this,
      e = function () {
        'out' === c._hoverState && (c.stopListening(d, 'window.click', e), a('body').off('click', e), c._keepOpen = !1, c.hide())
      };
      b.delay(function () {
        c.listenTo(d, 'window.click', e),
        a('body').on('click', e)
      }, 100)
    },
    isVisible: function () {
      return this._visible
    },
    handleShowProfile: function () {
      this.hide()
    }
  }, {
    open: {
    },
    instances: {
    },
    DELAY_ENTER: 350,
    DELAY_LEAVE: 175,
    POSITION_OFFSET: 20,
    exitAll: function () {
      b.invoke(e.open, 'leave')
    },
    create: function (a, b, c, d) {
      var f = e.instances[c];
      f || (e.instances[c] = f = {
      });
      var g = f[a];
      return g || (g = new d(b), f[a] = g),
      b.targetElement && g.target(b.targetElement),
      g
    }
  });
  return function () {
    a(window.document).on('mouseout', b.debounce(function (a) {
      var b = a.relatedTarget || a.toElement;
      b && 'HTML' !== b.nodeName || e.exitAll()
    }, 10))
  }(),
  e
}),
define('core/utils/views', [
  'underscore'
], function (a) {
  'use strict';
  var b = function (b, c, d) {
    var e = b.prototype,
    f = a.extend({
    }, c, d);
    if (a.defaults(e, f), a.defaults(e.events, f.events), void 0 !== e.initialize && void 0 !== f.initialize) {
      var g = e.initialize;
      e.initialize = function () {
        var a = g.apply(this, arguments);
        return f.initialize.apply(this, arguments),
        a
      }
    }
  };
  return {
    mixin: b
  }
}),
define('core/views/common/mixins/LocalScroll', [
], function () {
  'use strict';
  var a = {
    events: {
      mousewheel: 'handleScrollEvent',
      wheel: 'handleScrollEvent'
    },
    scrollMeasureSelector: '',
    getScrollMeasure: function () {
      return this.scrollMeasure || (this.scrollMeasure = this.$el, this.scrollMeasureSelector && (this.scrollMeasure = this.$el.find(this.scrollMeasureSelector))),
      this.scrollMeasure
    },
    handleScrollEvent: function (a) {
      var b = a.originalEvent,
      c = b.wheelDeltaY || - b.deltaY,
      d = this.$el,
      e = d.height(),
      f = this.getScrollMeasure(),
      g = f.height(),
      h = f.parent() [0].scrollTop,
      i = h >= g - e,
      j = 0 === h;
      (i && c < 0 || j && c > 0) && a.preventDefault()
    }
  };
  return a
}),
define('core/templates/usersCard', [
  'handlebars',
  'core/templates/handlebars.partials',
  'core/extensions/handlebars.helpers'
], function (a) {
  return a.template({
    1: function (a, b, c, d, e) {
      return 'guests-only'
    },
    3: function (a, b, c, d, e) {
      return 'tooltip--post-refresh'
    },
    5: function (a, b, c, d, e, f, g) {
      var h;
      return null != (h = c.each.call(null != b ? b : a.nullContext || {
      }, null != b ? b.users : b, {
        name: 'each',
        hash: {
        },
        fn: a.program(6, e, 0, f, g),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 5,
            column: 0
          },
          end: {
            line: 7,
            column: 9
          }
        }
      })) ? h : ''
    },
    6: function (a, b, c, d, e, f, g) {
      var h;
      return null != (h = a.invokePartial(d.cardUser, b, {
        name: 'cardUser',
        hash: {
          isRefreshEnabled: null != g[1] ? g[1].isRefreshEnabled : g[1],
          forumId: null != g[1] ? g[1].forumId : g[1],
          highlight: null != g[1] ? g[1].highlight : g[1]
        },
        data: e,
        helpers: c,
        partials: d,
        decorators: a.decorators
      })) ? h : ''
    },
    8: function (a, b, c, d, e) {
      return 'tooltip-point--refresh'
    },
    compiler: [
      8,
      '>= 4.3.0'
    ],
    main: function (a, b, c, d, e, f, g) {
      var h,
      i = null != b ? b : a.nullContext || {
      };
      return '<div class="tooltip-wrapper">\n<div class="tooltip voters ' + (null != (h = c.unless.call(i, null != (h = null != b ? b.users : b) ? h.length : h, {
        name: 'unless',
        hash: {
        },
        fn: a.program(1, e, 0, f, g),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 2,
            column: 27
          },
          end: {
            line: 2,
            column: 73
          }
        }
      })) ? h : '') + ' ' + (null != (h = c['if'].call(i, null != b ? b.isRefreshEnabled : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(3, e, 0, f, g),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 2,
            column: 74
          },
          end: {
            line: 2,
            column: 126
          }
        }
      })) ? h : '') + '">\n<ul class="scroll-measure" data-role="content">\n' + (null != (h = c['if'].call(i, null != (h = null != b ? b.users : b) ? h.length : h, {
        name: 'if',
        hash: {
        },
        fn: a.program(5, e, 0, f, g),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 4,
            column: 0
          },
          end: {
            line: 8,
            column: 7
          }
        }
      })) ? h : '') + '</ul>\n</div>\n</div>\n<div class="tooltip-point hidden ' + (null != (h = c['if'].call(i, null != b ? b.isRefreshEnabled : b, {
        name: 'if',
        hash: {
        },
        fn: a.program(8, e, 0, f, g),
        inverse: a.noop,
        data: e,
        loc: {
          start: {
            line: 12,
            column: 33
          },
          end: {
            line: 12,
            column: 86
          }
        }
      })) ? h : '') + '"></div>\n'
    },
    usePartial: !0,
    useData: !0,
    useDepths: !0
  })
}),
define('core/views/UsersCard', [
  'jquery',
  'underscore',
  'handlebars',
  'core/config',
  'core/bus',
  'core/utils/views',
  'core/switches',
  'core/utils',
  'core/views/common/HoverCard',
  'core/views/common/mixins/LocalScroll',
  'core/templates/usersCard'
], function (a, b, c, d, e, f, g, h, i, j, k) {
  'use strict';
  var l = function (a) {
    return a.get('isAnonymous') || a.get('isBlocked') || a.get('isBlocking')
  },
  m = i.extend({
    guestTextPartialName: 'cardOtherUserText',
    initialize: function (a) {
      this.isRefreshEnabled = a.isRefreshEnabled,
      this.$el.attr('class', this.isRefreshEnabled ? 'tooltip-outer voters-outer voters-outer--refresh' : 'tooltip-outer voters-outer'),
      i.prototype.initialize.call(this, a),
      this.collection = this.collection || a.collection,
      this.session = a.session,
      this.numUsers = a.numUsers,
      this.voteType = a.voteType,
      this.listenTo(this.collection, 'add', this.addUser),
      this.listenTo(this.collection, 'change:isBlocked', this.render),
      this.listenTo(this.collection, 'remove', this.removeUser),
      this.listenTo(this.collection, 'reset', this.render)
    },
    addUser: function (a) {
      l(a) ? this.updateGuests() : this.$listEl && this.$listEl.length && (this.$listEl.prepend(c.partials.cardUser(this.getUserTemplateData(a))), this.stopHighlightUsername())
    },
    removeUser: function (a) {
      if (l(a)) this.updateGuests();
       else {
        var b = this.$el.find('[data-username=' + a.get('username') + ']');
        b.length && b.remove()
      }
    },
    stopHighlightUsername: b.debounce(function () {
      var a = this.$el.find('.highlight');
      a.removeClass('highlight')
    }, 1100),
    getGuestCount: function () {
      return Math.max(this.numUsers - this.collection.reject(l).length, 0)
    },
    updateGuests: function () {
      var a = this.$el.find('[data-role=guest]'),
      b = this.getGuestCount(),
      e = c.partials[this.guestTextPartialName]({
        guestCount: b
      }),
      f = {
        guestCount: b,
        guestAvatarUrl: d.urls.avatar.generic,
        highlight: a.length,
        guestText: e,
        isRefreshEnabled: this.isRefreshEnabled
      },
      g = c.partials.cardGuestUser(f);
      a.length ? (a.replaceWith(g), this.stopHighlightUsername()) : this.$listEl && this.$listEl.length && this.$listEl.append(g)
    },
    getTemplateData: function () {
      var a = b.invoke(this.collection.reject(l), 'toJSON').map(function (a) {
        return a.initials = h.getInitials(a.name || ''),
        a
      });
      return {
        users: a,
        highlight: !1,
        isRefreshEnabled: this.isRefreshEnabled
      }
    },
    getUserTemplateData: function (a) {
      var c = a.toJSON();
      return c.initials = h.getInitials(c.name || ''),
      b.extend({
        highlight: !0,
        isRefreshEnabled: this.isRefreshEnabled
      }, c)
    },
    render: function () {
      delete this.pointEl,
      this.$el.html(k(this.getTemplateData())),
      i.prototype.render.call(this),
      this.$listEl = this.$el.find('.voters ul'),
      this.updateGuests()
    },
    show: function () {
      this.numUsers && !this.isVisible() && (i.prototype.show.call(this), e.trigger('uiAction:userCardShow'))
    },
    showPoint: function (a) {
      var c = [
        'tl',
        'bl'
      ],
      d = this.$el.find('.tooltip--post-refresh'),
      e = this.$el.find('.tooltip-wrapper');
      this.pointEl || (this.pointEl = this.$el.find('.tooltip-point'), this.pointEl.removeClass('hidden')),
      b.each(c, function (a) {
        this.pointEl.removeClass('point-position-' + a),
        d.removeClass('tooltip--' + a),
        e.removeClass('tooltip-wrapper--' + a)
      }, this),
      this.pointEl.addClass('point-position-' + a),
      d.addClass('tooltip--' + a),
      e.addClass('tooltip-wrapper--' + a)
    },
    moveTo: function (a, b) {
      if (a) {
        var c = i.POSITION_OFFSET,
        d = a.offset(),
        e = this.$el,
        f = e.height(),
        g = a.outerWidth(),
        h = this.getContainerPosition();
        b && (f += e.find('li.user').height() + 10),
        d.top - f - c >= 0 && d.top - f + h.containerOffset.top >= h.pageOffset ? (e.css({
          bottom: h.containerOffset.height - d.top + c,
          top: 'inherit'
        }), this.showPoint('bl')) : (e.css({
          bottom: 'inherit',
          top: d.top + 2 * c
        }), this.showPoint('tl')),
        'rtl' === window.document.documentElement.dir ? e.css('right', d.left ? h.containerOffset.width - d.left - g - c : 0) : e.css('left', d.left - c)
      }
    },
    handleShowProfile: function (b) {
      i.prototype.handleShowProfile.call(this, b);
      var c = a(b.currentTarget),
      d = c.attr('data-username');
      e.trigger('uiCallback:showProfile', d, b)
    }
  }, {
    create: function (a, b) {
      return i.create(a, b, 'UsersCard', m)
    }
  });
  return f.mixin(m, j, {
    scrollMeasureSelector: '[data-role=content]'
  }),
  m
}),
define('core/views/VotersCard', [
  'underscore',
  'core/views/common/HoverCard',
  'core/views/UsersCard',
  'core/switches',
  'core/utils'
], function (a, b, c, d, e) {
  'use strict';
  var f = e.preventDefaultHandler,
  g = c.extend({
    guestTextPartialName: 'cardGuestVoterText',
    initialize: function (b) {
      this.voteType = b.voteType;
      var d = b.model,
      e = 1 === this.voteType ? d.getUpvotersUserCollection() : d.getDownvotersUserCollection();
      a.extend(b, {
        collection: e,
        numUsers: 1 === this.voteType ? d.get('likes') : d.get('dislikes')
      }),
      c.prototype.initialize.call(this, b),
      this.model = d,
      this.session = b.session,
      this.likes = d.get('likes'),
      this.dislikes = d.get('dislikes'),
      this.hadLikes = Boolean(this.likes),
      this.hadDislikes = Boolean(this.dislikes),
      this.isRefreshEnabled = b.isRefreshEnabled,
      this._fetched = !1,
      this._rendered = !1,
      this.listenTo(this.model, 'change:userScore', this.updateUserSet),
      1 === this.voteType ? this.listenTo(this.model, 'change:likes', this.updateGuests) : this.listenTo(this.model, 'change:dislikes', this.updateGuests)
    },
    updateGuests: function () {
      this.numUsers = (1 === this.voteType ? this.model.get('likes') : this.model.get('dislikes')) || 0,
      c.prototype.updateGuests.call(this)
    },
    updateUserSet: function () {
      var a = this.session.user,
      b = this.likes,
      c = this.dislikes,
      d = !1;
      this.likes = this.model.get('likes'),
      this.dislikes = this.model.get('dislikes'),
      this.model.get('userScore') === this.voteType ? (this.session.isLoggedIn() && this.collection.add(a), 1 === this.voteType && this.likes && !b || this.voteType === - 1 && this.dislikes && !c ? (this._rendered = !1, this.show()) : d = !!this.session.isLoggedOut() || Boolean((1 === this.voteType ? this.likes : this.dislikes) - 1 - this.collection.length)) : (this.collection.remove(a), (1 === this.voteType && !this.likes || this.voteType === - 1 && !this.dislikes) && this.hide()),
      this.updateGuests(),
      this.moveTo(this.$target, d)
    },
    show: function () {
      if (this.isRefreshEnabled && (b.prototype.constructor.POSITION_OFFSET = 12), !(1 === this.voteType && !this.likes || this.voteType === - 1 && !this.dislikes || this.isVisible())) {
        if ((1 === this.voteType && !this.hadLikes || this.voteType === - 1 && !this.hadDislikes) && (this._fetched = !0), !this._fetched) return void this.collection.fetch({
          vote: this.voteType
        }).done(a.bind(function () {
          this._fetched = !0,
          this.show()
        }, this));
        var d = this.session.user;
        this.model.get('userScore') === this.voteType && this.session.isLoggedIn() && !this.collection.contains(d) && this.collection.add(d),
        c.prototype.show.call(this)
      }
    },
    handleShowProfile: f(function (a) {
      c.prototype.handleShowProfile.call(this, a)
    }),
    getTemplateData: function () {
      var b = c.prototype.getTemplateData.apply(this, arguments);
      return a.extend({
      }, b, {
        forumId: this.model.get('forum')
      })
    },
    getUserTemplateData: function () {
      var b = c.prototype.getUserTemplateData.apply(this, arguments);
      return a.extend({
      }, b, {
        forumId: this.model.get('forum')
      })
    }
  }, {
    create: function (a) {
      var c = a.model;
      if (c.has('id')) return b.create([c.get('id'),
      '-',
      a.voteType].join(''), a, 'VotersCard', g)
    }
  });
  return g
}),
define('templates/lounge/contextCard', [
  'react',
  'core/strings',
  'core/utils/object/get',
  'core/utils',
  'core/switches',
  'templates/lounge/partials/profileLink'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = b.gettext,
  h = d.getInitials,
  i = function (b) {
    var d = e.isFeatureActive('embed_refresh', {
      forum: b.post.forum
    }),
    f = !c(b.post, [
      'author',
      'avatar',
      'isCustom'
    ]);
    return f && d ? a.createElement('div', {
      className: 'initials user--refresh'
    }, h(b.post.author.name)) : a.createElement('img', {
      src: c(b.post, [
        'author',
        'avatar',
        'cache'
      ], ''),
      className: 'user',
      alt: g('Avatar')
    })
  },
  j = function (b) {
    var d = e.isFeatureActive('embed_refresh', {
      forum: b.post.forum
    }),
    g = d ? 'avatar avatar--refresh' : 'avatar',
    h = d ? 'tooltip tooltip--post-refresh' : 'tooltip';
    return a.createElement('div', {
      className: h
    }, a.createElement('div', {
      className: 'notch'
    }), c(b.post, [
      'author',
      'isAnonymous'
    ]) ? a.createElement('div', {
      className: g
    }, a.createElement(i, {
      post: b.post
    })) : a.createElement(f, {
      className: g,
      user: c(b.post, [
        'author'
      ]),
      forumId: b.post.forum
    }, a.createElement(i, {
      post: b.post
    })), a.createElement('div', {
      className: 'tooltip__content'
    }, a.createElement('h3', null, c(b.post, [
      'author',
      'isAnonymous'
    ]) ? a.createElement('h3', null, c(b.post, [
      'author',
      'name'
    ], null)) : a.createElement(f, {
      user: c(b.post, [
        'author'
      ]),
      forumId: b.post.forum
    }, a.createElement('h3', null, c(b.post, [
      'author',
      'name'
    ], null)))), a.createElement('p', null, c(b.post, [
      'excerpt'
    ], null))))
  };
  return j
}),
define('templates/lounge/partials/followButtonSmall', [
  'react',
  'core/config/urls',
  'core/strings',
  'core/utils/object/get',
  'core/switches'
], function (a, b, c, d, e) {
  'use strict';
  var f = c.gettext,
  g = function (c) {
    var g = e.isFeatureActive('embed_refresh', {
      forum: c.forumId
    }),
    h = g && e.isFeatureActive('embed_refresh_v2', {
      forum: c.forumId
    });
    return d(c.user, [
      'isSession'
    ]) ? d(c.user, [
      'isEditable'
    ]) ? g ? a.createElement('a', {
      href: b.editProfile || '',
      target: '_blank',
      className: c.buttonAsLink ? 'publisher-anchor-color follow-link hover-card' : 'follow-btn btn-small hover-card edit'
    }, f('Edit')) : a.createElement('a', {
      href: b.editProfile || '',
      target: '_blank',
      className: c.buttonAsLink ? 'publisher-anchor-color follow-link' : 'btn btn-small'
    }, f('Edit profile')) : null : d(c.user, [
      'isPrivate'
    ]) ? g ? h ? a.createElement('span', {
      className: 'btn btn-small follow-btn private'
    }, a.createElement('a', {
      href: d(c.user, [
        'profileUrl'
      ], ''),
      'data-action': 'profile',
      'data-username': d(c.user, [
        'username'
      ], ''),
      target: '_blank',
      rel: 'noopener noreferrer'
    }, a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon-lock'
    }), a.createElement('span', {
      className: 'btn-text'
    }, f('Private Profile')))) : null : a.createElement('span', {
      className: 'btn btn-small follow-btn private'
    }, a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon-lock'
    }), ' ', a.createElement('span', {
      className: 'btn-text'
    }, f('Private'))) : g ? h ? a.createElement('a', {
      href: d(c.user, [
        'profileUrl'
      ], ''),
      className: '' + (c.buttonAsLink ? 'publisher-anchor-color follow-link' : 'btn btn-small follow-btn hover-card') + (d(c.user, [
        'isFollowing'
      ]) ? ' following' : ''),
      'data-action': 'toggleFollow',
      'data-user': d(c.user, [
        'id'
      ], ''),
      target: '_blank',
      rel: 'noopener noreferrer'
    }, a.createElement('span', {
      className: 'btn-text following-text hover-card'
    }, a.createElement('span', {
      className: 'follow-user is-following'
    }), f('Following')), a.createElement('span', {
      className: 'btn-text follow-text'
    }, a.createElement('span', {
      className: 'follow-user publisher-background-color-refresh hover-card'
    }), f('Follow'))) : a.createElement('a', {
      href: d(c.user, [
        'profileUrl'
      ], ''),
      className: '' + (c.buttonAsLink ? 'publisher-anchor-color follow-link' : 'btn btn-small follow-btn hover-card') + (d(c.user, [
        'isFollowing'
      ]) ? ' following' : ''),
      'data-action': 'toggleFollow',
      'data-user': d(c.user, [
        'id'
      ], ''),
      target: '_blank',
      rel: 'noopener noreferrer'
    }, a.createElement('span', {
      className: 'btn-text following-text hover-card'
    }, a.createElement('span', {
      className: 'follow-user is-following publisher-background-color-refresh'
    })), a.createElement('span', {
      className: 'btn-text follow-text'
    }, a.createElement('span', {
      className: 'follow-user publisher-background-color-refresh hover-card'
    }))) : a.createElement('a', {
      href: d(c.user, [
        'profileUrl'
      ], ''),
      className: '' + (c.buttonAsLink ? 'publisher-anchor-color follow-link' : 'btn btn-small follow-btn') + (d(c.user, [
        'isFollowing'
      ]) ? ' following' : ''),
      'data-action': 'toggleFollow',
      'data-user': d(c.user, [
        'id'
      ], ''),
      target: '_blank',
      rel: 'noopener noreferrer'
    }, a.createElement('span', {
      className: 'btn-text following-text'
    }, f('Following')), a.createElement('span', {
      className: 'btn-text follow-text'
    }, f('Follow')), a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon-checkmark'
    }))
  };
  return g
}),
define('templates/lounge/partials/hovercardActions', [
  'react',
  'core/strings',
  'core/switches',
  'templates/lounge/partials/followButtonSmall',
  'templates/lounge/partials/profileLink'
], function (a, b, c, d, e) {
  'use strict';
  var f = b.gettext,
  g = function (b) {
    var g = c.isFeatureActive('embed_refresh', {
      forum: b.forumId
    }),
    h = g && c.isFeatureActive('embed_refresh_v2', {
      forum: b.forumId
    });
    return g ? h ? a.createElement('div', {
      className: 'hovercard-actions-container'
    }, b.showFollowButton ? a.createElement(d, {
      user: b.user,
      buttonAsLink: b.buttonAsLink,
      forumId: b.forumId
    }) : null, b.user.isPrivate && !b.user.isEditable ? null : a.createElement(e, {
      user: b.user,
      forumId: null,
      className: 'view-profile'
    }, a.createElement('span', {
      className: 'eye'
    }), f('View Profile'))) : a.createElement('div', null, b.showFollowButton ? a.createElement(d, {
      user: b.user,
      buttonAsLink: b.buttonAsLink,
      forumId: b.forumId
    }) : null) : a.createElement('div', null, a.createElement(e, {
      user: b.user,
      forumId: null,
      className: 'full-profile'
    }, f('Full profile')), b.showFollowButton ? a.createElement(d, {
      user: b.user,
      buttonAsLink: b.buttonAsLink
    }) : null, ' ')
  };
  return g
}),
define('templates/lounge/partials/hovercardCounters', [
  'react',
  'core/strings',
  'core/utils/object/get',
  'core/switches'
], function (a, b, c, d) {
  'use strict';
  var e = b.gettext,
  f = function (b) {
    var f = d.isFeatureActive('embed_refresh', {
      forum: b.forumId
    }),
    g = f && d.isFeatureActive('embed_refresh_v2', {
      forum: b.forumId
    });
    return f ? g ? a.createElement('div', {
      className: 'hovercard-counters-container hovercard-counters-container-v2'
    }, a.createElement('div', {
      className: 'counters'
    }, a.createElement('span', {
      className: 'count count-v2 comment'
    }), 1 === c(b.user, [
      'numPosts'
    ]) ? '1' : b.user.numPosts), a.createElement('div', {
      className: 'counters'
    }, a.createElement('span', {
      className: 'count count-v2 like'
    }), 1 === c(b.user, [
      'numLikesReceived'
    ]) ? '1' : b.user.numLikesReceived)) : a.createElement('div', {
      className: 'hovercard-counters-container'
    }, a.createElement('div', {
      className: 'counters'
    }, a.createElement('span', {
      className: 'count comment'
    }), 1 === c(b.user, [
      'numPosts'
    ]) ? '1' : b.user.numPosts), a.createElement('div', {
      className: 'counters'
    }, a.createElement('span', {
      className: 'count like'
    }), 1 === c(b.user, [
      'numLikesReceived'
    ]) ? '1' : b.user.numLikesReceived)) : a.createElement('div', null, 1 === c(b.user, [
      'numPosts'
    ]) ? e('1 comment') : e('%(numPosts)s comments', {
      numPosts: c(b.user, [
        'numPosts'
      ], '')
    }), ' ', a.createElement('span', {
      className: 'bullet'
    }, '•'), ' ', 1 === c(b.user, [
      'numLikesReceived'
    ]) ? e('1 vote') : e('%(numLikesReceived)s votes', {
      numLikesReceived: c(b.user, [
        'numLikesReceived'
      ], '')
    }))
  };
  return f
}),
define('templates/lounge/hovercard', [
  'react',
  'core/strings',
  'core/switches',
  'core/utils/object/get',
  'core/utils',
  'templates/lounge/partials/hovercardActions',
  'templates/lounge/partials/hovercardCounters',
  'templates/lounge/partials/profileLink'
], function (a, b, c, d, e, f, g, h) {
  'use strict';
  var i = b.gettext,
  j = e.getInitials,
  k = function (b, c) {
    return b.length <= c ? b : a.createElement('span', null, b.slice(0, c), '…')
  },
  l = function (b) {
    var e = c.isFeatureActive('embed_refresh', {
      forum: b.forumId
    }),
    l = e && c.isFeatureActive('embed_refresh_v2', {
      forum: b.forumId
    }),
    m = d(b.user, [
      'isPrivate'
    ]),
    n = d(b.user, [
      'avatar',
      'isCustom'
    ]) ? d(b.user, [
      'avatar',
      'cache'
    ], '') : b.forumAvatar;
    return e ? l ? a.createElement('div', {
      className: 'tooltip tooltip-v2 tooltip--refresh--v2'
    }, a.createElement('div', {
      className: 'tooltip__header'
    }, a.createElement(h, {
      user: b.user,
      forumId: b.forumId,
      className: 'avatar avatar--refresh-v2'
    }, n ? a.createElement('img', {
      'data-user': d(b.user, [
        'id'
      ], ''),
      'data-role': 'user-avatar',
      src: n,
      className: 'user',
      alt: i('Avatar')
    }) : a.createElement('div', {
      className: 'initials'
    }, j(b.user.name) [0])), a.createElement('div', {
      className: 'tooltip__content tooltip__content--refresh-v2'
    }, a.createElement('h3', {
      className: 'profile-link-container'
    }, a.createElement('div', {
      className: 'profile-link-username profile-link-username-refresh-v2'
    }, a.createElement(h, {
      user: b.user,
      forumId: null,
      'data-role': 'username'
    }, d(b.user, [
      'name'
    ], null)))), a.createElement('p', {
      className: 'stats stats--refresh-v2',
      'data-role': 'counters'
    }, null !== d(b.user, [
      'numPosts'
    ], null) && null !== d(b.user, [
      'numLikesReceived'
    ], null) ? a.createElement(g, {
      user: b.user
    }) : null))), a.createElement('div', {
      className: 'tooltip__bio'
    }, d(b.user, [
      'about'
    ]) ? a.createElement('p', {
      className: 'bio'
    }, d(b.user, [
      'about'
    ], '')) : null), a.createElement('footer', {
      className: 'tooltip__footer-v2',
      'data-role': 'actions'
    }, a.createElement(f, {
      user: b.user,
      buttonAsLink: b.buttonAsLink,
      showFollowButton: b.showFollowButton,
      forumId: b.forumId
    }))) : a.createElement('div', {
      className: 'tooltip tooltip--refresh'
    }, a.createElement(h, {
      user: b.user,
      forumId: b.forumId,
      className: 'avatar avatar--refresh'
    }, n ? a.createElement('img', {
      'data-user': d(b.user, [
        'id'
      ], ''),
      'data-role': 'user-avatar',
      src: n,
      className: 'user user--refresh',
      alt: i('Avatar')
    }) : a.createElement('div', {
      className: 'initials user--refresh'
    }, j(b.user.name)), m ? a.createElement('div', {
      className: 'view-profile-message-container'
    }, a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon-lock'
    }), a.createElement('div', null, 'Private')) : a.createElement('div', {
      className: 'view-profile-message-container'
    }, a.createElement('div', null, 'View'), a.createElement('div', null, 'Profile'))), a.createElement('div', {
      className: 'tooltip__content tooltip__content--refresh'
    }, a.createElement('h3', {
      className: 'profile-link-container'
    }, a.createElement('div', {
      className: 'profile-link-username'
    }, a.createElement(h, {
      user: b.user,
      forumId: null,
      'data-role': 'username'
    }, d(b.user, [
      'name'
    ], null))), a.createElement('div', {
      className: 'tooltip__actions',
      'data-role': 'actions'
    }, a.createElement(f, {
      user: b.user,
      buttonAsLink: b.buttonAsLink,
      showFollowButton: b.showFollowButton,
      forumId: b.forumId
    }))), a.createElement('p', {
      className: 'stats stats--refresh',
      'data-role': 'counters'
    }, null !== d(b.user, [
      'numPosts'
    ], null) && null !== d(b.user, [
      'numLikesReceived'
    ], null) ? a.createElement(g, {
      user: b.user
    }) : null))) : a.createElement('div', {
      className: 'tooltip'
    }, a.createElement('div', {
      className: 'notch'
    }), a.createElement(h, {
      user: b.user,
      forumId: null,
      className: 'avatar'
    }, a.createElement('img', {
      'data-user': d(b.user, [
        'id'
      ], ''),
      'data-role': 'user-avatar',
      src: d(b.user, [
        'avatar',
        'cache'
      ], ''),
      className: 'user',
      alt: i('Avatar')
    })), a.createElement('div', {
      className: 'tooltip__content'
    }, a.createElement('h3', null, a.createElement(h, {
      user: b.user,
      forumId: null,
      'data-role': 'username'
    }, d(b.user, [
      'name'
    ], null)), ' ', d(b.user, [
      'thread',
      'canModerate'
    ]) ? a.createElement('span', {
      className: 'badge moderator'
    }, i('MOD')) : null), d(b.user, [
      'about'
    ]) ? a.createElement('p', {
      className: 'bio'
    }, k(d(b.user, [
      'about'
    ], ''), 80)) : null, a.createElement('p', {
      className: 'stats',
      'data-role': 'counters'
    }, null !== d(b.user, [
      'numPosts'
    ], null) && null !== d(b.user, [
      'numLikesReceived'
    ], null) ? a.createElement(g, {
      user: b.user
    }) : null), a.createElement('div', {
      className: 'hovercard-badges',
      'data-role': 'hovercard-badges'
    })), a.createElement('footer', {
      className: 'tooltip__footer',
      'data-role': 'actions'
    }, a.createElement(f, {
      user: b.user,
      buttonAsLink: b.buttonAsLink,
      showFollowButton: b.showFollowButton
    })))
  };
  return l
}),
define('templates/lounge/upgradeCard', [
  'react',
  'core/strings',
  'core/utils/object/get'
], function (a, b, c) {
  'use strict';
  var d = b.gettext,
  e = function (b) {
    return a.createElement('div', {
      className: 'tooltip'
    }, a.createElement('div', {
      className: 'notch'
    }), a.createElement('div', null, a.createElement('p', {
      className: 'text-normal'
    }, d('Disqus Pro gives you access to exclusive features like auto-moderation, shadow banning, and customization options.')), a.createElement('a', {
      href: [
        'https://disqus.com/admin/',
        b.organization ? 'orgs/' + c(b.organization, [
          'id'
        ]) + '/' + c(b.organization, [
          'slug'
        ], 'sites') + '/' : '',
        'settings/subscription/'
      ].join(''),
      target: '_blank',
      rel: 'noopener noreferrer',
      className: 'btn btn-small',
      'data-role': 'upgrade-link'
    }, d('Subscriptions and Billing'))))
  };
  return e
}),
define('templates/lounge/partials/userBadges', [
  'react',
  'core/bus',
  'templates/lounge/partials/profileLink'
], function (a, b, c) {
  'use strict';
  var d = function (b) {
    var d = b.badge,
    e = b.user,
    f = b.forumId,
    g = b.context,
    h = b.trackClick,
    i = b.postId;
    return d.image ? a.createElement(c, {
      user: e,
      forumId: f,
      profileTab: 'badges',
      id: g + '-badge_' + e.id + '-' + d.id + '-' + i,
      className: 'user-badge badge-tooltip__wrapper',
      'data-role': 'user-badge',
      'data-badge': d.id,
      onClick: function (a) {
        return h(a, d.id)
      },
      tabIndex: 0
    }, a.createElement('img', {
      className: 'user-badge-image',
      src: d.image,
      alt: d.name
    }), a.createElement('div', {
      className: 'badge-tooltip__container'
    }, a.createElement('div', {
      className: 'tooltip show badge-tooltip'
    }, a.createElement('span', {
      className: 'badge-tooltip__content'
    }, d.name)))) : null
  },
  e = function (a, b) {
    return b.badges ? b.badges.filter(function (b) {
      return a.badges[b.id]
    }) : [
    ]
  },
  f = function (f) {
    var g = f.forum,
    h = f.user,
    i = f.context,
    j = f.limit,
    k = f.postId;
    if (!(g.settings.badgesEnabled && g.badges && Object.keys(g.badges).length && h)) return null;
    var l = e(g, h),
    m = function (a, c) {
      b.trigger('uiAction:clickBadge', a, c)
    },
    n = l.length > j,
    o = n ? j - 1 : j;
    return l.length ? a.createElement('span', {
      'data-role': 'badges',
      className: 'user-badges-collection',
      'data-tracking-area': i
    }, l.map(function (b, c) {
      return c < o ? a.createElement(d, {
        key: c,
        badge: b,
        user: h,
        forumId: g.id,
        context: i,
        trackClick: m,
        postId: k
      }) : null
    }), n ? a.createElement(c, {
      user: h,
      forumId: g.id,
      profileTab: 'badges',
      className: 'user-badge truncate-badge publisher-background-color',
      'data-role': 'user-badge',
      onClick: function (a) {
        return m(a, 'more')
      },
      tabIndex: 0
    }, a.createElement('span', {
      className: 'user-badge-more'
    }, '+', l.length - o)) : null) : a.createElement('span', {
      'data-role': 'badges',
      className: 'user-badges-collection'
    })
  };
  return f
}),
define('lounge/views/cards', [
  'jquery',
  'underscore',
  'lounge/common',
  'core/utils',
  'core/switches',
  'common/models',
  'common/views/mixins',
  'core/constants/badgesConstants',
  'core/views/common/HoverCard',
  'core/views/VotersCard',
  'templates/lounge/contextCard',
  'templates/lounge/hovercard',
  'templates/lounge/upgradeCard',
  'templates/lounge/partials/hovercardActions',
  'templates/lounge/partials/hovercardCounters',
  'templates/lounge/partials/userBadges'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p) {
  'use strict';
  i.prototype.getContainerPosition = function () {
    var a = c.getLounge().getPosition();
    return {
      pageOffset: a.pageOffset,
      containerOffset: a.frameOffset,
      containerHeight: a.height
    }
  },
  function () {
    var c = 10;
    a(window.document).on('mouseout', b.debounce(function (a) {
      var b = a.relatedTarget || a.toElement;
      b && 'HTML' !== b.nodeName || i.exitAll()
    }, c))
  }();
  var q = i.extend({
    className: 'tooltip-outer profile-card',
    events: b.defaults({
      'click [data-action=toggleFollow]': 'toggleFollow'
    }, i.prototype.events),
    initialize: function (a) {
      var b = this;
      i.prototype.initialize.call(b, a),
      b.session = a.session,
      b.user = a.user,
      b._fetched = !1,
      b.listenTo(b.session, 'change:id', function () {
        this._rendered && this.render()
      }),
      b.session.attributes.thread && e.isFeatureActive('embed_refresh', {
        forum: b.session.attributes.thread.forum.id
      }) && b.el.classList.add('profile-card--refresh')
    },
    onFetch: function (a) {
      this.user = new f.SyncedUser(a.attributes),
      this.updateCounters(),
      this.updateActions(),
      this.updateBadges(),
      this.listenTo(this.user, {
        'change:numPosts change:numLikesReceived': b.debounce(function () {
          this.updateCounters()
        }),
        'change:isFollowing': this.updateActions
      });
      var c = function (a) {
        this.set('isFollowing', a.get('isFollowing'))
      };
      a.listenTo(this.user, 'change:isFollowing', c),
      this.user.listenTo(a, 'change:isFollowing', c)
    },
    serialize: function () {
      var a = this.user.toJSON({
        session: this.session
      });
      a.numLikesReceived = a.numLikesReceived || this.user.get('numVotes') || 0;
      var b = this.session.get('thread').forum.get('avatar');
      return b = b && b.large && b.large.cache,
      b = d.isDefaultAvatar(b) ? null : b,
      {
        forumId: this.session.attributes.thread.forum.id,
        forumAvatar: b,
        user: a,
        showFollowButton: this.user.has('isFollowing') || this.session.isLoggedOut()
      }
    },
    render: function () {
      this.$el.html(l(this.serialize())),
      i.prototype.render.call(this)
    },
    setBadges: function (a) {
      this._fetched && (this.user.set('badges', a), this.updateBadges())
    },
    updateBadges: function () {
      if (!e.isFeatureActive('embed_refresh', {
        forum: this.session.attributes.thread.forum.id
      })) {
        var a = this.session.get('thread') && this.session.get('thread').forum,
        b = Boolean(a && a.get('settings') && a.get('settings').badgesEnabled && a.get('badges')),
        c = Boolean(b && this.user.get('badges') && this.user.get('badges').length);
        c && !this.el.classList.contains('has-badges') ? this.el.classList.add('has-badges') : !c && this.el.classList.contains('has-badges') && this.el.classList.remove('has-badges'),
        b && this.$el.find('[data-role=hovercard-badges]').html(p({
          forum: a.attributes,
          user: this.user.attributes,
          context: 'hovercard',
          limit: h.MAX_BADGE_COUNT
        }))
      }
    },
    updateCounters: function () {
      this.$el.find('[data-role=counters]').html(o(this.serialize()))
    },
    updateActions: function () {
      this.$el.find('[data-role=actions]').html(n(this.serialize()))
    },
    show: function () {
      this._fetched || (this._fetched = !0, this.user.fetch({
        success: b.bind(this.onFetch, this)
      })),
      e.isFeatureActive('embed_refresh', {
        forum: this.session.attributes.thread.forum.id
      }) && (i.prototype.constructor.POSITION_OFFSET = 0, i.prototype.constructor.DELAY_ENTER = 0, i.prototype.constructor.DELAY_LEAVE = 0),
      i.prototype.show.call(this)
    }
  }, {
    create: function (a) {
      var b = a.user;
      return i.create(b.id, a, 'ProfileCard', q)
    }
  });
  b.extend(q.prototype, g.FollowButtonMixin);
  var r = i.extend({
    className: 'context-card tooltip-outer',
    initialize: function (a) {
      var b = this;
      i.prototype.initialize.call(b, a),
      b.post = a.post
    },
    render: function () {
      var a = this.post,
      b = a.toJSON();
      b.excerpt = d.niceTruncate(b.plaintext, 40),
      this.$el.html(k({
        post: b
      })),
      i.prototype.render.call(this)
    }
  }, {
    create: function (a) {
      var b = a.post;
      return i.create(b.id, a, 'ContextCard', r)
    }
  }),
  s = i.extend({
    className: 'tooltip-outer upgrade-card',
    events: b.defaults({
      'click [data-role=upgrade-link]': 'onClickUpgrade'
    }, i.prototype.events),
    initialize: function (a) {
      i.prototype.initialize.call(this, a),
      this.organization = a.organization
    },
    render: function () {
      this.$el.html(m({
        organization: this.organization
      })),
      i.prototype.render.call(this)
    },
    onClickUpgrade: function (a) {
      this.trigger('click:upgrade', a)
    }
  }, {
    create: function (a) {
      var b = a.organization;
      return i.create(b ? b.id : 'upgrade', a, 'UpgradeCard', s)
    }
  });
  return {
    HoverCard: i,
    ProfileCard: q,
    ContextCard: r,
    VotersCard: j,
    UpgradeCard: s
  }
}),
define('core/views/SourcelessIframeRichMediaView', [
  'jquery',
  'core/mediaConfig',
  'core/views/RichMediaView'
], function (a, b, c) {
  'use strict';
  return c.extend({
    createContentNode: function (b) {
      return a('<iframe>').attr({
        frameBorder: 0,
        scrolling: 'no',
        width: '100%',
        height: this.model.get('deferredHeight'),
        'data-src': b,
        src: 'javascript:window.frameElement.getAttribute("data-src");'
      })
    },
    insertContentNode: function (a) {
      c.prototype.insertContentNode.apply(this, arguments);
      var d = this.model.get('deferredHeight') || b.get('defaultIframeHeight');
      a.height(d)
    }
  })
}),
define('lounge/views/media', [
  'underscore',
  'stance',
  'core/utils',
  'core/utils/storage',
  'core/utils/html/toHexColorString',
  'core/media',
  'core/mediaConfig',
  'core/models/RichMediaViewModel',
  'core/views/RichMediaLinkView',
  'core/views/RichMediaView',
  'core/views/IframeRichMediaView',
  'core/views/SoundCloudRichMediaView',
  'core/views/AutoplayRichMediaView',
  'core/views/SourcelessIframeRichMediaView',
  'core/views/DynamicHeightRichMediaView',
  'core/views/TwitterRichMediaView',
  'core/views/ImageRichMediaView',
  'core/views/FacebookPhotoRichMediaView',
  'core/views/VineRichMediaView',
  'lounge/common'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t) {
  'use strict';
  function u() {
    var b = d.get('disqus.collapse-media');
    return a.isBoolean(b) || (b = c.isMobileUserAgent()),
    b
  }
  return a.extend(j.prototype, {
    topEdgeOffset: function () {
      return - t.getLounge().getPosition().height
    },
    configureDeferred: function () {
      this.model.get('deferred') && !this.model.get('activated') && this.listenToOnce(b(this), 'enter', function () {
        this.relatedPost && this.listenToOnce(this, 'load error', function () {
          t.getLounge().postsView.onDeferredViewReady(this.relatedPost)
        }),
        this.enterViewport()
      }),
      this.listenToOnce(t.getLounge().postsView, 'render:end', this.updateDeferredHeight)
    }
  }),
  p.theme = function () {
    return t.getLounge().config.colorScheme
  },
  p.linkColor = function () {
    return e(t.getLounge().config.anchorColor)
  },
  g.set({
    collapsed: u()
  }),
  g.on('change:collapsed', function (b, c) {
    if (a.isObject(c)) {
      if (!c.persist) return;
      c = c.value
    }
    d.set('disqus.collapse-media', c)
  }),
  {
    settings: g,
    getCollapseDefault: u,
    getDomain: c.getDomain,
    RichMediaLinkView: i,
    RichMediaViewModel: h,
    RichMediaView: j,
    IframeRichMediaView: k,
    SoundCloudRichMediaView: l,
    AutoplayRichMediaView: m,
    SourcelessIframeRichMediaView: n,
    DynamicHeightRichMediaView: o,
    TwitterRichMediaView: p,
    ImageRichMediaView: q,
    FacebookPhotoRichMediaView: r,
    VineRichMediaView: s,
    instantiateRichMediaView: f.instantiateRichMediaView,
    getRichMediaViewConfig: f.getRichMediaViewConfig
  }
}),
define('core/templates/react/BadgesManageTemplate', [
  'react',
  'underscore',
  'core/strings',
  'core/constants/badgesConstants'
], function (a, b, c, d) {
  'use strict';
  var e = c.gettext,
  f = d.ACTION_TYPES,
  g = function (b) {
    var c = b.text,
    d = b.value,
    e = b.selected,
    f = b.handleChange,
    g = function (a) {
      var b = 13;
      a.keyCode === b && f(a)
    };
    return a.createElement('label', {
      className: 'padding-default align align__item--grow align__item--equal align--center align--column modal__option' + (e ? ' -selected' : ''),
      tabIndex: '0',
      onKeyPress: g,
      onChange: f
    }, a.createElement('input', {
      type: 'radio',
      name: 'badge_action',
      value: d,
      checked: e
    }), a.createElement('p', {
      className: 'text-semibold text-center modal__option-text'
    }, c))
  },
  h = function (b) {
    var c = b.badge,
    d = b.selectedBadge,
    e = b.handleChange;
    return a.createElement('span', {
      key: c.id,
      className: 'badge-option spacing-right ' + (d && d === c.id ? ' selected' : '') + (c.disabled ? ' disabled' : '')
    }, a.createElement('input', {
      id: 'badge-' + c.id + '-input',
      name: 'badge',
      type: 'radio',
      className: 'badge-option_input',
      value: c.id,
      onChange: e,
      disabled: c.disabled,
      tabIndex: '0'
    }), a.createElement('label', {
      htmlFor: 'badge-' + c.id + '-input',
      className: 'badge-option_label'
    }, a.createElement('span', {
      className: 'badge-option_image-wrapper'
    }, a.createElement('img', {
      className: 'badge-option_image',
      src: c.image,
      alt: c.name
    })), a.createElement('span', {
      className: 'badge-option_title'
    }, c.name)))
  },
  i = function (b) {
    var c = b.badgeAction,
    d = b.formValues,
    i = b.badgeOptions,
    j = b.updateBadgeAction,
    k = b.updateBadgeSelection,
    l = b.handleSubmit,
    m = b.handleClose,
    n = 'https://' + d.forum + '.disqus.com/admin/settings/badges';
    return a.createElement('form', {
      className: 'badges-manage-form'
    }, a.createElement('div', {
      className: 'admin-modal__content padding-bottom'
    }, a.createElement('div', null, a.createElement('div', {
      className: 'align align--stretch align--wrap'
    }, a.createElement(g, {
      text: e('Award a Badge'),
      value: f.AWARD,
      selected: c === f.AWARD,
      handleChange: j
    }), a.createElement(g, {
      text: e('Remove a Badge'),
      value: f.REMOVE,
      selected: c === f.REMOVE,
      handleChange: j
    })), a.createElement('div', {
      className: 'modal__description border-bottom-dark'
    }, a.createElement('p', {
      className: 'modal__option-subtext'
    }, e(c === f.AWARD ? 'Select a badge below to award it to this commenter.' : 'Select one of the manually awarded badges below to remove it from this commenter. Automatically awarded badges can only be removed by removing the badge from your site entirely.'), a.createElement('br', null), e('You can manage your site\'s badges using the '), a.createElement('a', {
      href: n,
      target: '_blank',
      rel: 'noopener noreferrer'
    }, e('Badges settings')), e(' in the Disqus Admin.'))), a.createElement('div', {
      className: 'modal__config'
    }, a.createElement('div', {
      className: 'badge-options_list'
    }, i.map(function (b) {
      return a.createElement(h, {
        key: b.id,
        badge: b,
        selectedBadge: d.badge,
        handleChange: k
      })
    }), c === f.AWARD ? a.createElement('span', {
      className: 'badge-option spacing-right create-badge'
    }, a.createElement('a', {
      className: 'badge-option_link',
      href: n,
      target: '_blank',
      rel: 'noopener noreferrer'
    }, a.createElement('span', {
      className: 'badge-option_image-wrapper'
    }, a.createElement('span', {
      className: 'icon icon-plus badge-option_add-icon'
    })), a.createElement('span', {
      className: 'badge-option_title'
    }, e('Create a new badge')))) : null), c !== f.REMOVE || i.length ? null : a.createElement('div', {
      className: 'badge-options_empty'
    }, e('This user doesn\'t have any badges.')), d.errorMessage ? a.createElement('div', {
      className: 'spacing-top-narrow'
    }, a.createElement('p', {
      className: 'text-small modal__option-subtext modal__error'
    }, d.errorMessage)) : null))), a.createElement('div', {
      className: 'admin-modal__footer clearfix'
    }, a.createElement('button', {
      className: 'button button-fill--brand button-small text-capitalized',
      onClick: l
    }, e(c === f.AWARD ? 'Award badge' : 'Remove badge')), a.createElement('button', {
      className: 'button button-fill button-small text-capitalized',
      onClick: m
    }, e('Cancel'))))
  };
  return i
});
var _extends = Object.assign || function (a) {
  for (var b = 1; b < arguments.length; b++) {
    var c = arguments[b];
    for (var d in c) Object.prototype.hasOwnProperty.call(c, d) && (a[d] = c[d])
  }
  return a
};
define('lounge/views/posts/BadgesManageView', [
  'underscore',
  'backbone',
  'core/api',
  'core/bus',
  'core/strings',
  'core/utils',
  'core/templates/react/BadgesManageTemplate',
  'core/constants/badgesConstants'
], function (a, b, c, d, e, f, g, h) {
  'use strict';
  var i = h.ACTION_TYPES,
  j = h.BADGES_CRITERIA,
  k = f.preventDefaultHandler,
  l = e.get,
  m = b.View.extend({
    className: 'badges-action',
    initialize: function (a) {
      this.forum = a.forum
    },
    render: function () {
      var a = this.$el;
      return this.badgeAction = this.badgeAction || i.AWARD,
      this.formValues = _extends({
        user: this.model.author.id,
        forum: this.forum.id
      }, this.formValues),
      a.html(g({
        badgeAction: this.badgeAction,
        formValues: this.formValues,
        badgeOptions: this.getBadgeOptions(),
        updateBadgeAction: this.updateBadgeAction.bind(this),
        updateBadgeSelection: this.updateBadgeSelection.bind(this),
        handleSubmit: this.submit.bind(this),
        handleClose: this.cancel.bind(this)
      })),
      this.trigger('render'),
      this
    },
    updateBadgeAction: function (a) {
      this.formValues.badge = null,
      this.formValues.errorMessage = null,
      this.badgeAction = a.target.value || a.target.children[0].value,
      this.render()
    },
    updateBadgeSelection: function (a) {
      this.formValues.errorMessage = null,
      a.target.disabled || (this.formValues.badge = a.target.value)
    },
    getBadgeOptions: function () {
      var a = [
      ],
      b = [
      ],
      c = this.forum.get('badges') ? f.deepClone(this.forum.get('badges')) : [
      ],
      d = this.model.author.get('badges') || [
      ];
      if (this.badgeAction === i.AWARD) {
        var e = d.map(function (a) {
          return a.id
        });
        Object.keys(c).forEach(function (d) {
          var f = c[d];
          f.criteria === j.MANUAL && (e.indexOf(f.id) > - 1 ? (f.disabled = !0, b.push(f)) : a.push(f))
        })
      } else this.badgeAction === i.REMOVE && d.forEach(function (c) {
        c.criteria === j.MANUAL ? a.push(c) : (c.disabled = !0, b.push(c))
      });
      return [].concat(a, b)
    },
    submit: k(function () {
      var b = this;
      if (this.formValues.badge) {
        this.formValues.errorMessage = null;
        var e = this.badgeAction === i.AWARD ? 'uiAction:awardBadge' : 'uiAction:removeBadge';
        c.call('badges/' + this.badgeAction, {
          method: 'POST',
          data: a.omit(this.formValues, a.isNull),
          success: function (a) {
            b.trigger('success', {
              action: b.badgeAction,
              badge: a.response
            }),
            d.trigger(e, a.response.id)
          },
          error: function (a) {
            b.formValues.errorMessage = a.responseJSON.response,
            b.render()
          }
        })
      } else this.badgeAction === i.AWARD ? this.formValues.errorMessage = l('You must select a badge to award') : this.formValues.errorMessage = l('You must select a badge to remove'),
      this.render()
    }),
    cancel: k(function () {
      this.trigger('cancel')
    })
  }, {
    defaultFormValues: {
      badge: null,
      errorMessage: null
    }
  });
  return m
}),
define('core/constants/moderationUserLists', [
  'exports',
  'moment'
], function (a, b) {
  'use strict';
  a.LIST_TYPES = {
    WHITELIST: 'whitelist',
    BLACKLIST: 'blacklist'
  },
  a.BAN_TYPES = {
    SHADOW: 'shadowban',
    PERMANENT: 'permanent',
    TEMP: 'temp'
  },
  a.RETROACTIVE_ACTION_TYPES = {
    DO_NOTHING: '',
    DELETE: '1',
    MARK_AS_SPAM: '2'
  },
  a.DEFAULT_FORM_VALUES = {
    durationHours: '24',
    customDurationAmount: '1',
    customDurationScale: '1'
  },
  a.STORAGE_KEY_BAN_TYPE = 'defaultBan',
  a.getDateExpires = function (a) {
    return 'custom' === a.durationHours && (a.durationHours = parseInt(a.customDurationAmount, 10) * parseInt(a.customDurationScale, 10)),
    b().add(a.durationHours, 'hours').toISOString()
  },
  a.isBanTypeSupported = function (b, c) {
    return !!c && (b === a.BAN_TYPES.SHADOW ? c.shadowBanning : b === a.BAN_TYPES.TEMP ? c.temporaryBanning : Boolean(b))
  }
}),
define('core/templates/react/ModerationUserListsTemplate', [
  'react',
  'underscore',
  'core/strings',
  'core/constants/moderationUserLists'
], function (a, b, c, d) {
  'use strict';
  var e = this,
  f = c.gettext,
  g = d.LIST_TYPES,
  h = d.BAN_TYPES,
  i = d.RETROACTIVE_ACTION_TYPES,
  j = 168,
  k = [
    {
      label: f('1 day'),
      durationHours: '24'
    },
    {
      label: f('1 week'),
      durationHours: j.toString()
    },
    {
      label: f('2 weeks'),
      durationHours: (2 * j).toString()
    }
  ],
  l = function (c) {
    var d = c.user,
    j = c.listName,
    l = c.ipAddress,
    m = c.formValues,
    n = c.supportsShadowBanning,
    o = c.supportsTempBanning,
    p = c.selectRetroactiveAction,
    q = c.toggleBanTypeCallback,
    r = c.toggleUserValueChecked,
    s = c.toggleIpAddressChecked,
    t = c.updateDuration,
    u = c.updateCustomDurationAmount,
    v = c.updateCustomDurationScale,
    w = c.updateReason,
    x = c.handleSubmit,
    y = c.handleClose,
    z = c.handleChangeValue,
    A = c.closeText,
    B = c.getPlaceholderForValue,
    C = c.itemTypes,
    D = c.itemType,
    E = c.UpgradeIcon,
    F = c.itemValue;
    return j ? a.createElement('form', {
      className: j + '-form'
    }, a.createElement('div', {
      className: 'admin-modal__content padding-bottom'
    }, a.createElement('div', null, j === g.WHITELIST ? a.createElement('p', {
      className: 'spacing-default'
    }, f('Adding this person to the whitelist will automatically approve his or her new comments from now on.')) : a.createElement('div', {
      className: 'align align--stretch align--wrap'
    }, a.createElement('label', {
      className: [
        'padding-default',
        'align',
        'align__item--grow',
        'align__item--equal',
        'align--center',
        'align--column',
        'modal__option',
        'ban__option',
        o ? null : '-disabled',
        m.type === h.TEMP ? '-selected' : null
      ].join(' ')
    }, a.createElement('input', {
      type: 'radio',
      name: 'ban_type',
      value: h.TEMP,
      checked: m.type === h.TEMP,
      onChange: q,
      disabled: !o
    }), a.createElement('p', {
      className: 'text-semibold text-center modal__option-text ban__option-text'
    }, f('Timeout'), o ? null : a.createElement(E, {
      tooltipClass: 'tooltip-timeout'
    }))), j === g.BLACKLIST && m.type === h.TEMP ? a.createElement('div', {
      className: 'padding-default modal__description ban__description border-bottom-dark'
    }, a.createElement('div', {
      className: 'text-small modal__option-subtext ban__option-subtext'
    }, f('Restrict a user\'s ability to comment for a period of time. This notifies the user of their timeout. If discussions get heated, enforce timeouts so that users cool off and improve their behavior.'), k.map(function (b) {
      return a.createElement('label', {
        className: 'fieldset__block--checkbox text-medium spacing-bottom-small text-semibold text-gray-dark',
        key: b.durationHours
      }, a.createElement('input', {
        type: 'radio',
        name: 'duration',
        checked: m.durationHours === b.durationHours,
        onChange: t,
        value: b.durationHours,
        className: 'spacing-right-small'
      }), b.label)
    }), a.createElement('div', null, a.createElement('label', {
      className: 'text-medium spacing-bottom-small inline__item spacing-right text-semibold text-gray-dark'
    }, a.createElement('input', {
      type: 'radio',
      name: 'duration',
      checked: 'custom' === m.durationHours,
      onChange: t,
      value: 'custom',
      className: 'spacing-right-small'
    }), f('Custom')), a.createElement('input', {
      name: 'customDurationAmount',
      type: 'number',
      value: m.customDurationAmount,
      onChange: u,
      onFocus: u,
      onKeyPress: u,
      className: 'spacing-right-small -text-small',
      maxLength: '2',
      style: {
        width: '50px'
      },
      min: '0'
    }), a.createElement('select', {
      value: m.customDurationScale,
      onChange: v
    }, a.createElement('option', {
      value: '1'
    }, 'Hour(s)'), a.createElement('option', {
      value: '24'
    }, 'Day(s)'), a.createElement('option', {
      value: 168 .toString()
    }, 'Week(s)'))))) : null, a.createElement('label', {
      className: [
        'padding-default',
        'align',
        'align__item--grow',
        'align__item--equal',
        'align--center',
        'align--column',
        'modal__option',
        'ban__option',
        n ? null : '-disabled',
        m.type === h.SHADOW ? '-selected' : null
      ].join(' ')
    }, a.createElement('input', {
      type: 'radio',
      name: 'ban_type',
      value: h.SHADOW,
      checked: m.type === h.SHADOW,
      onChange: q,
      disabled: !n
    }), a.createElement('p', {
      className: 'text-semibold text-center modal__option-text ban__option-text'
    }, f('Shadow Ban'), n ? null : a.createElement(E, null))), j === g.BLACKLIST && m.type === h.SHADOW ? a.createElement('div', {
      className: 'modal__description ban__description border-bottom-dark'
    }, a.createElement('p', {
      className: 'text-small modal__option-subtext ban__option-subtext'
    }, f('Ban a user without them knowing. The user can still comment, however, their posts will only be visible to themselves. Use it against trolls and spammers who attempt to circumvent a ban with new accounts.'))) : null, a.createElement('label', {
      className: [
        'padding-default',
        'align',
        'align__item--grow',
        'align__item--equal',
        'align--center',
        'align--column',
        'modal__option',
        'ban__option',
        m.type === h.PERMANENT ? '-selected' : null
      ].join(' ')
    }, a.createElement('input', {
      type: 'radio',
      name: 'ban_type',
      value: h.PERMANENT,
      checked: m.type === h.PERMANENT,
      onChange: q
    }), a.createElement('p', {
      className: 'text-semibold text-center modal__option-text ban__option-text'
    }, 'Permanent Ban')), j === g.BLACKLIST && m.type === h.PERMANENT ? a.createElement('div', {
      className: 'modal__description ban__description border-bottom-dark'
    }, a.createElement('p', {
      className: 'text-small modal__option-subtext ban__option-subtext'
    }, f('Permanently ban the user so they can no longer post, vote, or flag comments on your site. If the user repeatedly violates your comment policy, revoke their ability to participate.'), a.createElement('label', {
      className: 'fieldset__block--checkbox text-medium spacing-bottom-small'
    }, a.createElement('span', {
      className: 'text-semibold text-gray-dark'
    }, f('Last 30 days of comments:'), ' '), a.createElement('select', {
      value: m.retroactiveAction,
      onChange: p,
      className: 'custom-select'
    }, a.createElement('option', {
      value: i.DO_NOTHING
    }, f('Do nothing')), a.createElement('option', {
      value: i.DELETE
    }, f('Delete')), a.createElement('option', {
      value: i.MARK_AS_SPAM
    }, f('Mark as spam')))))) : null)), a.createElement('div', {
      className: 'padding-default modal__config ban__config'
    }, !d || d.isAnonymous ? null : a.createElement('div', {
      className: 'align align--stretch access__block spacing-bottom embed-hidden'
    }, a.createElement('a', {
      href: d.profileUrl,
      className: 'spacing-right'
    }, a.createElement('img', {
      src: d.avatar.cache,
      alt: d.name,
      className: 'comment-__avatar border-radius-sm'
    })), a.createElement('div', {
      className: 'access__value'
    }, a.createElement('h4', null, d.name), a.createElement('p', {
      className: 'text-gray text-small'
    }, ' ', d.username, ' '))), d ? a.createElement('label', {
      className: 'fieldset__block--checkbox text-medium spacing-bottom-small'
    }, a.createElement('input', {
      type: 'checkbox',
      checked: Boolean(m.username),
      onChange: b.partial(r, b, 'username'),
      className: 'spacing-right-small'
    }), f('User:'), ' ', ' ', a.createElement('strong', null, ' ', d.username, ' ')) : a.createElement(a.Fragment, null, a.createElement('div', {
      className: 'spacing-top spacing-bottom form-attribute-input'
    }, a.createElement('div', null, a.createElement('h3', {
      className: 'text-gray-darker'
    }, 'Type')), a.createElement('select', {
      name: 'itemType',
      className: 'input--select',
      value: e.itemType,
      onChange: z,
      disabled: C.length <= 1
    }, C.map(function (b) {
      return a.createElement('option', {
        key: b.value,
        value: b.value
      }, ' ', b.displayName, ' ')
    }))), a.createElement('div', {
      className: 'spacing-top spacing-bottom form-attribute-input'
    }, a.createElement('h3', {
      className: 'text-gray-darker'
    }, 'Value'), a.createElement('div', null, a.createElement('input', {
      className: 'input--textbox',
      name: 'itemValue',
      type: 'text',
      placeholder: B(D),
      value: F,
      onChange: z
    })))), d && j === g.BLACKLIST ? a.createElement('label', {
      className: 'fieldset__block--checkbox text-medium spacing-bottom-small'
    }, a.createElement('input', {
      type: 'checkbox',
      checked: Boolean(m.email),
      onChange: b.partial(r, b, 'email'),
      className: 'spacing-right-small'
    }), f('Email:'), ' ', a.createElement('strong', null, ' ', d.email, ' ')) : null, j === g.BLACKLIST && l ? a.createElement('label', {
      className: 'fieldset__block--checkbox text-medium spacing-bottom-small'
    }, a.createElement('input', {
      type: 'checkbox',
      checked: Boolean(m.ipAddress),
      onChange: s,
      className: 'spacing-right-small'
    }), f('IP Address:'), ' ', a.createElement('strong', null, ' ', l, ' '), a.createElement('div', {
      className: [
        'spacing-default-narrow',
        'text-small',
        'text-gray',
        'spacing-left-large',
        'embed-hidden'
      ].join(' ')
    }, a.createElement('strong', null, f('Note:'), ' '), f('Adding an IP address to the banned list may also unintentionally block others who may share this IP address.'))) : null, j === g.BLACKLIST ? a.createElement('div', null, a.createElement('div', {
      className: 'spacing-bottom-small spacing-top-narrow'
    }, a.createElement('label', {
      className: 'modal__reason ban__reason'
    }, f('Reason for banning:'), a.createElement('input', {
      name: 'reason',
      type: 'text',
      value: m.reason || '',
      onChange: w,
      className: 'input--textbox -text-small border-gray-light',
      maxLength: '50'
    }))), a.createElement('p', {
      className: 'text-small modal__option-subtext ban__option-subtext'
    }, f('You can remove the user from the banned list at any time.'))) : null)), a.createElement('div', {
      className: 'admin-modal__footer clearfix'
    }, a.createElement('div', null, a.createElement('button', {
      className: [
        'button',
        'button-fill--brand',
        'button-small',
        'text-capitalized'
      ].join(' '),
      disabled: !(m.email || m.username || m.ipAddress || F),
      onClick: x
    }, f(j === g.WHITELIST ? 'Add to Trusted List' : 'Add to Banned List')), j === g.BLACKLIST ? a.createElement('button', {
      className: [
        'button',
        'button-fill',
        'button-small',
        'text-capitalized'
      ].join(' '),
      onClick: y
    }, f(A)) : null))) : null
  };
  return l
}),
define('lounge/utils', [
  'jquery',
  'core/api'
], function (a, b) {
  'use strict';
  var c = {
  },
  d = function (d) {
    if (c[d]) return c[d];
    var e = a.Deferred();
    return d ? (c[d] = e.promise(), b.call('forums/details', {
      method: 'GET',
      data: {
        forum: d,
        attach: 'forumFeatures'
      }
    }).done(function (a) {
      e.resolve(a.response.features)
    }).fail(function () {
      e.reject({
      })
    }), e.promise()) : e.reject({
    })
  };
  return d._clearCache = function () {
    c = {
    }
  },
  {
    getSaasFeatures: d
  }
});
var _extends = Object.assign || function (a) {
  for (var b = 1; b < arguments.length; b++) {
    var c = arguments[b];
    for (var d in c) Object.prototype.hasOwnProperty.call(c, d) && (a[d] = c[d])
  }
  return a
};
define('lounge/views/posts/BlacklistView', [
  'jquery',
  'underscore',
  'backbone',
  'react',
  'moment',
  'core/bus',
  'core/api',
  'core/utils',
  'core/utils/storage',
  'core/templates/react/ModerationUserListsTemplate',
  'core/constants/moderationUserLists',
  'lounge/utils',
  'lounge/views/cards'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m) {
  'use strict';
  var n = k.BAN_TYPES,
  o = k.LIST_TYPES,
  p = k.STORAGE_KEY_BAN_TYPE,
  q = k.RETROACTIVE_ACTION_TYPES,
  r = k.DEFAULT_FORM_VALUES,
  s = k.getDateExpires,
  t = k.isBanTypeSupported,
  u = h.preventDefaultHandler,
  v = c.View.extend({
    className: 'moderate',
    initialize: function (b) {
      this.forum = b.forum;
      var c = [
        l.getSaasFeatures(this.model.get('forum'))
      ];
      this.model.get('ipAddress') && this.model.author.get('email') || c.push(this.model.fetch()),
      this.loading = a.when.apply(a, c)
    },
    render: function () {
      var a = this,
      b = this.$el;
      return b.addClass('loading'),
      f.trigger('uiAction:viewBanUser'),
      this.loading.always(function (c) {
        var e = a.model.author,
        f = i.get(p);
        a.saasFeatures = c,
        a.formValues = _extends({
        }, r, {
          type: t(f, c) ? f : n.PERMANENT,
          username: e.get('username'),
          email: e.get('email'),
          user: e.get('id'),
          postId: a.model.id
        }, a.formValues),
        b.removeClass('loading'),
        b.html(j({
          user: e.toJSON(),
          listName: o.BLACKLIST,
          ipAddress: a.model.get('ipAddress'),
          formValues: a.formValues,
          supportsShadowBanning: t(n.SHADOW, a.saasFeatures),
          supportsTempBanning: t(n.TEMP, a.saasFeatures),
          selectRetroactiveAction: a.selectRetroactiveAction.bind(a),
          toggleBanTypeCallback: a.toggleBanTypeCallback.bind(a),
          toggleUserValueChecked: a.toggleUserValueChecked.bind(a),
          toggleIpAddressChecked: a.toggleIpAddressChecked.bind(a),
          updateReason: a.updateReason.bind(a),
          updateDuration: a.updateDuration.bind(a),
          updateCustomDurationAmount: a.updateCustomDurationAmount.bind(a),
          updateCustomDurationScale: a.updateCustomDurationScale.bind(a),
          handleSubmit: a.submit.bind(a),
          handleClose: a.cancel.bind(a),
          closeText: 'Cancel',
          UpgradeIcon: function () {
            return d.createElement('span', {
              className: 'text-largest text-yellow icon-upgrade-arrow-pro media-middle spacing-left upgrade-card',
              'data-role': 'upgrade-card-target'
            })
          }
        })),
        a.initUpgradeCard()
      }),
      this.trigger('render'),
      this
    },
    initUpgradeCard: function () {
      var b = m.UpgradeCard.create({
        organization: this.forum ? {
          id: this.forum.get('organizationId')
        }
         : null
      });
      this.$('[data-role=upgrade-card-target]').each(function () {
        b.target(a(this))
      }),
      this.listenToOnce(b, 'show', function () {
        f.trigger('uiAction:viewUpgradeCard')
      }),
      this.listenTo(b, 'click:upgrade', function (a) {
        a.stopPropagation(),
        f.trigger('uiAction:clickUpgrade')
      })
    },
    toggleBanType: function (a, b) {
      t(b, this.saasFeatures) && (this.formValues.type = b, i.set(p, b), this.render())
    },
    toggleBanTypeCallback: function (a) {
      this.toggleBanType(a, a.target.value)
    },
    selectRetroactiveAction: function (a) {
      this.formValues.retroactiveAction = a.target.value || q.DO_NOTHING
    },
    toggleUserValueChecked: function (a, b) {
      this.formValues[b] = a.target.checked ? 1 : 0
    },
    toggleIpAddressChecked: function (a) {
      this.formValues.ipAddress = a.target.checked ? 1 : 0
    },
    updateReason: function (a) {
      this.formValues.reason = a.target.value
    },
    updateDuration: function (a) {
      this.formValues.durationHours = a.target.value
    },
    updateCustomDurationAmount: function (a) {
      var b = this;
      if ('keypress' === a.type && /[^\d]/.test(a.key)) return void a.preventDefault();
      var c = a.target.value,
      d = 'custom';
      this.formValues.customDurationAmount === c && this.formValues.durationHours === d || (this.formValues.customDurationAmount = c, this.formValues.durationHours = d, a.target === window.document.activeElement && this.once('render', function () {
        b.$('input[name=customDurationAmount]').focus()
      }), this.render())
    },
    updateCustomDurationScale: function (a) {
      this.formValues.customDurationScale = a.target.value,
      this.formValues.durationHours = 'custom',
      this.render()
    },
    cancel: u(function () {
      this.trigger('cancel')
    }),
    submit: u(function () {
      var a = this,
      c = this.formValues.type === n.TEMP ? s(this.formValues) : null;
      f.trigger('uiAction:clickBanUser', JSON.stringify({
        date_expires: c,
        date_added: e().toISOString()
      }));
      var d = {
        post: this.formValues.postId,
        notes: this.formValues.reason,
        shadowBan: this.formValues.type === n.SHADOW ? 1 : 0,
        dateExpires: c
      };
      this.formValues.email && (d.banEmail = 1),
      this.formValues.username && (d.banUser = 1),
      this.formValues.ipAddress && (d.banIp = 1),
      this.formValues.type === n.PERMANENT && (d.retroactiveAction = this.formValues.retroactiveAction),
      d.post && g.call('forums/block/banPostAuthor.json', {
        method: 'POST',
        data: b.omit(d, b.isNull),
        success: function () {
          a.trigger('success')
        }
      })
    })
  }, {
    defaultFormValues: {
      postId: null,
      username: null,
      email: null,
      ipAddress: null,
      reason: '',
      retroactiveAction: null
    }
  });
  return v
}),
define('templates/lounge/edit', [
  'react',
  'core/switches'
], function (a, b) {
  'use strict';
  var c = function (c) {
    var d = c.forum.id,
    e = b.isFeatureActive('embed_refresh', {
      forum: d
    }),
    f = b.isFeatureActive('embed_v2', {
      forum: d
    }),
    g = e ? 'textarea-outer-wrapper textarea-outer-wrapper--refresh' : 'textarea-outer-wrapper',
    h = f ? 'textarea-wrapper textarea-wrapper--embedv2' : 'textarea-wrapper';
    return a.createElement('div', {
      className: g
    }, a.createElement('div', {
      className: 'ratings-wrapper',
      'data-role': 'ratings-container'
    }), a.createElement('div', {
      className: h,
      'data-role': 'textarea'
    }, a.createElement('div', {
      className: 'edit-alert',
      role: 'postbox-alert'
    }), a.createElement('div', {
      className: 'text-editor-container'
    })))
  };
  return c
}),
define('lounge/views/posts/PostEditView', [
  'backbone',
  'moment',
  'underscore',
  'core/bus',
  'core/mixins/withAlert',
  'core/strings',
  'core/switches',
  'core/time',
  'core/views/TextareaView',
  'core/utils/threadRatingsHelpers',
  'lounge/common',
  'lounge/mixins/asTextEditor',
  'lounge/mixins/asTextEditorV2',
  'lounge/mixins/withStarRatings',
  'lounge/views/posts/DummyTextareaView',
  'templates/lounge/edit',
  'templates/lounge/textEditor'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q) {
  'use strict';
  var r = f.get,
  s = a.View.extend({
    tagName: 'form',
    className: 'edit',
    events: {
      submit: 'submitForm',
      'click [data-action=cancel]': 'cancel'
    },
    initialize: function (a) {
      this.post = a.post,
      this.session = a.session,
      this.thread = a.thread,
      this.isRefreshEnabled = g.isFeatureActive('embed_refresh', {
        forum: this.thread.forum.id
      }),
      this.isRefreshV2Enabled = this.isRefreshEnabled && g.isFeatureActive('embed_refresh_v2', {
        forum: this.thread.forum.id
      }),
      this.$el.addClass(this.isRefreshEnabled ? 'form-refresh' : ''),
      this.$el.addClass(this.isRefreshV2Enabled ? 'form-refresh-v2' : ''),
      this._alertSelector = '[role=postbox-alert]',
      this.textEditorTemplate = q,
      this.postEditMode = !0
    },
    cancel: function () {
      this.trigger('cancel')
    },
    getEditTimeLeft: function () {
      var a,
      c = b().format(h.ISO_8601);
      return a = c < this.post.get('editableUntil') ? f.interpolate(r('You have until %(editableUntil)s to edit this comment.'), {
        editableUntil: this.post.getRelativeCreatedAt('editableUntil')
      }) : r('The edit period for this comment has expired.'),
      '<div class="edit-time-left">' + a + ' <a class="edit-time-message"href="https://help.disqus.com/commenting/remove-and-edit-your-comments"target="_blank"rel="noopener noreferrer"align="center">' + r('Learn more') + '</a></div>'
    },
    getEditorProps: function () {
      return {
        focusOnLoad: !0,
        onSubmit: this.submitForm.bind(this, null),
        isEdit: !0,
        onCancel: this.cancel.bind(this),
        initialState: this.post.toJSON().message
      }
    },
    render: function () {
      var a = this.post.toJSON();
      this.$el.html(p({
        post: a,
        user: this.session.toJSON(),
        forum: this.thread.forum
      }));
      var b = this.getEditTimeLeft();
      if (this.isEmbedV2Enabled) this.loadEditorV2(this.getEditorProps()),
      this.textarea = new o,
      this.$('[data-role=textarea]').after(b);
       else {
        this.initTextEditor();
        var c = this.textarea = new i({
          value: a.raw_message
        });
        this.$('[data-role=textarea]').prepend(c.render().el).after(b)
      }
      return this.initStarRatings(),
      this
    },
    resize: function () {
      var a = k.getLounge();
      a && this.textarea && this.textarea.$input && this.textarea.$input.on('transitionend webkitTransitionEnd oTransitionEnd otransitionend MSTransitionEnd', function () {
        a.resize()
      }),
      this.textarea.resize()
    },
    submitForm: function (a, b) {
      this.dismissAlert(),
      a && a.preventDefault() && a.preventDefault();
      var e = this,
      f = {
        raw_message: b || this.textarea.get(),
        rating: this.rating
      },
      g = e.post.validateMessage(f);
      return void 0 !== g ? this.alert(g, {
        type: 'error'
      }) : void e.post.save(f, {
        success: function () {
          e.trigger('submitted'),
          d.trigger('uiCallback:postUpdated', e.post, {
            area: 'main'
          }),
          c.isNumber(e.rating) && j.isThreadModelRatingsEnabled(e.thread) && (e.thread.set('userRating', e.rating), c.delay(c.bind(e.thread.fetchRatings, e.thread), 500))
        },
        error: function (a, b) {
          var c;
          return c = b.response.indexOf('Comment edit period expired') > - 1 ? r('You can no longer edit this comment. Comments can only be edited within 7 days after posting.') + ' <a href="https://help.disqus.com/commenting/remove-and-edit-your-comments" target="_blank" rel="noopener noreferrer"style="color:white ! important" >' + r('Learn more') + '</a>' : b.response,
          e.alert(c, {
            type: 'error',
            safe: !0
          })
        }
      })
    },
    remove: function () {
      this.$el.remove()
    }
  });
  return e.call(s.prototype),
  n.call(s.prototype),
  l.call(s.prototype),
  m.call(s.prototype),
  s
}),
define('lounge/views/posts/TypingUserView', [
  'backbone',
  'core/strings',
  'core/switches',
  'core/utils/object/get'
], function (a, b, c, d) {
  'use strict';
  var e = b.get,
  f = a.View.extend({
    initialize: function (a) {
      this.options = a
    },
    render: function () {
      var a,
      d = this.options.parentView.reply,
      f = d && d.typingUser,
      g = this.model.usersTyping.count(f && f.id),
      h = c.isFeatureActive('embed_refresh', {
        forum: this.model.get('forum')
      });
      return g <= 0 ? void this.$el.hide() : (1 === g ? a = e(h ? '1 person writing a comment…' : 'One other person is typing…') : (a = e(h ? '%(num)s people writing comments…' : '%(num)s other people are typing…'), a = b.interpolate(a, {
        num: g
      })), this.$el.text(a), this.$el.show(), this)
    }
  });
  return f
});
var _extends = Object.assign || function (a) {
  for (var b = 1; b < arguments.length; b++) {
    var c = arguments[b];
    for (var d in c) Object.prototype.hasOwnProperty.call(c, d) && (a[d] = c[d])
  }
  return a
};
define('templates/lounge/flaggingReasons', [
  'react',
  'core/strings',
  'core/switches'
], function (a, b, c) {
  'use strict';
  var d = b.gettext,
  e = [
    {
      id: 6,
      title: d('I disagree with this user')
    },
    {
      id: 0,
      title: d('Targeted harassment'),
      description: d('posted or encouraged others to post harassing comments or hate speech targeting me, other individuals, or groups')
    },
    {
      id: 1,
      title: d('Spam'),
      description: d('posted spam comments or discussions')
    },
    {
      id: 2,
      title: d('Inappropriate profile'),
      description: d('profile contains inappropriate images or text')
    },
    {
      id: 3,
      title: d('Threatening content'),
      description: d('posted directly threatening content')
    },
    {
      id: 4,
      title: d('Impersonation'),
      description: d('misrepresents themselves as someone else')
    },
    {
      id: 5,
      title: d('Private information'),
      description: d('posted someone else\'s personally identifiable information')
    }
  ],
  f = function (b) {
    var c = b.id,
    d = b.title,
    e = b.description,
    f = b.updateReason;
    return a.createElement('label', {
      className: [
        'padding-default',
        'flagging__reason'
      ].join(' ')
    }, a.createElement('input', {
      type: 'radio',
      name: 'reason',
      value: c,
      onChange: f
    }), a.createElement('p', {
      className: 'text-bold flagging__reason-text'
    }, d, e ? a.createElement('span', {
      className: 'text-small text-normal'
    }, ' — ', e) : null))
  },
  g = function (b) {
    var g = b.updateReason,
    h = b.handleSubmit,
    i = b.handleCancel,
    j = b.forumId;
    return a.createElement('form', {
      className: 'flagging-form'
    }, a.createElement('div', {
      className: 'flagging__title text-semibold'
    }, d('Flag Comment')), a.createElement('div', {
      className: 'flagging__content'
    }, a.createElement('p', {
      className: 'flagging__subtitle text-semibold'
    }, d('Why are you flagging this comment?')), e.map(function (b) {
      return a.createElement(f, _extends({
        key: b.id,
        updateReason: g
      }, b))
    }), a.createElement('p', {
      className: 'flagging__reason-subtext'
    }, c.isFeatureActive('sso_less_branding', {
      forum: j
    }) ? d('Your username will be shown to the moderator, so you should only flag this comment for one of the reasons listed above.') : d('Before flagging, please keep in mind that %(disqus)s does not moderate communities. Your username will be shown to the moderator, so you should only flag this comment for one of the reasons listed above.', {
      disqus: 'Disqus'
    }))), a.createElement('div', {
      className: 'admin-modal__footer -mobile clearfix'
    }, a.createElement('button', {
      className: 'button button-fill--brand',
      onClick: h
    }, d('Flag Comment')), ' ', a.createElement('button', {
      className: 'button button-fill',
      onClick: i
    }, d('Cancel'))))
  };
  return g
}),
define('templates/lounge/flaggingUserBlocking', [
  'react',
  'core/strings',
  'core/switches',
  'templates/lounge/partials/profileLink'
], function (a, b, c, d) {
  'use strict';
  var e = b.gettext,
  f = function (b) {
    var f = b.user,
    g = b.forumId,
    h = b.handleBlock,
    i = b.handleComplete;
    return a.createElement('div', {
      className: 'flagging__blocking-form'
    }, a.createElement('div', {
      className: 'flagging__title text-semibold'
    }, e('Thanks for your feedback!')), c.isFeatureActive('sso_less_branding', {
      forum: g
    }) ? a.createElement('div', {
      className: 'admin-modal__footer -mobile clearfix'
    }, a.createElement('button', {
      className: 'button button-fill--brand',
      onClick: i
    }, e('Done'))) : [
      a.createElement('div', {
        key: 'blocking-0',
        className: 'flagging__blocking-content'
      }, a.createElement('p', {
        className: 'flagging__subtitle text-semibold'
      }, e('Other tools for you:')), a.createElement('p', {
        className: 'spacing-bottom'
      }, e('Blocking this user will hide all of their activity and comments from your %(disqus)s content, feeds, and notifications.', {
        disqus: 'Disqus'
      })), a.createElement('p', {
        className: 'spacing-top spacing-bottom-none'
      }, e('Would you like to block %(user)s?', {
        user: a.createElement(d, {
          user: f,
          forumId: g,
          className: 'text-semibold'
        }, f.name)
      }))),
      a.createElement('div', {
        key: 'blocking-1',
        className: 'admin-modal__footer -mobile clearfix'
      }, a.createElement('div', null, a.createElement('button', {
        className: 'button button-fill--red',
        onClick: h
      }, e('Block User')), ' ', a.createElement('button', {
        className: 'button button-fill',
        onClick: i
      }, e('No Thanks'))))
    ])
  };
  return f
}),
define('templates/lounge/flaggingUserBlocked', [
  'react',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.gettext,
  d = function (b) {
    var d = b.displayName,
    e = b.handleComplete,
    f = b.error;
    return a.createElement('div', {
      className: 'flagging__blocking-complete'
    }, a.createElement('div', {
      className: 'flagging__title'
    }, c('Blocked User')), a.createElement('div', {
      className: 'flagging__blocking-complete-content'
    }, a.createElement('img', {
      className: 'flagging-pam',
      alt: 'Pam',
      src: 'https://c.disquscdn.com/next/embed/assets/img/PamX.fe88e2955f3d594a6cc13c66569ed7d0.svg'
    }), f ? a.createElement('p', {
      className: 'spacing-top-bottom'
    }, f) : a.createElement('div', null, a.createElement('p', {
      className: 'spacing-top-bottom text-semibold'
    }, c('You\'ve blocked %(user)s.', {
      user: d
    })), a.createElement('p', {
      className: 'spacing-top-bottom'
    }, c('You won\'t see comments from this user on %(disqus)s in discussions, notifications, and more.', {
      disqus: 'Disqus'
    })))), a.createElement('div', {
      className: 'admin-modal__footer -mobile clearfix'
    }, a.createElement('div', null, a.createElement('button', {
      className: 'button button-fill--brand',
      onClick: e
    }, c('Done')), ' ', a.createElement('a', {
      className: 'button button-fill',
      href: 'https://disqus.com/home/settings/blocking/',
      target: '_blank',
      rel: 'noopener noreferrer',
      onClick: e
    }, c('Manage Blocked Users')))))
  };
  return d
}),
define('lounge/views/posts/FlaggingView', [
  'backbone',
  'core/api',
  'core/utils',
  'core/bus',
  'core/strings',
  'templates/lounge/flaggingReasons',
  'templates/lounge/flaggingUserBlocking',
  'templates/lounge/flaggingUserBlocked'
], function (a, b, c, d, e, f, g, h) {
  'use strict';
  var i = c.preventDefaultHandler,
  j = e.gettext,
  k = a.View.extend({
    className: 'moderate',
    render: function () {
      if (this.model.get('isFlaggedByUser')) if (this.blockComplete) {
        var a = this.model.author;
        this.$el.html(h({
          displayName: a.get('name'),
          error: this.blockError,
          handleComplete: this.handleComplete.bind(this)
        }))
      } else {
        var b = this.model.author;
        this.$el.html(g({
          user: b.toJSON(),
          forumId: this.model.get('forum'),
          handleBlock: this.handleBlockUser.bind(this),
          handleComplete: this.handleComplete.bind(this)
        })),
        d.trigger('uiAction:viewBlockUser')
      } else this.$el.html(f({
        updateReason: this.updateFlaggingReason.bind(this),
        handleSubmit: this.submitReason.bind(this),
        handleCancel: this.cancel.bind(this),
        forumId: this.model.get('forum')
      })),
      d.trigger('uiAction:viewFlagPost');
      return this
    },
    updateFlaggingReason: function (a) {
      this.reason = a.target.value
    },
    cancel: i(function () {
      this.trigger('cancel')
    }),
    handleComplete: function () {
      this.trigger('success')
    },
    submitReason: i(function () {
      this.reason && (d.trigger('uiAction:clickFlagPost'), this.model.report(this.reason), this.model.set('isFlaggedByUser', !0), this.render())
    }),
    handleBlockUser: i(function () {
      var a = this,
      c = this.model.author;
      return d.trigger('uiAction:clickBlockUser'),
      c.block().fail(function (c) {
        var d = j('Something went wrong while trying to block this user. Please try again later.'),
        e = c && c.responseJSON && c.responseJSON.code;
        e === b.ERROR_CODES.MAX_ITEMS_REACHED && (d = j('Unfortunately this user could not be blocked; you have reached the limit for number of users blocked.')),
        a.blockError = d
      }).always(function () {
        a.blockComplete = !0,
        a.render()
      })
    })
  });
  return k
}),
define('core/views/Tooltip', [
  'jquery',
  'core/views/common/HoverCard'
], function (a, b) {
  'use strict';
  var c = b.extend({
    className: 'tooltip-outer message-card',
    initialize: function (a) {
      b.prototype.initialize.call(this, a),
      this.template = a.template,
      this.message = a.message
    },
    render: function () {
      if (this.template) this.$el.html(this.template());
       else {
        if (!this.message) return;
        this.$el.html(a('<div>').addClass('tooltip').text(this.message))
      }
      b.prototype.render.call(this)
    },
    moveTo: function (a) {
      if (a) {
        var b = this.constructor.POSITION_OFFSET,
        c = a.offset(),
        d = this.getContainerPosition(),
        e = this.$el.width();
        this.$el.css({
          bottom: d.containerOffset.height - c.top + b,
          top: 'inherit',
          left: c.left - e / 2
        })
      }
    }
  }, {
    create: function (a) {
      return b.create(a.id, a, 'Tooltip', c)
    },
    POSITION_OFFSET: 10
  });
  return c
}),
define('core/views/ClickTooltip', [
  'underscore',
  'core/views/common/HoverCard',
  'core/views/Tooltip'
], function (a, b, c) {
  'use strict';
  var d = c.extend({
    target: function (b) {
      b.on('click', a.bind(this.targetClicked, this, b)),
      b.on('mouseleave', a.bind(this.leave, this))
    },
    targetClicked: function (a) {
      a && (this.$target = a),
      'in' !== this._hoverState && (this._hoverState = 'in', this.show(), c.open[this.uid] = this)
    }
  }, {
    create: function (a) {
      return b.create(a.id, a, 'ClickTooltip', d)
    }
  });
  return d
}),
define('templates/lounge/partials/postVotes', [
  'react',
  'core/constants/voteConstants',
  'core/strings',
  'core/switches',
  'core/utils/object/get'
], function (a, b, c, d, e) {
  'use strict';
  var f = c.gettext,
  g = function (c) {
    var g = d.isFeatureActive('embed_refresh', {
      forum: c.forumId
    }),
    h = a.createElement('span', {
      className: 'control'
    }, g ? null : a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon icon-arrow-2'
    })),
    i = a.createElement('span', {
      className: 'updatable count',
      'data-role': 'likes'
    }, e(c.post, [
      'likes'
    ], null)),
    j = g ? [
      h,
      ' ',
      i
    ] : [
      i,
      ' ',
      h
    ];
    return c.votingType === b.VOTING_TYPES.DISABLED ? null : a.createElement('div', {
      className: 'post-votes'
    }, a.createElement('a', {
      href: '#',
      className: 'vote-up ' + (e(c.post, [
        'userScore'
      ], 0) > 0 ? 'upvoted' : '') + ' count-' + e(c.post, [
        'likes'
      ], ''),
      'data-action': 'upvote',
      title: e(c.post, [
        'likes'
      ]) ? '' : f('Vote up'),
      name: f('Vote up')
    }, j), c.votingType === b.VOTING_TYPES.DOWNVOTE_DISABLED || g ? null : a.createElement('div', {
      className: 'post-votes__separator'
    }, ''), c.votingType === b.VOTING_TYPES.DOWNVOTE_DISABLED ? null : a.createElement('a', {
      href: '#',
      className: 'vote-down ' + (e(c.post, [
        'userScore'
      ], 0) < 0 ? 'downvoted' : '') + ' count-' + (c.votingType === b.VOTING_TYPES.DOWNVOTE_LIMITED ? 0 : e(c.post, [
        'dislikes'
      ], '')),
      'data-action': 'downvote',
      title: e(c.post, [
        'dislikes'
      ]) ? '' : f('Vote down'),
      name: f('Vote down')
    }, a.createElement('span', {
      className: 'control'
    }, g ? null : a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon icon-arrow'
    })), ' ', a.createElement('span', {
      className: 'updatable count',
      'data-role': 'dislikes'
    }, c.votingType === b.VOTING_TYPES.DOWNVOTE_LIMITED ? null : e(c.post, [
      'dislikes'
    ], null))))
  };
  return g
}),
define('templates/lounge/partials/postFooter', [
  'react',
  'core/constants/voteConstants',
  'core/strings',
  'core/switches',
  'core/utils/object/get',
  'templates/lounge/partials/postVotes'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = c.gettext,
  h = function (c) {
    var h = (e(c.session, [
      'isRegistered'
    ]) || !d.isFeatureActive('sso_less_branding', {
      forum: c.post.forum
    })) && c.votingType !== b.VOTING_TYPES.DISABLED,
    i = d.isFeatureActive('sso_less_branding', {
      forum: c.post.forum
    }) ? e(c.post, [
      'permalink'
    ], '') : e(c.post, [
      'shortLink'
    ], ''),
    j = d.isFeatureActive('embed_refresh', {
      forum: c.post.forum
    }),
    k = j && d.isFeatureActive('embed_refresh_v2', {
      forum: c.post.forum
    }),
    l = j ? 'realtime-replies realtime-replies--refresh icon icon-pencil' : 'realtime-replies',
    m = j ? 'realtime-button realtime-button--refresh' : 'realtime-button';
    return a.createElement('menu', {
      className: 'comment-footer__menu'
    }, h ? [
      a.createElement('li', {
        key: 'vote-0',
        className: 'voting',
        'data-role': 'voting'
      }, a.createElement(f, {
        post: c.post,
        votingType: c.votingType,
        forumId: c.forumId
      })),
      j && k ? null : a.createElement('li', {
        key: 'vote-1',
        className: 'bullet',
        'aria-hidden': 'true'
      }, '•')
    ] : null, e(c.post, [
      'canBeEdited'
    ]) ? a.createElement('li', {
      key: 'edit-0',
      className: 'edit',
      'data-role': 'edit-link'
    }, a.createElement('a', {
      className: 'comment-footer__action',
      href: '#',
      'data-action': 'edit'
    }, a.createElement('i', {
      className: 'icon icon-pencil-large'
    }), a.createElement('span', {
      className: 'text'
    }, g('Edit')))) : null, e(c.post, [
      'canBeRepliedTo'
    ]) ? a.createElement('li', {
      key: 'reply-0',
      className: 'reply',
      'data-role': 'reply-link'
    }, a.createElement('a', {
      className: 'comment-footer__action',
      href: '#',
      'data-action': 'reply'
    }, a.createElement('span', {
      className: 'text'
    }, g('Reply')))) : null, e(c.post, [
      'isSponsored'
    ]) && !e(c.post, [
      'hideViewAllComments'
    ]) ? [
      a.createElement('li', {
        key: 'sponsored-0',
        className: 'thread-link',
        'data-role': 'thread-link'
      }, a.createElement('a', {
        href: e(c.post, [
          'permalink'
        ], ''),
        target: '_blank',
        rel: 'noopener noreferrer',
        'data-action': 'thread'
      }, a.createElement('i', {
        className: 'icon icon-mobile'
      }), a.createElement('span', {
        className: 'text'
      }, g('View all comments')), a.createElement('span', {
        className: 'mobile-text'
      }, g('All Comments')))),
      a.createElement('li', {
        key: 'sponsored-1',
        className: 'bullet',
        'aria-hidden': 'true'
      }, '•')
    ] : null, e(c.post, [
      'canBeShared'
    ]) ? a.createElement('li', {
      id: 'comment__share-' + e(c.post, [
        'id'
      ], ''),
      className: 'comment__share'
    }, a.createElement('a', {
      className: 'toggle',
      href: '#',
      'data-action': 'expand-share'
    }, a.createElement('i', {
      className: 'icon icon-share'
    }), a.createElement('span', {
      className: 'text'
    }, g('Share'), ' ›')), a.createElement('ul', {
      className: 'comment-share__buttons'
    }, c.disableSocialShare ? null : a.createElement('div', {
      className: 'comment-share__social-share-buttons'
    }, a.createElement('li', {
      className: 'twitter share__button-container'
    }, a.createElement('button', {
      className: 'share__button icon icon-twitter-x',
      'data-action': 'share:twitter',
      'aria-label': 'Share comment on X (Twitter)'
    })), a.createElement('li', {
      className: 'facebook share__button-container'
    }, a.createElement('button', {
      className: 'share__button icon icon-facebook',
      'data-action': 'share:facebook',
      'aria-label': 'Share comment on Facebook'
    }))), a.createElement('li', {
      className: 'link share__button-container'
    }, a.createElement('button', {
      className: 'share__button icon icon-link',
      value: i,
      name: g('Link'),
      title: g('Click to copy post link'),
      'data-action': 'copy-link',
      'aria-label': 'Copy link to comment'
    }), d.isFeatureActive('sso_less_branding', {
      forum: c.post.forum
    }) ? null : a.createElement('input', {
      className: 'share__button link_url',
      value: i,
      name: g('Link'),
      title: g('Click to copy post link'),
      'data-action': 'copy-link',
      readOnly: !0
    })))) : null, e(c.post, [
      'isDeleted'
    ]) ? null : a.createElement('li', {
      className: 'realtime',
      'data-role': 'realtime-notification:' + e(c.post, [
        'id'
      ], '')
    }, a.createElement('span', {
      style: {
        display: 'none'
      },
      className: l
    }), a.createElement('a', {
      style: {
        display: 'none'
      },
      href: '#',
      className: m
    })), e(c.post, [
      'isSponsored'
    ]) ? a.createElement('li', {
      className: 'feedback'
    }, a.createElement('button', {
      'data-action': 'feedback'
    }, g('Leave Feedback'))) : null)
  };
  return h
});
var _extends = Object.assign || function (a) {
  for (var b = 1; b < arguments.length; b++) {
    var c = arguments[b];
    for (var d in c) Object.prototype.hasOwnProperty.call(c, d) && (a[d] = c[d])
  }
  return a
};
define('templates/lounge/partials/postMenu', [
  'react',
  'core/config/urls',
  'core/strings',
  'core/switches',
  'core/utils/object/get'
], function (a, b, c, d, e) {
  'use strict';
  var f = c.gettext,
  g = function (a, c, d, g) {
    var h = [
    ],
    i = e(c, [
      'thread',
      'canModerate'
    ]),
    j = e(c, [
      'isRegistered'
    ]),
    k = j && e(a, [
      'author'
    ]) && e(a, [
      'author',
      'id'
    ]) === e(c, [
      'id'
    ]);
    if (i) {
      if (h = [
        {
          link: '#',
          action: 'spam',
          text: f('Mark as Spam')
        },
        {
          link: '#',
          action: 'delete',
          text: f('Delete')
        },
        {
          link: '#',
          action: 'blacklist',
          text: f('Ban User')
        },
        {
          link: b.moderate + 'approved/search/id:' + e(a, [
            'id'
          ], ''),
          action: 'moderate',
          target: '_blank',
          rel: 'noopener noreferrer',
          text: f('Moderate')
        },
        {
          link: '#',
          action: e(a, [
            'isHighlighted'
          ]) ? 'unhighlight' : 'highlight',
          text: f(e(a, [
            'isHighlighted'
          ]) ? 'Stop featuring' : 'Feature this comment'),
          className: 'highlight-toggle'
        }
      ], d && !a.author.isAnonymous) {
        var l = 4;
        h.splice(l, 0, {
          link: '#',
          action: 'manage-badges',
          text: f('Manage Badges')
        })
      }
      k || g || h.unshift({
        link: '#',
        action: 'block-user',
        text: f('Block User')
      })
    } else k ? h = [
      {
        link: '#',
        action: 'delete',
        text: f('Delete')
      },
      {
        link: '#',
        action: 'flag',
        text: f(e(a, [
          'isFlaggedByUser'
        ]) ? 'Flagged' : 'Flag as inappropriate')
      }
    ] : j && (h = [
      {
        link: '#',
        action: 'block-user',
        text: f('Block User')
      },
      {
        link: '#',
        action: 'flag',
        text: f(e(a, [
          'isFlaggedByUser'
        ]) ? 'Flagged' : 'Flag as inappropriate')
      }
    ]);
    return h
  },
  h = function (b) {
    var c = null,
    h = e(b.session, [
      'thread',
      'canModerate'
    ]),
    i = d.isFeatureActive('sso_less_branding', {
      forum: b.post.forum
    }),
    j = b.forum && b.forum.settings && b.forum.settings.badgesEnabled,
    k = d.isFeatureActive('embed_refresh', {
      forum: b.post.forum
    }),
    l = g(b.post, b.session, j, i);
    return e(b.post, [
      'id'
    ]) && e(b.post, [
      'isMinimized'
    ]) !== !0 && e(b.post, [
      'isDeleted'
    ]) !== !0 && e(b.post, [
      'author',
      'isBlocked'
    ]) !== !0 && e(b.post, [
      'sb'
    ]) !== !0 && (l.length ? c = a.createElement('div', null, a.createElement('a', {
      className: 'dropdown-toggle',
      'data-toggle': 'dropdown',
      href: '#'
    }, k ? a.createElement('span', {
      className: 'dropdown-toggle-icon' + (h ? ' moderator-menu-options' : '')
    }) : a.createElement('b', {
      className: 'caret' + (h ? ' moderator-menu-options' : '')
    })), a.createElement('ul', {
      className: 'dropdown-menu' + (k ? ' dropdown-menu--refresh' : '')
    }, l.map(function (b) {
      var c = {
      };
      return b.rel && (c.rel = b.rel),
      b.target && (c.target = b.target),
      a.createElement('li', {
        key: b.action,
        className: 'dropdown-item ' + (b.className || '')
      }, a.createElement('a', _extends({
        className: 'dropdown-link',
        href: b.link,
        'data-action': b.action,
        role: 'menuitem'
      }, c), b.text))
    }))) : i || (c = a.createElement('a', {
      className: 'dropdown-toggle',
      href: '#',
      'data-action': 'flag',
      'data-role': 'flag',
      title: f('Flag as inappropriate')
    }, a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon icon-flag'
    })))),
    a.createElement('ul', {
      className: 'post-menu dropdown' + (k ? ' post-menu--refresh' : ''),
      'data-role': 'menu',
      'data-view-id': 'post-menu',
      'data-post-id': e(b.post, [
        'id'
      ])
    }, a.createElement('li', {
      className: 'post-menu-item collapse'
    }, a.createElement('a', {
      href: '#',
      'data-action': 'collapse',
      title: f('Collapse'),
      name: f('Collapse')
    }, a.createElement('span', null, '−'))), a.createElement('li', {
      className: 'post-menu-item expand'
    }, a.createElement('a', {
      href: '#',
      'data-action': 'collapse',
      title: f('Expand'),
      name: f('Collapse')
    }, a.createElement('span', null, '+'))), null === c ? null : a.createElement('li', {
      className: (h ? 'moderator-menu-options' : '') + ' post-menu-item',
      role: 'menuitem'
    }, c))
  };
  return h
}),
define('templates/lounge/partials/postUserAvatar', [
  'react',
  'core/strings',
  'core/switches',
  'core/utils',
  'core/utils/object/get',
  'templates/lounge/partials/userAvatar'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = b.gettext,
  h = d.getInitials,
  i = function (b) {
    var d = c.isFeatureActive('embed_refresh', {
      forum: b.forum && b.forum.id
    }),
    i = d ? 'user user--refresh' : 'user',
    j = d ? 'user image-refresh' : 'user',
    k = void 0;
    return k = e(b.post, [
      'author',
      'isRegistered'
    ]) && e(b.post, [
      'isMinimized'
    ]) !== !0 ? a.createElement('div', {
      className: 'avatar hovercard'
    }, a.createElement(f, {
      defaultAvatarUrl: b.defaultAvatarUrl,
      forum: b.forum,
      user: b.post.author,
      hasForumAvatar: b.hasForumAvatar
    })) : e(b.post, [
      'author',
      'hasSponsoredAvatar'
    ]) ? a.createElement('div', {
      className: 'avatar'
    }, a.createElement('div', {
      className: 'user'
    }, a.createElement('img', {
      src: b.defaultAvatarUrl,
      'data-src': e(b.post, [
        'author',
        'avatar',
        'cache'
      ], ''),
      className: 'user',
      alt: g('Avatar')
    }))) : a.createElement('div', {
      className: 'avatar'
    }, a.createElement('div', {
      className: i
    }, d && !b.hasForumAvatar ? a.createElement('div', null, h(b.post.author.name) || 'G') : a.createElement('img', {
      src: b.defaultAvatarUrl,
      className: j,
      alt: g('Avatar')
    })))
  };
  return i
}),
define('templates/lounge/partials/postWrapper', [
  'react',
  'core/strings',
  'core/switches',
  'core/utils/object/get',
  'templates/lounge/partials/postMenu'
], function (a, b, c, d, e) {
  'use strict';
  var f = b.gettext,
  g = function (b) {
    var g = [
      'post-content',
      d(b.post, [
        'isRealtime'
      ]) && 'new',
      d(b.session, [
        'isRegistered'
      ]) && d(b.post, [
        'author',
        'id'
      ]) === d(b.session, [
        'id'
      ]) && 'authored-by-session-user'
    ].filter(Boolean).join(' ');
    return [a.createElement('div', {
      key: 'post-wrapper-content',
      'data-role': 'post-content',
      className: g,
      tabIndex: 0
    }, a.createElement('div', {
      className: 'indicator'
    }), c.isFeatureActive('embed_refresh', {
      forum: b.forum && b.forum.id
    }) ? a.createElement('span', {
      className: 'pinned-icon'
    }) : null, a.createElement(e, {
      post: b.post,
      session: b.session,
      forum: b.forum
    }), b.children, a.createElement('div', {
      className: 'moderate-form blacklist-form',
      'data-role': 'blacklist-form'
    }), a.createElement('div', {
      className: 'moderate-form flag-form',
      'data-role': 'flagging-form'
    }), a.createElement('div', {
      className: 'badges-form',
      'data-role': 'badges-form'
    }), a.createElement('div', {
      className: 'reply-form-container',
      'data-role': 'reply-form'
    })),
    a.createElement('div', {
      className: 'children',
      key: 'post-wrapper-children'
    }, a.createElement('ul', {
      'data-role': 'children'
    }), a.createElement('div', {
      className: 'show-children-wrapper ' + (b.post.hasMore ? '' : 'hidden')
    }, a.createElement('a', {
      className: 'show-children',
      id: 'post-' + b.post.id + '-show-children',
      'data-action': 'show-children',
      href: '#'
    }, f('Show more replies'))))]
  };
  return g
}),
define('templates/lounge/post', [
  'react',
  'core/constants/voteConstants',
  'core/strings',
  'core/switches',
  'core/utils/object/get',
  'core/utils/threadRatingsHelpers',
  'templates/lounge/partials/postFooter',
  'templates/lounge/partials/postUserAvatar',
  'templates/lounge/partials/postWrapper',
  'templates/lounge/partials/profileLink',
  'templates/lounge/partials/userBadges'
], function (a, b, c, d, e, f, g, h, i, j, k) {
  'use strict';
  var l = c.gettext,
  m = function (a) {
    var b = e(a.parentPost, [
      'author',
      'id'
    ]),
    c = e(a.session, [
      'blockedUserIdSet'
    ]);
    return a.post.hideParent || !(!b || !c) && c.has(b)
  },
  n = function (b) {
    return e(b.post, [
      'author',
      'badge'
    ]) ? a.createElement('span', {
      className: 'badge',
      'data-type': 'tracked-badge'
    }, b.hasEmbedRefreshV2 ? a.createElement('span', {
      className: 'badge-content'
    }, e(b.post, [
      'author',
      'badge'
    ], null)) : e(b.post, [
      'author',
      'badge'
    ], null)) : e(b.post, [
      'author',
      'thread',
      'canModerate'
    ]) ? a.createElement('span', {
      className: 'badge moderator'
    }, b.hasEmbedRefreshV2 ? a.createElement('span', {
      className: 'badge-content'
    }, l('Mod')) : l('Mod')) : b.opBadgeEnabled && e(b.post, [
      'author',
      'thread',
      'isOP'
    ]) ? a.createElement('span', {
      className: 'badge'
    }, b.hasEmbedRefreshV2 ? a.createElement('span', {
      className: 'badge-content'
    }, l('OP')) : l('OP')) : null
  },
  o = function (b) {
    var c = e(b.author, [
      'isFollowing'
    ]),
    f = e(b.author, [
      'id'
    ]),
    g = e(b.session, [
      'id'
    ]);
    return !d.isFeatureActive('embed_refresh', {
      forum: b.forumId
    }) || f === g || e(b.author, [
      'isPrivate'
    ]) ? null : a.createElement('a', {
      'data-action': 'follow',
      'data-user': f,
      className: 'follow-user-container',
      tabIndex: '0'
    }, a.createElement('span', {
      className: 'follow-user' + (c ? ' is-following' : ''),
      'aria-label': l(c ? 'Unfollow' : 'Follow'),
      title: l(c ? 'Unfollow' : 'Follow')
    }))
  },
  p = function (b) {
    return !b.parentPost && f.isThreadRatingsEnabled(b.thread, b.forum) && b.post.author.threadRating ? a.createElement('span', {
      className: 'post-ratings'
    }, b.hasEmbedRefresh ? null : a.createElement('span', {
      className: 'bullet time-ago-bullet',
      'aria-hidden': 'true'
    }, '•'), a.createElement('span', {
      className: 'post-ratings-stars'
    }, a.createElement('div', {
      className: 'post-stars active',
      style: {
        width: Math.round(20 * b.post.author.threadRating) + '%'
      }
    }, a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★')), a.createElement('div', {
      className: 'post-stars inactive'
    }, a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★')))) : null
  },
  q = function (b) {
    return a.createElement('span', {
      className: 'post-meta'
    }, b.hasEmbedRefresh ? null : a.createElement('span', {
      className: 'bullet time-ago-bullet',
      'aria-hidden': 'true'
    }, '•'), ' ', e(b.post, [
      'id'
    ]) ? a.createElement('a', {
      href: e(b.post, [
        'permalink'
      ], ''),
      'data-role': 'relative-time',
      className: 'time-ago' + (b.hasEmbedRefresh && !b.hasEmbedRefreshV2 ? ' icon icon-clock' : ''),
      title: e(b.post, [
        'formattedCreatedAt'
      ], '')
    }, e(b.post, [
      'relativeCreatedAt'
    ], null)) : a.createElement('span', {
      className: 'time-ago' + (b.hasEmbedRefresh && !b.hasEmbedRefreshV2 ? ' icon icon-clock' : ''),
      'data-role': 'relative-time',
      title: e(b.post, [
        'formattedCreatedAt'
      ], '')
    }, e(b.post, [
      'relativeCreatedAt'
    ], null)), ' ', e(b.post, [
      'isEdited'
    ]) ? a.createElement('span', null, b.hasEmbedRefresh ? null : a.createElement('span', {
      className: 'bullet time-ago-bullet',
      'aria-hidden': 'true'
    }, '•'), ' ', a.createElement('span', {
      className: 'has-edit',
      'data-role': 'has-edit'
    }, l('edited'))) : null)
  },
  r = function (c) {
    return [a.createElement('div', {
      key: 'post-alert',
      role: 'alert'
    }),
    a.createElement(i, {
      key: 'post-wrapper',
      post: c.post,
      session: c.session,
      forum: c.forum
    }, a.createElement(h, {
      post: c.post,
      forum: c.forum,
      defaultAvatarUrl: c.defaultAvatarUrl,
      hasForumAvatar: c.hasForumAvatar
    }), a.createElement('div', {
      className: 'post-body'
    }, a.createElement('header', {
      className: 'comment__header'
    }, a.createElement('span', {
      className: 'post-byline'
    }, e(c.post, [
      'author',
      'isRegistered'
    ]) ? a.createElement('span', null, c.isInHome && e(c.post, [
      'author',
      'isPowerContributor'
    ]) ? a.createElement('a', {
      href: '#',
      className: 'icon__position -inline -allstar',
      'data-toggle': 'tooltip',
      'data-role': 'allstar',
      title: l('All-Star')
    }, a.createElement('span', {
      className: 'icon-allstar allstar__icon'
    })) : null, ' ', a.createElement('span', {
      className: 'author publisher-anchor-color'
    }, a.createElement(j, {
      user: e(c.post, [
        'author'
      ]),
      forumId: c.post.forum
    }, e(c.post, [
      'author',
      'name'
    ], null))), ' ', a.createElement(n, {
      post: c.post,
      forumId: c.forum.id,
      hasEmbedRefreshV2: d.isFeatureActive('embed_refresh', {
        forum: c.forum && c.forum.id
      }) && d.isFeatureActive('embed_refresh_v2', {
        forum: c.forum && c.forum.id
      }),
      opBadgeEnabled: c.isOnChannel
    }), d.isFeatureActive('sso_less_branding', {
      forum: c.forum.id
    }) ? null : a.createElement(o, {
      author: e(c.post, [
        'author'
      ]),
      session: c.session,
      forumId: c.forum.id
    }), a.createElement(k, {
      forum: c.forum,
      user: e(c.post, [
        'author'
      ]),
      context: 'post',
      limit: 4,
      postId: e(c.post, [
        'id'
      ])
    })) : a.createElement('span', {
      className: 'author'
    }, e(c.post, [
      'author',
      'name'
    ], null)), c.parentPost && !m(c) ? a.createElement('span', {
      className: 'parent-link-container'
    }, ' ', a.createElement('a', {
      href: e(c.parentPost, [
        'permalink'
      ], ''),
      className: 'parent-link',
      'data-role': 'parent-link'
    }, a.createElement('i', {
      'aria-label': 'in reply to',
      className: 'icon-forward',
      title: 'in reply to'
    }), ' ', e(c.parentPost, [
      'author',
      'name'
    ], null))) : null), ' ', d.isFeatureActive('embed_refresh', {
      forum: c.forum && c.forum.id
    }) ? [
      a.createElement(p, {
        parentPost: e(c, [
          'parentPost'
        ]),
        thread: c.thread,
        forum: c.forum,
        post: c.post,
        key: 'ratings',
        hasEmbedRefresh: !0
      }),
      ' ',
      a.createElement(q, {
        post: c.post,
        key: 'meta',
        hasEmbedRefresh: !0,
        hasEmbedRefreshV2: d.isFeatureActive('embed_refresh_v2', {
          forum: c.forum && c.forum.id
        })
      })
    ] : [
      a.createElement(q, {
        post: c.post,
        key: 'meta'
      }),
      ' ',
      a.createElement(p, {
        parentPost: e(c, [
          'parentPost'
        ]),
        thread: c.thread,
        forum: c.forum,
        post: c.post,
        key: 'ratings'
      })
    ], ' ', c.stateByline ? a.createElement('span', {
      className: 'state-byline state-byline-' + e(c.stateByline, [
        'style'
      ], '')
    }, a.createElement('span', {
      className: 'icon-mobile icon-' + e(c.stateByline, [
        'icon'
      ], ''),
      'aria-hidden': 'true'
    }), ' ', a.createElement('span', {
      className: 'text'
    }, e(c.stateByline, [
      'text'
    ], null))) : null), a.createElement('div', {
      className: 'post-body-inner'
    }, a.createElement('div', {
      className: 'post-message-container',
      'data-role': 'message-container'
    }, a.createElement('div', {
      className: 'publisher-anchor-color',
      'data-role': 'message-content'
    }, a.createElement('div', {
      className: 'post-message ' + (e(c.post, [
        'message'
      ]) ? '' : 'loading'),
      'data-role': 'message',
      dir: 'auto'
    }, '' === e(c.post, [
      'message'
    ]) ? a.createElement('p', null, a.createElement('i', null, l('This comment has no content.'))) : a.createElement('div', {
      dangerouslySetInnerHTML: {
        __html: e(c.post, [
          'message'
        ], '')
      }
    })), a.createElement('span', {
      className: 'post-media'
    }, a.createElement('ul', {
      'data-role': 'post-media-list'
    })))), a.createElement('a', {
      className: 'see-more hidden',
      title: l('see more'),
      'data-action': 'see-more'
    }, l('see more'))), a.createElement('footer', {
      className: 'comment__footer'
    }, a.createElement(g, {
      post: c.post,
      session: c.session,
      disableSocialShare: e(c.forum, [
        'settings',
        'disableSocialShare'
      ], !1),
      votingType: e(c.forum, [
        'votingType'
      ], b.VOTING_TYPES.DEFAULT_VOTING_TYPE),
      forumId: c.forum && c.forum.id
    }))))]
  };
  return r
}),
define('templates/lounge/postDeleted', [
  'react',
  'core/config/urls',
  'core/strings',
  'core/utils/object/get',
  'templates/lounge/partials/postMenu',
  'templates/lounge/partials/postWrapper'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = c.gettext,
  h = function (c) {
    return a.createElement(f, {
      post: c.post,
      session: c.session,
      forum: c.forum
    }, a.createElement('div', {
      className: 'avatar'
    }, a.createElement('img', {
      'data-src': d(b, [
        'avatar',
        'generic'
      ], ''),
      className: 'user',
      alt: g('Avatar')
    })), a.createElement('div', {
      className: 'post-body'
    }, a.createElement('div', {
      className: 'post-message'
    }, a.createElement('p', null, g('This comment was deleted.'))), a.createElement('header', null, a.createElement(e, {
      post: c.post,
      session: c.session,
      forum: c.forum
    }))))
  };
  return h
}),
define('templates/lounge/postBlocked', [
  'react',
  'core/config/urls',
  'core/strings',
  'core/utils/object/get',
  'core/switches',
  'templates/lounge/partials/postWrapper'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = c.gettext,
  h = function (c) {
    return a.createElement(f, {
      post: c.post,
      session: c.session,
      forum: c.forum
    }, a.createElement('div', {
      className: 'avatar'
    }, a.createElement('img', {
      'data-src': d(b, [
        'avatar',
        'generic'
      ], ''),
      className: 'user',
      alt: g('Avatar')
    })), a.createElement('div', {
      className: 'post-body'
    }, a.createElement('div', {
      className: 'post-message'
    }, a.createElement('p', null, g('Content unavailable')))))
  };
  return h
}),
define('templates/lounge/postMinimized', [
  'react',
  'core/strings',
  'core/utils/object/get',
  'templates/lounge/partials/postMenu',
  'templates/lounge/partials/postUserAvatar',
  'templates/lounge/partials/postWrapper'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = b.gettext,
  h = function (b) {
    var d = void 0;
    return d = c(b.post, [
      'isApproved'
    ]) ? a.createElement('p', null, g('Comment score below threshold.'), ' ', a.createElement('a', {
      href: '#',
      'data-action': 'reveal'
    }, g('Show comment.'))) : b.created ? a.createElement('p', null, g('Your comment is awaiting moderation.'), ' ', a.createElement('a', {
      href: '#',
      'data-action': 'reveal'
    }, g('See your comment.')), ' ', a.createElement('a', {
      href: 'https://help.disqus.com/customer/portal/articles/466223',
      className: 'help-icon',
      title: g('Why?'),
      target: '_blank',
      rel: 'noopener noreferrer'
    }), ' ') : a.createElement('p', null, g('This comment is awaiting moderation.'), ' ', a.createElement('a', {
      href: '#',
      'data-action': 'reveal'
    }, g('Show comment.')))
  },
  i = function (b) {
    return a.createElement(f, {
      post: b.post,
      session: b.session,
      forum: b.forum
    }, a.createElement(e, {
      post: b.post,
      forum: b.forum,
      defaultAvatarUrl: b.defaultAvatarUrl
    }), a.createElement('div', {
      className: 'post-body'
    }, a.createElement('div', {
      className: 'post-message publisher-anchor-color'
    }, a.createElement(h, {
      create: b.created,
      post: b.post
    })), a.createElement('header', null, a.createElement('div', {
      className: 'post-meta'
    }, g('This comment is awaiting moderation.')), a.createElement(d, {
      post: b.post,
      session: b.session,
      forum: b.forum
    }))))
  };
  return i
}),
define('templates/lounge/postSpam', [
  'react',
  'core/config/urls',
  'core/strings',
  'core/utils/object/get',
  'templates/lounge/partials/postMenu',
  'templates/lounge/partials/postWrapper'
], function (a, b, c, d, e, f) {
  'use strict';
  var g = c.gettext,
  h = function (c) {
    return a.createElement(f, {
      post: c.post,
      session: c.session,
      forum: c.forum
    }, a.createElement('div', {
      className: 'avatar'
    }, a.createElement('img', {
      'data-src': d(b, [
        'avatar',
        'generic'
      ], ''),
      className: 'user',
      alt: g('Avatar')
    })), a.createElement('div', {
      className: 'post-body'
    }, a.createElement('div', {
      className: 'post-message'
    }, a.createElement('p', null, g('This comment was marked as spam.'))), a.createElement('header', null, a.createElement(e, {
      post: c.post,
      session: c.session,
      forum: c.forum
    }))))
  };
  return h
}),
define('templates/lounge/anonUpvoteCard', [
  'react',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.gettext,
  d = function () {
    return a.createElement('div', {
      className: 'vote-action tooltip'
    }, c('You must sign in to up-vote this post.'))
  };
  return d
}),
define('templates/lounge/anonDownvoteCard', [
  'react',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.gettext,
  d = function () {
    return a.createElement('div', {
      className: 'vote-action tooltip'
    }, c('You must sign in to down-vote this post.'))
  };
  return d
}),
define('lounge/views/post', [
  'jquery',
  'underscore',
  'backbone',
  'stance',
  'react',
  'react-dom',
  'core/api',
  'core/constants/badgesConstants',
  'core/constants/voteConstants',
  'core/strings',
  'core/switches',
  'core/utils',
  'core/utils/sso',
  'core/mixins/withAlert',
  'core/mixins/withRichMedia',
  'core/WindowBus',
  'core/bus',
  'common/urls',
  'common/views/mixins',
  'common/utils',
  'lounge/common',
  'lounge/mixins',
  'lounge/views/cards',
  'lounge/views/media',
  'lounge/views/posts/BadgesManageView',
  'lounge/views/posts/BlacklistView',
  'lounge/views/posts/PostEditView',
  'lounge/views/posts/PostReplyView',
  'lounge/views/posts/TypingUserView',
  'lounge/views/posts/FlaggingView',
  'core/views/ClickTooltip',
  'core/views/Tooltip',
  'templates/lounge/partials/postFooter',
  'templates/lounge/partials/postMenu',
  'templates/lounge/partials/userBadges',
  'templates/lounge/post',
  'templates/lounge/postDeleted',
  'templates/lounge/postBlocked',
  'templates/lounge/postMinimized',
  'templates/lounge/postSpam',
  'templates/lounge/anonUpvoteCard',
  'templates/lounge/anonDownvoteCard'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u, v, w, x, y, z, A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P) {
  'use strict';
  var Q = l.preventDefaultHandler,
  R = j.get,
  S = new p,
  T = h.ACTION_TYPES,
  U = 13,
  V = c.View.extend({
    tagName: 'li',
    className: 'post',
    events: {
      'click > [data-role=post-content] [data-action]': 'performAction',
      'keydown > [data-role=post-content] [data-action]': function (a) {
        a.keyCode && a.keyCode !== U || this.performAction(a)
      },
      'click [data-role=allstar]': function () {
        S.broadcast('click:allstar')
      }
    },
    actions: {
      upvote: Q(function (a) {
        this.handleVote(a, 1)
      }),
      downvote: Q(function (a) {
        this.handleVote(a, - 1)
      }),
      reply: 'handleReply',
      flag: 'handleFlag',
      'block-user': 'handleBlockUser',
      edit: 'handleEdit',
      'delete': 'handleDelete',
      spam: 'handleSpam',
      blacklist: 'handleBlacklist',
      'manage-badges': 'handleManageBadges',
      highlight: 'handleHighlight',
      unhighlight: 'handleUnhighlight',
      collapse: 'handleCollapse',
      reveal: 'handleReveal',
      'expand-share': 'handleExpandShare',
      'share:twitter': '_onShare',
      'share:facebook': '_onShare',
      'copy-link': 'handleCopyLink',
      follow: 'toggleFollow'
    },
    performAction: function (c) {
      var d = this,
      e = a(c.currentTarget).attr('data-action'),
      f = d.actions[e];
      if (f) return (b.isFunction(f) ? f : d[f]).call(d, c)
    },
    initialize: function (a) {
      var b = this;
      this.thread = a.thread,
      this.session = a.session,
      this.created = Boolean(a.created),
      this.options = a,
      this.userSuggestions = a.userSuggestions,
      this.gifPickerEnabled = Boolean(this.thread) && Boolean(this.thread.forum) && this.thread.forum.get('settings').gifPickerEnabled,
      this.config = a.config,
      this.setAlertSelector('> [role=alert]'),
      this.listenTo(this.model, {
        'change:isDeleted spam': this.removeAsDeleted,
        'change:message': this.stopLoading,
        'change:points': this.updateVotePoints,
        'change:userScore': this.updateActiveUserVote,
        'change:isFlaggedByUser': this.updateMenu,
        'change:hasMore': this.handleHasMoreChanged,
        'change:isHighlighted': function () {
          this.redraw()
        },
        'change:hideReplyPreview': this.updateHideReplyPreview,
        change: function () {
          var a = this.model.changedAttributes();
          (a.id || a.message) && (a.media && k.isFeatureActive('embed_v2', {
            forum: this.thread.forum.id
          }) && (this.shouldWaitToRenderMedia = !0, this.listenToOnce(this.model.media, 'reset', function () {
            this.shouldWaitToRenderMedia = !1,
            this.renderMedia()
          })), this.redraw())
        }
      }),
      this.model.author && (this.listenTo(this.model.author, 'change:isBlocked', function (a, c) {
        var d = a.previous('isBlocked') || !1;
        return b.flaggingView ? void b.listenToOnce(b.flaggingView, 'success cancel', b.redraw) : b.manageBadgeView ? void b.listenToOnce(b.manageBadgeView, 'success cancel', b.redraw) : void (c !== d && b.redraw())
      }), this.listenTo(this.model.author, 'change:badges', this.updateBadges), this.listenTo(this.model.author, 'change:isFollowing', this.updateFollowing)),
      this.thread.forum.get('features') || this.listenToOnce(this.thread.forum, 'change:features', this.redraw),
      this.listenTo(this.thread, 'change:ratingsEnabled', this.redraw),
      !this.model.getParent() && this.model.isAuthorSessionUser(this.session) && this.listenTo(this.thread, 'change:userRating', function () {
        this.model.author.set('threadRating', this.thread.get('userRating')),
        this.redraw()
      }),
      this.listenTo(this.model.usersTyping, 'add remove reset change', this.updateTypingCount),
      this.listenTo(this.session, 'change:id', function () {
        this.updateFooter(),
        this.updateMenu(),
        this.updateSessionClass(),
        k.isFeatureActive('embed_refresh', {
          forum: this.thread.forum.id
        }) && this.updateFollowingInitial()
      }),
      this.listenTo(u.getLounge(), 'opened:post-menu', this.positionMenu),
      this.listenTo(this.thread, 'change:ratingsEnabled', this.render),
      this.hasVisibleChildren = !1,
      this.reply = null,
      this.edit = null,
      this.parent = a.parent,
      this.trackPosition = !1,
      this.offset = {
        top: - 1,
        height: - 1
      },
      this.dim = {
        height: - 1,
        width: - 1
      },
      this.listenTo(u.getLounge(), 'domReflow', this.calcRect),
      this.isCollapseAllowed = !0,
      this.haveSubscribedToRichMediaEvents = !1
    },
    calcRect: function () {
      if (!this.trackPosition || !this.visible) return this.offset = {
        top: - 1,
        height: - 1
      },
      void (this.dim = {
        height: - 1,
        width: - 1
      });
      var a = this.contentNode;
      this.offset = a.offset(),
      this.dim = {
        height: a.height(),
        width: a.width()
      }
    },
    updatePostMetaPlacement: function () {
      var a = k.isFeatureActive('embed_refresh', {
        forum: this.thread.forum.id
      });
      if (a && !l.isMobileUserAgent()) {
        var b = a && k.isFeatureActive('embed_refresh_v2', {
          forum: this.thread.forum.id
        }),
        c = this.$el.find('.comment__header').first(),
        d = c.find('.post-meta'),
        e = 32;
        d.css({
          display: '',
          'margin-top': ''
        }),
        c.height() <= e ? d.css({
          display: 'block',
          'margin-top': b ? '' : '6px'
        }) : b && d.css({
          top: '-2px'
        })
      }
    },
    createTypingUserView: function () {
      var a = this.$el.find('[data-role=realtime-notification\\:' + this.model.id + '] .realtime-replies');
      this.typingUserView = new C({
        parentView: this,
        model: this.model,
        el: a
      })
    },
    updateTypingCount: function () {
      this.typingUserView || this.createTypingUserView(),
      this.typingUserView.render()
    },
    stopLoading: function () {
      this.contentNode.find('.loading').removeClass('loading')
    },
    updateRelativeTime: function () {
      this.contentNode.find('[data-role=relative-time]').text(this.model.getRelativeCreatedAt())
    },
    updateSessionClass: function () {
      var a = 'authored-by-session-user';
      this.model.isAuthorSessionUser(this.session) ? this.contentNode.addClass(a) : this.contentNode.removeClass(a)
    },
    updateActiveUserVote: function () {
      var a = this.model,
      b = this.contentNode.find('[data-action=upvote]'),
      c = this.contentNode.find('[data-action=downvote]');
      c.removeClass('downvoted'),
      b.removeClass('upvoted'),
      a.get('userScore') > 0 ? b.addClass('upvoted') : a.get('userScore') < 0 && c.addClass('downvoted')
    },
    updateHideReplyPreview: function () {
      var a = this.contentNode.find('a.parent-link');
      a.removeClass('parent-link'),
      a.addClass('hidden'),
      this.updatePostMetaPlacement()
    },
    updateVotePoints: function () {
      var c = this,
      d = c.model,
      e = c.contentNode.find('[data-role=likes], [data-role=dislikes]'),
      f = c.contentNode.find('[data-action=upvote], [data-action=downvote]'),
      g = function (a) {
        b.delay(function () {
          a.addClass('update'),
          b.delay(function () {
            a.removeClass('update')
          }, 1000)
        }, 500)
      };
      b.each(e, function (b, e) {
        b = a(b);
        var h = b.html(),
        j = d.get(b.attr('data-role')),
        k = a(f[e]);
        if (j = Math.max(j, 0).toString(), h !== j) {
          k.removeClass('count-' + h);
          var l = c.thread.forum.get('votingType'),
          m = l === i.VOTING_TYPES.DOWNVOTE_LIMITED || l === i.VOTING_TYPES.DOWNVOTE_DISABLED;
          l === i.VOTING_TYPES.DISABLED || 'dislikes' === b.attr('data-role') && m ? k.addClass('count-0') : (k.addClass('count-' + j), b.html(j)),
          g(b)
        }
      })
    },
    updateFooter: function () {
      var a = this.contentNode.find('footer'),
      b = G({
        post: this.getPostAttributes(),
        session: this.session.toJSON(),
        disableSocialShare: this.thread.forum.get('settings').disableSocialShare,
        votingType: this.thread.forum.get('votingType'),
        forumId: this.thread.forum.id
      });
      B.open[this.model.cid] && this.toggleReplyLink(!0),
      a.html(b),
      this.initVotersCard()
    },
    updateMenu: function () {
      var a = this.contentNode.find('[data-role=menu]'),
      b = H({
        session: this.session.toJSON(),
        post: this.getPostAttributes(),
        forum: this.thread.forum.toJSON()
      });
      a.replaceWith(b)
    },
    updateBadges: function () {
      var a = this.getPostAttributes().author,
      b = this.contentNode.find('[data-role=badges]'),
      c = I({
        forum: this.thread.forum.toJSON(),
        user: a,
        context: 'post',
        limit: 4
      });
      b.replaceWith(c),
      this.profileCard && this.profileCard.setBadges(a.badges),
      this.updatePostMetaPlacement()
    },
    updateFollowing: function () {
      var a = '[data-user=' + this.model.author.id + '][data-action=follow]';
      if (this.model.author.get('isPrivate') || this.model.author.id === this.session.user.id) return void this.$el.find(a).hide();
      var b = Boolean(this.model.author.get('isFollowing')),
      c = a + ' .follow-user',
      d = R(b ? 'Unfollow' : 'Follow');
      this.$el.find(c).toggleClass('is-following', b),
      this.$el.find(c).attr('aria-label', d),
      this.$el.find(c).attr('title', d)
    },
    updateFollowingInitial: function () {
      (this.session.user.get('followingUserIdSet') && this.session.user.get('followingUserIdSet').has(this.model.author.id) || this.session.user.id === this.model.author.id) && this.updateFollowing()
    },
    updatePostStateClasses: function () {
      var a = this.model,
      b = a.get('isHighlighted') || a.get('isSponsored');
      this.$el.toggleClass('highlighted', Boolean(b)),
      this.contentNode.toggleClass('disabled', !a.id)
    },
    getMessageContent: function () {
      return this.messageContent && this.messageContent.length || (this.messageContent = this.contentNode.find('[data-role=message-content]')),
      this.messageContent
    },
    manageMessageHeight: function (a) {
      var b = this,
      c = b.getMessageContent(),
      d = 1.5 * b.collapsedHeight,
      e = c && c.length && c.height() || 0;
      e += a || 0,
      e > d && !b.$el.hasClass('collapsed') ? b.collapse() : b.expand(!0)
    },
    preventCollapsing: function (a) {
      a.get('deferred') || (this.expand(), this.isCollapseAllowed = !1)
    },
    markSeen: function () {
      function a() {
        c.contentNode.addClass('seen'),
        b.delay(function () {
          c.contentNode.removeClass('seen'),
          c.contentNode.removeClass('new')
        }, 10000),
        c.trackPosition = !1
      }
      var c = this,
      e = d(c);
      e.isVisible() ? a() : this.listenToOnce(e, 'enter', a)
    },
    renderMedia: function () {
      var a = this.model.media;
      if (a && a.length) {
        var c = this.$el.find('[data-role=post-media-list]');
        this.richMediaViews = this.renderRichMedia(a, c, {
          convertLinkToButton: !0,
          beforeRender: function (a) {
            this.listenTo(a.model, 'change:activated', this.preventCollapsing),
            a.relatedPost = this.model.cid
          },
          normalize: function (a) {
            var b = l.bleachFindUrls(a);
            return b.length && (a = b[0].url),
            a
          }
        }),
        !this.haveSubscribedToRichMediaEvents && this.richMediaViews.length && (this.listenTo(x.settings, 'change:collapsed', function (a, c) {
          if (c) this.manageMessageHeight();
           else {
            var d = b.reduce(this.richMediaViews, function (a, b) {
              return a + (b.model.get('deferredHeight') || 0)
            }, 0);
            this.manageMessageHeight(d)
          }
        }), this.haveSubscribedToRichMediaEvents = !0)
      }
    },
    renderSpoilers: function () {
      this.$el.find('spoiler').each(function () {
        a(this).attr('tabindex', '0')
      })
    },
    getStateByline: function () {
      var a,
      b = this.model;
      return b.get('isHighlighted') ? a = {
        icon: 'trophy',
        text: R('Featured by %(forum)s'),
        style: 'default'
      }
       : b.get('isSponsored') ? a = {
        icon: 'trophy',
        text: R('Sponsored on Disqus'),
        style: 'sponsored'
      }
       : b.isAuthorSessionUser(this.session) && (b.get('isApproved') || (a = {
        icon: 'clock',
        text: R('Hold on, this is waiting to be approved by %(forum)s.'),
        style: 'default'
      })),
      a && (a.text = j.interpolate(a.text, {
        forum: this.thread.forum.get('name')
      })),
      a
    },
    getTemplate: function (a) {
      if (a.isDeleted) return K;
      var b = this.model.isAuthorSessionUser(this.session);
      return a.sb && !b ? K : a.isSpam ? N : this.model.author && (this.model.author.get('isBlocked') || this.model.author.get('isBlocking')) ? L : b && !a.isApproved ? J : a.isMinimized ? M : J
    },
    getPostAttributes: function () {
      var a = this.model.toJSON({
        session: this.session,
        thread: this.thread
      }),
      b = this.model.getParent();
      return b && b.get('isSponsored') && (a.canBeRepliedTo = !1, a.hideViewAllComments = b.get('hideViewAllComments')),
      a
    },
    render: function () {
      var a = this.$el,
      b = this.getPostAttributes(),
      c = u.getLounge(),
      d = this.thread.forum.get('avatar'),
      g = this.model.getParent(),
      h = this.getTemplate(b);
      return !b.message && b.raw_message && t.isPlainText(b.raw_message) && (b.message = this.model.constructor.formatMessage(b.raw_message)),
      f.render(e.createElement(h, {
        post: b,
        forumName: this.thread.forum.get('name'),
        session: this.session.toJSON(),
        thread: this.thread.toJSON(),
        forum: this.thread.forum.toJSON(),
        created: this.created,
        parentPost: g && g.toJSON({
          session: this.session,
          thread: this.thread
        }),
        defaultAvatarUrl: d ? d.large.cache : r.avatar.generic,
        hasForumAvatar: Boolean(d && !l.isDefaultAvatar(d.large.cache)),
        stateByline: this.getStateByline(),
        isInHome: c.isInHome(),
        isOnChannel: c.isOnChannel()
      }), this.el),
      h === J ? a.removeClass('minimized') : a.addClass('minimized'),
      b.sb && !this.model.isAuthorSessionUser(this.session) ? this.hasVisibleChildren || a.addClass('banned') : this.parent && this.parent.markHasVisibleChildren(),
      !this.options.excludeAnchor && this.model.id && a.attr('id', 'post-' + this.model.id),
      this.contentNode = a.find('[data-role=post-content]'),
      this.childrenNode = a.find('[data-role=children]'),
      this.messageNode = this.contentNode.find('[data-role=message]'),
      this.highlightSyntax(),
      this.processMentions(),
      this.initCards(),
      this.updatePostStateClasses(),
      this.shouldWaitToRenderMedia || this.renderMedia(),
      this.renderSpoilers(),
      this.model.get('isRealtime') && (this.trackPosition = !0, this.listenToOnce(c.postsView, 'render:end', this.markSeen)),
      this.listenToOnce(c.postsView, 'render:end', function () {
        this.markSeen(),
        this.manageMessageHeight(),
        this.updatePostMetaPlacement()
      }),
      this
    },
    positionMenu: function (b) {
      var c = b.data('postId').toString();
      if (c === this.model.id) {
        var d = this.$('.dropdown-menu', b);
        if (d.css('top', ''), d.height() + d.offset().top > a(window.document).height()) {
          var e = d.css('top') || 0;
          d.css('top', (d.height() + parseInt(e, 10)) * - 1)
        }
      }
    },
    markHasVisibleChildren: function () {
      this.hasVisibleChildren = !0,
      this.model.get('sb') && (this.$el.removeClass('banned'), this.parent && this.parent.markHasVisibleChildren())
    },
    highlightSyntax: function () {
      var a = this.contentNode.find('pre code');
      a.length && a.each(function () {
        t.syntaxHighlighter.highlight(this)
      })
    },
    redraw: function () {
      var a = window.document.createDocumentFragment();
      this.childrenNode.children().appendTo(a),
      this.render(),
      this.childrenNode.append(a),
      this.blacklist && this.contentNode.find('[data-role=blacklist-form]').first().append(this.blacklist.el),
      u.getLounge().postsView.trigger('render:end'),
      u.getLounge().trigger('domReflow')
    },
    handleHasMoreChanged: function () {
      var b = this.$el.find('.show-children-wrapper');
      a(b[b.length - 1]).toggleClass('hidden', !this.model.get('hasMore'))
    },
    processMentions: function () {
      var b = this.session,
      c = m.getProfileUrlTemplate(b && b.get('sso') && b.get('sso').profile_url),
      d = k.isFeatureActive('sso_less_branding', {
        forum: this.thread.forum.id
      }) && !c;
      this.contentNode.find('[data-dsq-mention]').each(function () {
        var b = a(this);
        if (d) {
          var e = a('<span />');
          e.text(b.text()),
          e.addClass('mention'),
          b.replaceWith(e)
        } else {
          if (c) {
            var f = m.getProfileUrl(c, b.text());
            b.attr('href', f),
            b.attr('title', f)
          } else {
            var g = b.attr('data-dsq-mention').split(':') [0];
            b.attr('data-action', 'profile'),
            b.attr('data-username', g)
          }
          b.addClass('mention')
        }
      })
    },
    attachChild: function (a) {
      var b = a.model;
      b.created || !b.id || b.get('isImmediateReply') ? this.childrenNode.prepend(a.el) : this.childrenNode.append(a.el)
    },
    toggleReply: function () {
      this.reply && this.reply.isOpen() ? this.hideReply() : this.showReply()
    },
    toggleReplyLink: function (a) {
      this.contentNode.find('[data-role=reply-link]').toggleClass('active', a),
      this.contentNode.find('[data-role=reply-link]').toggleClass('publisher-anchor-color', a)
    },
    showReply: function () {
      this.reply ? (this.$el.find('[data-role=reply-form]').first().prepend(this.reply.$el), this.reply.show(), this.reply.focus()) : this.getReplyView(),
      this.toggleReplyLink(!0)
    },
    hideReply: function () {
      this.reply && (this.reply.hide(), this.toggleReplyLink(!1))
    },
    toggleEdit: function () {
      return this.contentNode.find('[data-role=edit-link]').toggleClass('active', !this.edit),
      this.edit ? (this.edit.remove(), this.edit = null, void this.messageNode.show()) : void this.showEdit()
    },
    showEdit: function () {
      if (this.session.isLoggedOut()) return void this.listenToOnce(this.session, 'change:id', this.toggleEdit);
      if (this.model.canBeEdited(this.session, this.thread) && !this.edit) {
        this.edit = new A({
          post: this.model,
          session: this.session,
          thread: this.thread
        }),
        this.edit.render(),
        this.listenTo(this.edit, 'submitted cancel', this.toggleEdit),
        this.expand(!0);
        var a = this.messageNode;
        a.parent().prepend(this.edit.$el),
        a.hide(),
        this.edit.resize();
        var b = u.getLounge();
        b && b.scrollToPost(this.model.id),
        q.trigger('uiAction:postStartUpdate', this.model, {
          area: 'main'
        })
      }
    },
    removeAsDeleted: function () {
      this.redraw()
    },
    initCards: function () {
      var a = this;
      a.initProfileCard(),
      a.initContextCard(),
      a.initVotersCard(),
      a.initAnonVoteCards(),
      a.initTooltips()
    },
    initProfileCard: function () {
      if (!l.isMobileUserAgent() && !k.isFeatureActive('sso_less_branding', {
        forum: this.thread.forum.id
      })) {
        var a = this.$el.find('.hovercard');
        a.length && (this.profileCard = w.ProfileCard.create({
          session: this.session,
          user: this.model.author,
          targetElement: a
        }))
      }
    },
    initContextCard: function () {
      if (!l.isMobileUserAgent()) {
        var a = this.parent && this.parent.model;
        a && !a.get('isDeleted') && (this.contextCard = w.ContextCard.create({
          post: a,
          targetElement: this.$el.find('[data-role=parent-link]')
        }))
      }
    },
    initVotersCard: function () {
      if (!l.isMobileUserAgent()) {
        var a = this.$el.find('[data-action=upvote]'),
        b = this.$el.find('[data-action=downvote]'),
        c = this.thread.forum.get('votingType');
        a.length && c !== i.VOTING_TYPES.DISABLED && (this.upvotersCard = w.VotersCard.create({
          session: this.session,
          model: this.model,
          targetElement: a,
          voteType: 1,
          isRefreshEnabled: k.isFeatureActive('embed_refresh', {
            forum: this.thread.forum.id
          })
        })),
        !b.length || null !== c && void 0 !== c && c !== i.VOTING_TYPES.DETAILED || (this.downvotersCard = w.VotersCard.create({
          session: this.session,
          model: this.model,
          targetElement: b,
          voteType: - 1,
          isRefreshEnabled: k.isFeatureActive('embed_refresh', {
            forum: this.thread.forum.id
          })
        }))
      }
    },
    initAnonVoteCards: function () {
      this.session.isLoggedOut() && !this.thread.forum.get('settings').allowAnonVotes && (this.anonVoteCards = this.anonVoteCards || {
      }, b.each({
        upvote: O,
        downvote: P
      }, function (a, b) {
        this.anonVoteCards[b] && (this.anonVoteCards[b].remove(), this.anonVoteCards[b] = null);
        var c = this.$('[data-action=' + b + ']');
        c.length && (this.anonVoteCards[b] = E.create({
          targetElement: c,
          template: a,
          id: 'anon' + b + this.model.id
        }))
      }, this), this.anonVoteCards.upvote && this.listenTo(this.anonVoteCards.upvote, 'show', this.closeUpvotersCard), this.anonVoteCards.downvote && this.listenTo(this.anonVoteCards.upvote, 'show', this.closeDownvotersCard))
    },
    initTooltips: function () {
      if (!l.isMobileUserAgent()) {
        var b = this.$el.find('[data-toggle=tooltip]');
        b.length && b.each(function (b, c) {
          var d = a(c),
          e = d.attr('title');
          d.attr('data-original-title', e).attr('title', ''),
          F.create({
            targetElement: d,
            message: e,
            id: e
          })
        })
      }
    },
    closeUpvotersCard: function () {
      this.upvotersCard && this.upvotersCard.hide()
    },
    closeDownvotersCard: function () {
      this.downvotersCard && this.downvotersCard.hide()
    },
    _onShare: Q(function (a) {
      if (!this.thread.forum.get('settings').disableSocialShare) {
        var b = t.extractService(a.target, 'share');
        b && (u.getLounge().trigger('uiAction:postShare', this.model, b), this.share(b))
      }
    }),
    handleBlacklist: Q(function () {
      if (!this.blacklist) {
        var a = this.blacklist = new z({
          model: this.model,
          forum: this.thread.forum
        });
        a.render(),
        this.listenTo(a, 'success cancel', function () {
          this.blacklist.remove(),
          this.blacklist = null
        }),
        this.contentNode.find('[data-role=blacklist-form]').first().append(a.el)
      }
    }),
    handleManageBadges: Q(function () {
      if (!this.manageBadgeView) {
        var a = this.manageBadgeView = new y({
          model: this.model,
          forum: this.thread.forum
        });
        a.render(),
        q.trigger('uiAction:viewBadgeModal'),
        this.listenTo(a, 'success cancel', function () {
          this.manageBadgeView.remove(),
          this.manageBadgeView = null
        }),
        this.listenTo(a, 'success', function (a) {
          var b = this.model.author;
          b.get('badges') || b.set('badges', [
          ]);
          var c = b.get('badges');
          a.action === T.AWARD ? c.unshift(a.badge) : a.action === T.REMOVE && b.set('badges', c.filter(function (b) {
            return b.id !== a.badge.id
          })),
          this.thread.trigger('change:badgeAction', b)
        }),
        this.contentNode.find('[data-role=badges-form]').first().append(a.el)
      }
    }),
    toggleCollapse: function (a) {
      this.$el.toggleClass('collapsed', a)
    },
    handleCollapse: Q(function () {
      this.toggleCollapse()
    }),
    handleHighlight: Q(function () {
      this.model.highlight();
      var a = R('You\'ve featured a comment! This comment will now also appear at the top of the discussion.');
      this.alert(a, {
        safe: !0,
        type: 'success'
      }),
      this.thread.set('highlightedPost', this.model);
      var b = u.getLounge();
      b && b.scrollToPost(this.model.id)
    }),
    handleUnhighlight: Q(function () {
      this.model.unhighlight(),
      this.dismissAlert(),
      this.thread.unset('highlightedPost')
    }),
    handleVote: function (a, b) {
      if (this.thread.forum.get('votingType') !== i.VOTING_TYPES.DISABLED && (b !== - 1 || this.thread.forum.get('votingType') !== i.VOTING_TYPES.DOWNVOTE_DISABLED)) {
        if (!this.thread.forum.get('settings').allowAnonVotes && this.session.isLoggedOut()) return void this.queueAuthAction(function () {
          this.handleVote(a, b)
        }, this);
        var c = u.getLounge(),
        d = this.model.get('userScore') === b;
        d ? c.trigger('uiAction:postUnvote', this.model, a) : 1 === b ? c.trigger('uiAction:postUpvote', this.model, a) : b === - 1 && c.trigger('uiAction:postDownvote', this.model, a),
        this.model.vote(d ? 0 : b)
      }
    },
    queueAuthAction: function (a, b) {
      this.listenToOnce(this.session, 'change:id', function () {
        this.session.isLoggedIn() && a.call(b)
      }),
      this.session.get('sso') && this.session.get('sso').url ? this.session.authenticate('sso') : this.session.authenticate('disqusDotcom')
    },
    getReplyView: function () {
      return this.reply ? this.reply : (this.reply = new B({
        parentView: this,
        parent: this.model,
        thread: this.thread,
        session: this.options.session,
        userSuggestions: this.userSuggestions,
        gifPickerEnabled: this.gifPickerEnabled,
        shouldShowEmailAlertInForm: !0
      }), this.reply.render(), this.showReply(), this.reply)
    },
    handleReply: Q(function () {
      this.toggleReply()
    }),
    handleFlag: Q(function () {
      if (!this.model.get('isFlaggedByUser') && !this.flaggingView) {
        if (this.session.isLoggedOut()) {
          var a = this;
          return a._pendingFlagComplete = !1,
          void a.queueAuthAction(function () {
            a._pendingFlagComplete || (a._pendingFlagComplete = !0, setTimeout(function () {
              a.handleFlag()
            }, 400))
          })
        }
        var b = this.flaggingView = new D({
          model: this.model
        });
        b.render(),
        this.listenTo(b, 'cancel success', function () {
          b.remove(),
          this.flaggingView = null,
          this.updateMenu()
        }),
        this.contentNode.find('[data-role=flagging-form]').first().append(b.el),
        q.frame.sendHostMessage('scrollTo', {
          top: b.$el.offset().top - 80
        })
      }
    }),
    handleBlockUser: Q(function () {
      this.dismissAlert(function (a) {
        return a.options && a.options.isBlockError
      });
      var a = this;
      this.model.author.block().fail(function (b) {
        var c = R('Something went wrong while trying to block this user. Please try again later.'),
        d = b && b.responseJSON && b.responseJSON.code;
        d === g.ERROR_CODES.MAX_ITEMS_REACHED && (c = R('Unfortunately this user could not be blocked; you have reached the limit for number of users blocked.')),
        a.alert(c, {
          type: 'error',
          isBlockError: !0
        })
      })
    }),
    handleEdit: Q(function () {
      this.toggleEdit()
    }),
    handleDelete: Q(function () {
      this.model.get('isHighlighted') && (this.model.set('isHighlighted', !1), this.thread.unset('highlightedPost')),
      this.model._delete()
    }),
    handleSpam: Q(function () {
      this.model.spam()
    }),
    handleReveal: Q(function () {
      this.model.set('isMinimized', !1),
      this.redraw()
    }),
    handleExpandMessage: Q(function () {
      return this.expand()
    }),
    handleExpandShare: Q(function () {
      var a = this.$('#comment__share-' + this.model.id + ' .comment-share__buttons');
      a.toggleClass('comment-share__buttons-visible')
    }),
    handleCopyLink: function () {
      k.isFeatureActive('sso_less_branding', {
        forum: this.thread.forum.id
      }) ? l.copyToClipboard(this.model.permalink(this.thread)) : l.copyToClipboard(this.model.shortLink())
    }
  });
  return b.extend(V.prototype, v.ShareMixin),
  b.extend(V.prototype, s.FollowButtonMixin),
  n.call(V.prototype),
  v.asCollapsible.call(V.prototype, {
    collapsedHeight: 374,
    collapseTargetSelector: '[data-role=message-container]',
    collapseScope: 'contentNode'
  }),
  o.call(V.prototype),
  V
}),
define('lounge/views/posts/collection', [
  'jquery',
  'underscore',
  'backbone',
  'moment',
  'core/bus',
  'core/strings',
  'core/switches',
  'common/models',
  'common/utils',
  'lounge/views/posts/PostReplyView',
  'lounge/views/post'
], function (a, b, c, d, e, f, g, h, i, j, k) {
  'use strict';
  var l = f.get,
  m = c.View.extend({
    events: {
      'click [data-action=more-posts]': 'handleLoadMore',
      'click [data-action=show-children]': 'handleLoadMoreChildPosts'
    },
    STREAMING_MAX_VISIBLE: 250,
    initialize: function (a) {
      this.lounge = a.lounge,
      this.thread = a.thread,
      this.userSuggestions = a.userSuggestions,
      this.posts = a.posts,
      this.postsToAppend = [
      ],
      this.postsToPrepend = [
      ],
      this.session = a.session,
      this.subViews = {
      },
      this.state = {
        nextPassTimeoutId: null,
        renderedPosts: [
        ],
        clearDomAfterRender: !1,
        totalPostsProcessed: 0,
        totalElapsedTime: 0
      },
      this.addPostsIncremental = b.bind(this.addPostsIncremental, this),
      this.listenTo(this.posts, {
        reset: this.redrawPosts,
        add: this.addPosts,
        remove: this.removePost
      }),
      this.listenTo(this.thread, 'change:badgeAction', this.handleBadgeAction),
      this.listenTo(this.thread, 'change:highlightedPost', this.handleHasHighlightedState),
      this.listenToOnce(this.lounge, 'threadView:init', function () {
        this.listenTo(this.thread, 'change:isClosed', this.toggleNoPosts),
        this.listenTo(this.session, 'change:id', this.toggleNoPosts),
        this.listenTo(this.posts, 'reset add', this.toggleNoPosts)
      }),
      this.listenTo(this.posts, 'reset add', this.enableTimestampUpdates),
      this.listenTo(this, 'render:end', this.toggleLoadMorePosts),
      this.listenTo(this, 'render:end', this.handleHasHighlightedState),
      g.isFeatureActive('limit_rendered_posts', {
        forum: this.thread.forum.id
      }) && this.listenTo(this.lounge, 'scroll', b.throttle(this.hideOffscreenPosts, 200))
    },
    handleHasHighlightedState: function () {
      this.$el.toggleClass('has-highlighted-post', this.thread.has('highlightedPost'))
    },
    handleBadgeAction: function (a) {
      var b = this;
      Object.keys(this.subViews).forEach(function (c) {
        var d = b.subViews[c];
        d.model.author.id === a.id && d.updateBadges()
      })
    },
    getPostView: function (a) {
      return this.subViews[a]
    },
    bootstrap: function (a, c) {
      this.permalinkOptions = c,
      this.listenTo(this.posts, 'reset', b.bind(this.posts.restoreFromCache, this.posts)),
      this.listenTo(this.posts, 'change:isDeleted', b.bind(this.posts.removeFromCache, this.posts)),
      this.handleInitialCommentCount(a.posts)
    },
    handleInitialCommentCount: function (a) {
      var c = this.thread.forum.get('initialCommentCount');
      if (!c) {
        var d = g.getSwitchContext('customCommentCounts') || {
        };
        c = d[this.thread.forum.id]
      }
      this.posts.reset(a, {
        customThreadLength: c
      }),
      b.invoke(this.subViews, 'manageMessageHeight')
    },
    bindUIUpdateHandlers: function () {
      var c = this,
      d = a(window),
      e = a(window.document.body),
      f = e.width(),
      g = b.debounce(function () {
        var a = e.width();
        f !== a && c.subViews && (f = a, b.each(c.subViews, function (a) {
          a.manageMessageHeight()
        }))
      }, 50);
      d.on('resize', g)
    },
    updateTimestamps: function () {
      return !(!this.subViews || b.size(this.subViews) < 1) && (b.invoke(this.subViews, 'updateRelativeTime'), !0)
    },
    enableTimestampUpdates: function () {
      var a = this,
      c = 60000;
      if (!a.timestampUpdateTimer) {
        var d = function e() {
          return a.updateTimestamps() ? void (a.timestampUpdateTimer = b.delay(e, c)) : void (a.timestampUpdateTimer = null)
        };
        a.timestampUpdateTimer = b.delay(d, c)
      }
    },
    openReply: function (a) {
      var b = this.posts.get(a);
      if (b) {
        var c = this.subViews[b.cid];
        c.showReply()
      }
    },
    openEdit: function (a) {
      var b = this.posts.get(a);
      if (b) {
        var c = this.subViews[b.cid];
        c.showEdit()
      }
    },
    toggleLoadMorePosts: function () {
      var a = this.lounge.threadView.$el.find('#posts [data-role=more]'),
      b = this.posts.hasNext();
      b ? a.show() : a.hide()
    },
    handleLoadMore: function (a) {
      var b = this.posts.currentPage();
      this._loadMore(a),
      this.lounge.trigger('uiAction:seeMore', b + 1)
    },
    handleLoadMoreChildPosts: function (a) {
      var b = a.currentTarget.id.split('-') [1],
      c = this.posts.get(b);
      this._loadMore(a, c),
      this.lounge.trigger('uiAction:seeMoreChildren', a)
    },
    _loadMore: function (b, c) {
      b.preventDefault();
      var d = this,
      f = a(b.currentTarget);
      f.addClass('busy'),
      d.posts.more({
        post: c,
        success: function () {
          d.posts.restoreFromCache(),
          d.once('render:end', function () {
            f.removeClass('busy')
          })
        },
        error: function () {
          f.removeClass('busy')
        }
      }),
      e.frame.sendHostMessage('posts.paginate')
    },
    renderLayout: a.noop,
    toggleNoPosts: function () {
      var a,
      b = this.lounge.threadView.$el.find('#no-posts');
      this.posts.models.length ? b.hide() : (a = l(this.thread.get('isClosed') ? 'This discussion has been closed.' : this.session.get('canReply') ? 'Be the first to comment.' : 'Nothing in this discussion yet.'), b.text(a), b.show())
    },
    handleSort: function () {
      a('#posts [data-role=more]').hide(),
      a('#no-posts').hide(),
      a('#post-list').addClass('loading').empty()
    },
    redrawPosts: function () {
      var a = this;
      a.subViews = {
      },
      a.once('render:end', function () {
        b.each(j.open, function (b, c) {
          var d = a.subViews[c];
          if (d) {
            var e = d.getReplyView();
            e.textarea.set(b.textarea.get()),
            b.isOpen() ? e.show() : e.hide()
          }
        })
      }),
      a.posts.setPageFor && a.permalinkOptions && a.permalinkOptions.postId && a.posts.setPageFor(a.permalinkOptions.postId, {
        silent: !0
      }),
      a.addPosts(a.posts, {
        clearDom: !0
      })
    },
    hideOffscreenPosts: function (a) {
      var c = a.pageOffset,
      d = this.lounge.position.frameOffset.top,
      e = 2 * a.height,
      f = c - e,
      g = c + a.height + e;
      b.isNumber(c) && b.isNumber(e) && b.each(this.subViews, function (a) {
        var b = a.$el,
        c = b.offset().top + d,
        e = c + b.outerHeight();
        e < f || c > g ? b.addClass('invisible') : b.removeClass('invisible')
      })
    },
    postsShouldBePrepended: function (a) {
      var b = a.length && a[0];
      return Boolean(b && (b.created || !b.id || b.get('isRealtime') || b.get('isCached') || b.requestedByPermalink))
    },
    hasQueuedPosts: function () {
      return this.postsToAppend.length || this.postsToPrepend.length
    },
    addPosts: i.decorate(c.collectionAddNormalizer(c.Collection, h.Post), function (a, c, d) {
      var e = this;
      if (d.clearDom && (e.postsToAppend = [
      ], e.postsToPrepend = [
      ], e.postsShouldClearDom = !0), e.postsShouldBePrepended(a)) {
        var f = [
        ];
        b.each(a, function (a) {
          var b = a.get('parent');
          b && e.posts.get(b) ? e.postsToPrepend.push(a) : f.push(a)
        }),
        e.postsToPrepend = f.concat(e.postsToPrepend)
      } else e.postsToAppend = e.postsToAppend.concat(a);
      e.state.nextPassTimeoutId || (e.state.nextPassTimeoutId = b.defer(function () {
        e.trigger('render:start'),
        e.addPostsIncremental(!0)
      }))
    }),
    onDeferredViewReady: function (a) {
      var b = this.subViews;
      b.hasOwnProperty(a) && b[a].manageMessageHeight()
    },
    removePost: function (a) {
      if (this.hasQueuedPosts()) return void this.once('render:end', b.bind(this.removePost, this, a));
      var c = this.subViews[a.cid];
      c && (c.remove(), delete this.subViews[a.cid])
    },
    addPostsIncremental: function (a) {
      this.state.nextPassTimeoutId = null,
      this.discardRenderProgressIfClearDomRequested();
      var b = this.getPostModelsForThePass();
      b.length && this.renderPass(b, a ? m.FIRST_ATTEMPT_TIME_SCALE : void 0),
      this.finishPass(b),
      this.scheduleNextPass()
    },
    discardRenderProgressIfClearDomRequested: function () {
      this.postsShouldClearDom && (this.state.clearDomAfterRender = !0, this.postsShouldClearDom = !1, this.state.renderedPosts = [
      ])
    },
    getPostModelsForThePass: function () {
      return this.postsToAppend.length ? this.postsToAppend : this.postsToPrepend
    },
    renderPass: function (a, b) {
      var c = m.TARGET_PROCESS_TIME;
      b && (c *= b);
      for (var d = this.calculatePostsForNextRun(c) || m.MINIMUM_POSTS_PER_RUN; d > 0; ) {
        var e = a.splice(0, d),
        f = this.timedRenderPosts(e);
        if (null === f) break;
        c -= f,
        d = this.calculatePostsForNextRun(c)
      }
    },
    timedRenderPosts: function (a) {
      if (!a.length) return null;
      var c = Number(new Date);
      this.state.renderedPosts = this.state.renderedPosts.concat(b.map(a, this.createPostView, this));
      var d = Number(new Date) - c;
      return d < 0 && (d = 0),
      this.state.totalElapsedTime += d,
      this.state.totalPostsProcessed += a.length,
      d || null
    },
    createPostView: function (a) {
      var b,
      c = a.get('parent');
      c && (c = this.posts.get(c), b = c && this.getPostView(c.cid));
      var d = new k({
        parent: b,
        model: a,
        thread: this.thread,
        session: this.session,
        created: a.created,
        userSuggestions: this.userSuggestions,
        config: this.lounge.config
      });
      return this.subViews[a.cid] = d,
      d.render(),
      d
    },
    calculatePostsForNextRun: function (a) {
      return a <= 0 ? 0 : this.state.totalElapsedTime <= 0 ? this.state.totalPostsProcessed : Math.floor(a * this.state.totalPostsProcessed / this.state.totalElapsedTime)
    },
    finishPass: function (a) {
      if (!a.length) {
        if (this.$postList = this.lounge.threadView.$el.find('#post-list'), this.state.clearDomAfterRender && (this.$postList.empty(), this.state.clearDomAfterRender = !1), this.state.renderedPosts.length) {
          this.removeOldPostsIfRealtime(),
          this.enablePostTracking(this.state.renderedPosts);
          var b = a === this.postsToAppend;
          this.insertPostElements(this.state.renderedPosts, b),
          this.state.renderedPosts = [
          ]
        }
        this.$postList.removeClass('loading'),
        this.postsToPrepend.length || this.postsToAppend.length || this.trigger('render:end')
      }
    },
    removeOldPostsIfRealtime: function () {
      var a = b.any(this.state.renderedPosts, function (a) {
        return a.model.get('isRealtime')
      });
      a && this.removeOldPosts()
    },
    removeOldPosts: function () {
      var a = b.size(this.subViews) - this.STREAMING_MAX_VISIBLE;
      if (!(a <= 0)) for (var c, e = this.posts.sortBy(function (a) {
        return d(a.get('createdAt')).valueOf()
      }), f = 0, g = 0; g < e.length && f <= a; g++) c = this.getPostView(e[g].cid),
      c && 0 === c.childrenNode.children().length && (this.posts.remove(e[g]), f += 1)
    },
    enablePostTracking: function (a) {
      b.each(a, function (a) {
        a.visible = !0
      })
    },
    insertPostElements: function (a, c) {
      var d = b.groupBy(a, function (a) {
        return Boolean(a.parent)
      });
      b.each(d['true'], function (a) {
        a.parent.attachChild(a)
      });
      var e = b.pluck(d['false'], '$el');
      c ? this.$postList.append(e) : this.$postList.prepend(e)
    },
    scheduleNextPass: function () {
      (this.postsToPrepend.length || this.postsToAppend.length) && (this.state.nextPassTimeoutId = b.defer(this.addPostsIncremental))
    }
  });
  m.TARGET_PROCESS_TIME = 30,
  m.FIRST_ATTEMPT_TIME_SCALE = 0.8,
  m.MINIMUM_POSTS_PER_RUN = 2;
  var n = c.View.extend({
    initialize: function (a) {
      this.lounge = a.lounge,
      this.thread = a.thread,
      this.userSuggestions = a.userSuggestions,
      this.posts = a.posts,
      this.postsToAppend = [
      ],
      this.postsToPrepend = [
      ],
      this.session = a.session,
      this.subViews = {
      },
      this.state = {
        nextPassTimeoutId: null,
        renderedPosts: [
        ],
        clearDomAfterRender: !1,
        totalPostsProcessed: 0,
        totalElapsedTime: 0
      },
      this.listenTo(this.posts, {
        reset: this.addPosts,
        add: this.addPosts
      })
    },
    handleHasHighlightedState: function () {
    },
    handleBadgeAction: function () {
    },
    getPostView: function () {
    },
    bootstrap: function (a) {
      this.posts.reset(a.posts)
    },
    handleInitialCommentCount: function () {
    },
    bindUIUpdateHandlers: function () {
    },
    enableTimestampUpdates: function () {
    },
    openReply: function () {
    },
    openEdit: function () {
    },
    toggleLoadMorePosts: function () {
    },
    handleLoadMore: function () {
    },
    handleLoadMoreChildPosts: function () {
    },
    _loadMore: function () {
    },
    renderLayout: function () {
    },
    toggleNoPosts: function () {
    },
    handleSort: function () {
    },
    redrawPosts: function () {
    },
    hideOffscreenPosts: function () {
    },
    postsShouldBePrepended: function () {
    },
    hasQueuedPosts: function () {
    },
    addPosts: function () {
      this.trigger('render:end')
    },
    onDeferredViewReady: function () {
    },
    removePost: function () {
    },
    addPostsIncremental: function () {
    },
    discardRenderProgressIfClearDomRequested: function () {
    },
    getPostModelsForThePass: function () {
    },
    renderPass: function () {
    },
    timedRenderPosts: function () {
    },
    createPostView: function () {
    },
    calculatePostsForNextRun: function () {
    },
    finishPass: function () {
    },
    removeOldPostsIfRealtime: function () {
    },
    removeOldPosts: function () {
    },
    enablePostTracking: function () {
    },
    insertPostElements: function () {
    },
    scheduleNextPass: function () {
    }
  });
  return {
    PostCollectionView: m,
    DummyPostCollectionView: n
  }
}),
define('templates/lounge/onboard', [
  'react',
  'core/config/urls',
  'core/strings',
  'core/utils/object/get'
], function (a, b, c, d) {
  'use strict';
  var e = c.gettext,
  f = function (c) {
    return [a.createElement('div', {
      key: 'onboard-notice',
      className: 'notice ' + (c.showHome ? 'notice--brand' : '')
    }, a.createElement('div', {
      className: 'notice-wrapper'
    }, a.createElement('span', {
      className: 'notice__icon icon icon-disqus'
    }), a.createElement('a', {
      'data-action': 'show-home',
      href: (b.home || '') + 'explore/?utm_source=embed&utm_medium=onboard_message&utm_content=see_home_msg&forum_id=' + d(c.forum, [
        'id'
      ], ''),
      target: '_blank',
      className: 'notice__message'
    }, e('Welcome to %(Disqus)s! Discover more great discussions just like this one. We\'re a lot more than comments.', {
      Disqus: 'Disqus'
    })), a.createElement('a', {
      'data-action': 'show-home',
      href: (b.home || '') + 'explore/?utm_source=embed&utm_medium=onboard_message&utm_content=see_home_btn&forum_id=' + d(c.forum, [
        'id'
      ], ''),
      target: '_blank',
      className: 'btn btn-primary notice__button'
    }, e('Get Started')))),
    a.createElement('a', {
      key: 'onboard-link',
      className: 'dismiss',
      'data-action': 'close',
      href: '#',
      title: e('Dismiss')
    }, 'Dismiss ', a.createElement('span', {
      'aria-label': 'Dismiss',
      className: 'cross'
    }, '×'))]
  };
  return f
}),
define('lounge/views/onboard-alert', [
  'backbone',
  'react',
  'react-dom',
  'common/utils',
  'templates/lounge/onboard'
], function (a, b, c, d, e) {
  'use strict';
  var f = a.View.extend({
    events: {
      'click [data-action=close]': 'handleClose',
      'click [data-action=show-home]': 'handleShowHome'
    },
    initialize: function (a) {
      this.session = a.session,
      this.forum = a.forum
    },
    render: function () {
      return this.session.isLoggedIn() && this.shouldShow() && (c.render(b.createElement(e, {
        forum: this.forum.toJSON()
      }), this.el), this.trigger('uiAction:onboardAlertShow')),
      this
    },
    shouldShow: function () {
      return !1
    },
    getCookie: function () {
      return d.cookies.read(f.COOKIE_NAME)
    },
    setInitialCookie: function () {
      this.session.user.get('joinedRecently') && this.createCookie(f.COOKIE_NEW_USER)
    },
    createCookie: function (a) {
      d.cookies.create(f.COOKIE_NAME, a, {
        expiresIn: 2592000000
      })
    },
    eraseCookie: function () {
      d.cookies.erase(f.COOKIE_NAME)
    },
    handleShowHome: function () {
      this.remove()
    },
    handleClose: function (a) {
      a.preventDefault(),
      this.remove(),
      this.trigger('uiAction:onboardAlertDismiss')
    },
    remove: function () {
      this.eraseCookie(),
      this.session = null,
      a.View.prototype.remove.call(this)
    }
  }, {
    COOKIE_NAME: 'disqus.onboarding',
    COOKIE_NEW_USER: 'newUser'
  });
  return {
    OnboardAlert: f
  }
}),
define('templates/lounge/notificationMenu', [
  'react',
  'core/config/urls',
  'core/switches'
], function (a, b, c) {
  'use strict';
  var d = function (d) {
    var e = c.isFeatureActive('embed_refresh', {
      forum: d.forumId
    }),
    f = e ? 'notification-icon notification-icon--refresh' : 'notification-icon',
    g = e ? 'notification-count notification-count--refresh' : 'notification-count';
    return a.createElement('a', {
      href: b.homeInbox || '',
      className: 'notification-container',
      'data-action': 'home',
      'data-home-path': 'home/notifications/'
    }, a.createElement('span', {
      className: f + ' icon-comment',
      'aria-hidden': !0
    }), a.createElement('span', {
      className: g,
      'data-role': 'notification-count'
    }))
  };
  return d
}),
define('lounge/views/notification-menu', [
  'jquery',
  'underscore',
  'backbone',
  'stance',
  'core/bus',
  'core/switches',
  'core/utils',
  'templates/lounge/notificationMenu'
], function (a, b, c, d, e, f, g, h) {
  'use strict';
  var i = c.View.extend({
    events: {
      'click [data-action=home]': 'handleShowHome'
    },
    initialize: function (c) {
      var e = a.Deferred();
      this.listenToOnce(d(this), 'enter', function () {
        e.resolveWith(this)
      });
      var f = this.session = c.session;
      this.forum = c.forum,
      this.language = window.document.documentElement.lang,
      this.listenTo(f, 'change:id', this.render),
      this.listenTo(f, 'change:notificationCount', this.updateCount),
      this.listenTo(f, 'change:id', function () {
        e.done(b.bind(f.fetchNotificationCount, f)),
        e.done(this.preloadSidebar)
      }),
      this.listenTo(this, {
        'sidebar:open:start': this.startLoadingAnimation,
        'sidebar:open:done': this.stopLoadingAnimation
      })
    },
    startLoadingAnimation: function () {
      this.$el.addClass('notification-loading')
    },
    stopLoadingAnimation: function () {
      this.$el.removeClass('notification-loading')
    },
    preloadSidebar: function () {
      e.trigger('sidebar:preload')
    },
    render: function () {
      return this.forum.get('settings').ssoRequired && this.session.isLoggedOut() || f.isFeatureActive('sso_less_branding', {
        forum: this.forum.id
      }) && !this.forum.get('settings').sidebarEnabled ? void this.$el.hide() : (this.$el.html(h({
        forumId: this.forum.id
      })), this.updateCount(), this.$el.show(), this)
    },
    handleShowHome: function (b) {
      if (this.session.set('notificationCount', 0), !g.willOpenNewWindow(b)) {
        b.preventDefault();
        var c = a(b.currentTarget).attr('data-home-path');
        e.trigger('sidebar:open', c, this)
      }
    },
    updateCount: function () {
      var a = this.session.get('notificationCount') || 0;
      a > 0 ? (this.$('[data-role=notification-count]').html(a > 9 ? '9<i class="icon icon-plus"></i>' : a), this.$el.addClass('unread')) : (this.$('[data-role=notification-count]').html(''), this.$el.removeClass('unread'))
    }
  });
  return {
    NotificationMenuView: i
  }
}),
define('templates/lounge/highlightedPost', [
  'react',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.gettext,
  d = function (b) {
    return a.createElement('div', null, b.isRefreshEnabled ? null : a.createElement('h2', {
      className: 'highlighted-comment-header'
    }, c('Featured Comment')), a.createElement('ul', {
      className: 'post-list'
    }))
  };
  return d
}),
define('lounge/views/highlighted-post', [
  'backbone',
  'underscore',
  'jquery',
  'core/switches',
  'core/UniqueModel',
  'common/models',
  'lounge/views/post',
  'templates/lounge/highlightedPost'
], function (a, b, c, d, e, f, g, h) {
  'use strict';
  var i = g.extend({
    getPostAttributes: function () {
      var a = g.prototype.getPostAttributes.apply(this, arguments);
      return a.hasMore = !1,
      d.isFeatureActive('embed_refresh', {
        forum: this.thread.forum.id
      }) ? a.hideParent = !0 : a.canBeRepliedTo = !1,
      a
    },
    getStateByline: function () {
      return !1
    }
  }),
  j = a.View.extend({
    template: h,
    itemViewContainer: '.post-list',
    initialize: function (a) {
      b.extend(this, b.pick(a, [
        'thread',
        'session',
        'userSuggestions',
        'config'
      ])),
      this.listenTo(this.thread, 'change:highlightedPost', this.reset)
    },
    getPost: function () {
      return this.post ? c.Deferred().resolve(this.post) : this.getHighlightedPost()
    },
    _getHighlightedPost: function () {
      var a = this.thread.get('highlightedPost');
      return a ? (a instanceof f.Post || (a = new e(f.Post, a)), a.get('isDeleted') ? null : a.get('sb') && !a.isAuthorSessionUser(this.session) ? null : a.get('isHighlighted') ? a : null) : null
    },
    getHighlightedPost: function () {
      var a,
      e = this.post = this._getHighlightedPost(),
      g = c.Deferred();
      return e ? !(a = e.getParent()) || a.author || d.isFeatureActive('embed_refresh', {
        forum: this.thread.forum.id
      }) ? e.sync('read', e, {
        isHighlighted: !0
      }).always(b.bind(g.resolve, g)) : f.Post.fetchContext(e.id, this.thread).always(b.bind(g.resolve, g)) : g.reject(),
      g.promise()
    },
    reset: function () {
      delete this.post,
      this.getPost().always(b.bind(this.render, this))
    },
    createPostView: function () {
      return this.post ? new i({
        model: this.post,
        thread: this.thread,
        session: this.session,
        userSuggestions: this.userSuggestions,
        config: this.config,
        excludeAnchor: !0
      }).stopListening(this.post.usersTyping) : null
    },
    render: function () {
      var a = this.createPostView();
      return a ? (a.render(), this.$el.html(this.template({
        isRefreshEnabled: d.isFeatureActive('embed_refresh', {
          forum: this.thread.forum.id
        })
      })), this.$(this.itemViewContainer).append(a.el), this.$el.show(), this) : (this.$el.hide(), this)
    }
  });
  return {
    HighlightedPostView: j,
    FeaturedPostView: i
  }
}),
define('templates/lounge/realtimeCommentNotification', [
  'core/strings',
  'core/switches'
], function (a, b) {
  'use strict';
  var c = a.gettext,
  d = function (a) {
    var d = b.isFeatureActive('embed_refresh', {
      forum: a.forumId
    });
    return 1 === a.comments ? c(d ? '+1 new comment' : 'Show One New Comment') : d ? c('+%(comments)s new comments', {
      comments: a.comments
    }) : c('Show %(comments)s New Comments', {
      comments: a.comments
    })
  };
  return d
}),
define('templates/lounge/realtimeReplyNotification', [
  'react',
  'core/strings',
  'core/switches'
], function (a, b, c) {
  'use strict';
  var d = b.gettext,
  e = function (b) {
    var e = c.isFeatureActive('embed_refresh', {
      forum: b.forumId
    }),
    f = e ? 'indicator indicator--refresh' : 'indicator';
    return 1 === b.replies ? [
      a.createElement('span', {
        key: 'indicator',
        className: f
      }),
      d(e ? '+1 new reply' : 'Show 1 new reply')
    ] : [
      a.createElement('span', {
        key: 'indicator',
        className: f
      }),
      e ? d('+%(replies)s new replies', {
        replies: b.replies
      }) : d('Show %(replies)s new replies', {
        replies: b.replies
      })
    ]
  };
  return e
}),
define('lounge/views/realtime', [
  'underscore',
  'backbone',
  'react',
  'react-dom',
  'core/bus',
  'core/utils',
  'core/utils/object/get',
  'lounge/common',
  'templates/lounge/realtimeCommentNotification',
  'templates/lounge/realtimeReplyNotification'
], function (a, b, c, d, e, f, g, h, i, j) {
  'use strict';
  var k = f.preventDefaultHandler,
  l = b.View.extend({
    events: {
      click: 'handleDrain'
    },
    initialize: function (a) {
      this.options = a
    },
    getDirection: function (a) {
      if (this.offset && this.dim) {
        var b = a.pageOffset,
        c = b + a.height,
        d = this.offset.top + a.frameOffset.top,
        e = d + this.dim.height;
        return e < b ? 1 : d > c ? - 1 : 0
      }
    },
    setCount: function (a) {
      this.options.count = a
    },
    render: function () {
      return 0 === this.options.count ? void this.$el.hide() : (d.render(c.createElement(i, {
        comments: this.options.count,
        forumId: this.model.get('forum')
      }), this.el), this.listenTo(h.getLounge(), 'domReflow', a.throttle(function () {
        0 !== this.options.count && (this.offset = this.$el.offset(), this.dim = {
          height: this.$el.height(),
          width: this.$el.width()
        })
      }, 400)), this.$el.show(), this)
    },
    handleDrain: k(function () {
      this.model.queue.drain(),
      this.setCount(this.model.queue.counters.comments),
      this.render(),
      e.trigger('uiAction:loadLiveComments')
    })
  }),
  m = l.extend({
    events: {
      click: 'handleDrain'
    },
    getDirection: function (a) {
      if (this.options.postView.visible) {
        this.offset = this.options.postView.offset,
        this.dim = this.options.postView.dim;
        var b = l.prototype.getDirection.call(this, a);
        return delete this.offset,
        delete this.dim,
        b
      }
    },
    render: function () {
      var b = this,
      e = b.options.postView;
      return 0 === b.options.count ? (b.$el.hide(), void (e.trackPosition = !1)) : (e.trackPosition = !0, e.calcRect(), d.render(c.createElement(j, {
        replies: b.options.count,
        forumId: this.model.get('forum')
      }), this.el), b.$el.show(), void a.delay(function () {
        b.$el.addClass('reveal')
      }, 13))
    },
    handleDrain: k(function () {
      var a = this.model.id,
      b = this.options.postView,
      c = this.options.thread.queue;
      c.drain(a),
      this.setCount(c.counters.replies[a]),
      b.trackPosition = !1,
      this.render(),
      e.trigger('uiAction:loadLiveReplies')
    })
  });
  return {
    QueuedPostView: l,
    QueuedReplyView: m
  }
}),
define('lounge/views/posts/UserSuggestionsManager', [
  'underscore',
  'common/collections'
], function (a, b) {
  'use strict';
  function c(a) {
    this.remotes = [
    ],
    this.threadId = a.threadId,
    this.userCollection = new b.UserSuggestionsCollection([], {
      threadId: this.threadId
    })
  }
  return a.extend(c.prototype, {
    fetch: function (a, b) {
      this.userCollection.fetch({
        query: a || '',
        next: b
      })
    },
    addRemote: function (a) {
      this.remotes.push(a)
    },
    all: function () {
      var c = new b.UserCollection;
      return c.add(this.userCollection.models),
      c.add(a.chain(this.remotes).pluck('models').flatten().value()),
      c
    },
    find: function (a, b) {
      a && a.length && this.fetch(a.join(' ').replace(/[^\w\s]/, ''), b)
    },
    get: function (a) {
      return this.userCollection.get(a)
    }
  }),
  c
}),
define('lounge/views/sidebar', [
  'underscore',
  'backbone',
  'modernizr',
  'core/bus',
  'core/switches',
  'core/utils/url/serialize',
  'core/shared/urls',
  'core/utils'
], function (a, b, c, d, e, f, g, h) {
  'use strict';
  var i = b.View.extend({
    initialize: function (a) {
      this.forum = a.forum,
      this.session = a.session,
      this.config = a.config,
      this.language = window.document.documentElement.lang,
      'en' === this.language && (this.language = void 0),
      this.listenTo(this.session, 'change:id', this.destroyHome),
      this.listenTo(d, {
        'sidebar:open': this.open,
        'sidebar:preload': this.preload
      }),
      this.iframeAlive = !0,
      this.iframeReady = !1,
      this.listenToOnce(d.frame, 'home.timeout', this.handleTimeout),
      this.listenToOnce(d.frame, 'home.ready', this.handleReady)
    },
    isIE9: function () {
      return 9 === window.document.documentMode
    },
    shouldUseIframe: function () {
      return !!(this.forum && this.forum.get('settings').sidebarEnabled && e.isFeatureActive('sso_less_branding', {
        forum: this.forum.id
      })) || !!this.iframeAlive && (this.session.isSSO() || this.forum && this.forum.get('settings').sidebarEnabled)
    },
    handleTimeout: function () {
      this.iframeAlive = !1
    },
    handleReady: function () {
      this.iframeReady = !0,
      d.frame.off('home.timeout')
    },
    open: function (b, c) {
      if (this.shouldUseIframe()) {
        if (this.storeHomeSession(), d.frame.sendHostMessage('home.show', {
          path: b,
          language: this.language,
          forum: this.forum
        }), this.iframeReady || this.listenToOnce(d.frame, 'home.timeout', a.bind(this.open, this, b, c)), c) {
          c.trigger('sidebar:open:start');
          var e = a.bind(c.trigger, c, 'sidebar:open:done');
          this.listenToOnce(d.frame, {
            'home.opened': e,
            'home.timeout': e
          })
        }
      } else h.openWindow(f(g.apps.home + b, {
        l: this.language
      }));
      var i = 'unknown';
      0 === b.indexOf('home/forums/') ? i = 'community' : 0 === b.indexOf('by/') ? i = 'profile' : 'home/notifications/' !== b && 'home/inbox/' !== b || (i = 'notifications'),
      d.trigger('uiAction:openHome', i, this.shouldUseIframe())
    },
    destroyHome: function () {
      d.frame.sendHostMessage('home.destroy')
    },
    preload: function () {
      this.session.isLoggedOut() || this.shouldUseIframe() && (this.storeHomeSession(), d.frame.sendHostMessage('home.preload', {
        language: this.language,
        disableMOTD: e.isFeatureActive('sso_less_branding', {
          forum: this.forum.id
        }),
        forum: this.forum
      }))
    },
    storeHomeSession: function () {
      c.sessionstorage && window.sessionStorage.setItem('home.session', JSON.stringify(this.session.user.toJSON()))
    }
  });
  return i
}),
define('core/constants/ratingsConstants', [
  'exports'
], function (a) {
  'use strict';
  a.DEFAULT_RATINGS = {
    average: 0,
    breakdown: {
      1: 0,
      2: 0,
      3: 0,
      4: 0,
      5: 0
    },
    count: 0
  }
});
var _slicedToArray = function () {
  function a(a, b) {
    var c = [
    ],
    d = !0,
    e = !1,
    f = void 0;
    try {
      for (var g, h = a[Symbol.iterator](); !(d = (g = h.next()).done) && (c.push(g.value), !b || c.length !== b); d = !0);
    } catch (i) {
      e = !0,
      f = i
    } finally {
      try {
        !d && h['return'] && h['return']()
      } finally {
        if (e) throw f
      }
    }
    return c
  }
  return function (b, c) {
    if (Array.isArray(b)) return b;
    if (Symbol.iterator in Object(b)) return a(b, c);
    throw new TypeError('Invalid attempt to destructure non-iterable instance')
  }
}();
define('core/templates/react/RatingsScoreTemplate', [
  'react',
  'underscore',
  'core/strings'
], function (a, b, c) {
  'use strict';
  var d = function (b) {
    var c = b.breakdown,
    d = b.totalCount;
    return a.createElement('div', {
      className: 'ratings-breakdown-units align align--stretch'
    }, a.createElement('div', {
      className: 'align__item--flex-1 align align--column'
    }, c.map(function (b, c) {
      var e = b.rating,
      f = b.count,
      g = b.percentage;
      return a.createElement('div', {
        className: 'ratings-breakdown-unit-row align align--middle',
        key: c
      }, a.createElement('div', {
        className: 'ratings-breakdown-text'
      }, e, ' ', a.createElement('div', {
        className: 'rating-star'
      }, '★')), a.createElement('div', {
        className: 'align__item--flex-1 align align--center align--middle'
      }, a.createElement('div', {
        className: 'ratings-breakdown-outer-bar'
      }, a.createElement('div', {
        className: 'ratings-breakdown-inner-bar' + (d && f ? '' : ' no-rating'),
        style: {
          width: g / 2 + 'px'
        }
      }))))
    })), a.createElement('div', {
      className: 'align align--column'
    }, c.map(function (b, c) {
      var d = b.percentage;
      return a.createElement('div', {
        key: c,
        className: 'ratings-breakdown-unit-row ratings-breakdown-percentage align__item--flex-1 align align--center'
      }, a.createElement('div', {
        className: 'align__item--flex-1 text-right'
      }, d, '%'))
    })), a.createElement('div', {
      className: 'align align--column'
    }, c.map(function (b, c) {
      var d = b.count;
      return a.createElement('div', {
        key: c,
        className: 'ratings-breakdown-unit-row ratings-breakdown-percentage align__item--flex-1 align align--center'
      }, a.createElement('div', {
        className: 'align__item--flex-1 text-left'
      }, '(', d, ')'))
    })))
  },
  e = function (e) {
    var f = e.totalCount,
    g = e.average,
    h = e.breakdown,
    i = e.error,
    j = e.expandClass;
    return a.createElement('div', {
      className: 'ratings-score'
    }, a.createElement('div', {
      className: 'spacing-top-small align align--center'
    }, 1 === f ? c.gettext('1 Rating') : c.gettext('%(totalCount)s Ratings', {
      totalCount: f
    })), a.createElement('div', {
      className: 'ratings-items align align--center align--middle',
      tabIndex: '0'
    }, a.createElement('div', {
      className: 'ratings-stars'
    }, a.createElement('div', {
      className: 'stars score-stars',
      style: {
        width: 20 * g + '%'
      }
    }, a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★')), a.createElement('div', {
      className: 'stars base-stars'
    }, a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'), a.createElement('div', {
      className: 'rating-star'
    }, '★'))), a.createElement('div', {
      className: 'ratings-average'
    }, (Math.round(10 * g) / 10).toFixed(1), a.createElement('div', {
      className: 'ratings-breakdown ' + j
    }, a.createElement('div', {
      className: 'ratings-breakdown-notch-border'
    }), a.createElement('div', {
      className: 'ratings-breakdown-notch'
    }), a.createElement(d, {
      breakdown: b.sortBy(b.mapObject(h, function (a, b) {
        return [Number(b),
        a]
      }), function (a) {
        return - a[0]
      }).map(function (a) {
        var b = _slicedToArray(a, 2),
        c = b[0],
        d = b[1];
        return {
          rating: c,
          count: d,
          percentage: f && d ? (100 * d / f).toFixed() : 0
        }
      }),
      totalCount: f
    })))), a.createElement('div', {
      className: 'err text-semibold'
    }, i || ''))
  };
  return e
});
var _extends = Object.assign || function (a) {
  for (var b = 1; b < arguments.length; b++) {
    var c = arguments[b];
    for (var d in c) Object.prototype.hasOwnProperty.call(c, d) && (a[d] = c[d])
  }
  return a
};
define('lounge/views/ratings', [
  'underscore',
  'backbone',
  'react',
  'react-dom',
  'core/constants/ratingsConstants',
  'core/utils/threadRatingsHelpers',
  'core/templates/react/RatingsScoreTemplate'
], function (a, b, c, d, e, f, g) {
  'use strict';
  var h = b.View.extend({
    initialize: function (a) {
      this.session = a.session,
      this.thread = a.thread,
      this.error = null,
      this.listenTo(this.thread, 'change:ratingsEnabled change:ratings', this.render),
      this.thread.forum.get('features') || this.listenToOnce(this.thread.forum, 'change:features', this.render)
    },
    setError: function () {
      var b = this;
      this.error = 'You must be logged in to rate this page',
      this.render(),
      setTimeout(a.bind(function () {
        b.error = null,
        b.render()
      }, this), 5000)
    },
    render: function () {
      if (f.isThreadModelRatingsEnabled(this.thread)) {
        var a = this.thread.get('ratings') || e.DEFAULT_RATINGS;
        d.render(c.createElement(g, _extends({
        }, a, {
          totalCount: a.count || 0,
          error: this.error,
          expandClass: 'expand-below'
        })), this.el)
      } else this.$el.empty();
      return this
    }
  });
  return h
}),
define('core/utils/reactions', [
  'jquery',
  'underscore',
  'core/switches'
], function (a, b, c) {
  'use strict';
  var d = function (b) {
    for (var d, e = c.isFeatureActive('embed_refresh', {
      forum: b
    }), f = e && c.isFeatureActive('embed_refresh_v2', {
      forum: b
    }), g = 24, h = a('#reactions').width(), i = a('.reaction-item').map(function (b, c) {
      return e ? Math.ceil(a(c) [0].getBoundingClientRect().width) : a(c).width()
    }).get(), j = 0, k = [
    ]; !d && j < a('.reaction-item').length; ) {
      j += 1,
      d = !0;
      var l = Math.ceil(i.length / j);
      k = [
      ];
      for (var m = 0; m < j; m++) {
        var n = i.slice(l * m, l * (m + 1)),
        o = (n.length - 1) * g,
        p = n.reduce(function (a, b) {
          return a + b
        }, 0) + (e && !f ? o : 0);
        if (p >= h) {
          d = !1;
          break
        }
        k.push(p)
      }
    }
    if (e) {
      var q = 16;
      a('.reaction-tooltip').each(function (b, c) {
        a(c).height() > q && (c.style.top = '-68px')
      })
    }
    a('.reaction-items__container').width(Math.max.apply(null, k) + 1)
  },
  e = function (b) {
    var c = a('.reaction-items').width();
    c !== b._lastReactionsWidth && (b._lastReactionsWidth = c, d(b.forum))
  },
  f = function (c) {
    c._lastReactionsWidth = a('.reaction-items').width();
    var d = 200;
    c._reactionsResizeListener = b.debounce(b.partial(e, c), d),
    a(window).resize(c._reactionsResizeListener)
  },
  g = function (b) {
    b._reactionsResizeListener && a(window).off('resize', b._reactionsResizeListener)
  };
  return {
    attachReactionsListener: f,
    formatReactionsItems: d,
    detachReactionsListener: g
  }
}),
define('core/constants/reactionConstants', [
  'exports',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.get,
  d = '//c.disquscdn.com/next/current/publisher-admin/assets/img/emoji/';
  a.DEFAULT_REACTIONS = [
    {
      text: 'Upvote',
      imageUrl: d + 'upvote-512x512.png'
    },
    {
      text: 'Funny',
      imageUrl: d + 'funny-512x512.png'
    },
    {
      text: 'Love',
      imageUrl: d + 'love-512x512.png'
    },
    {
      text: 'Surprised',
      imageUrl: d + 'surprised-512x512.png'
    },
    {
      text: 'Angry',
      imageUrl: d + 'angry-512x512.png'
    },
    {
      text: 'Sad',
      imageUrl: d + 'sad-512x512.png'
    }
  ],
  a.DEFAULT_PROMPT = c('What do you think?'),
  a.DEFAULT_DESCRIPTIONS = [
    'Upvote',
    'Funny',
    'Love',
    'Surprised',
    'Angry',
    'Sad'
  ],
  a.UPLOAD_IMAGE_ERROR_MESSAGES = {
    'invalid-image-file': 'Unfortunately your image upload failed. Please verify that the file is valid and in a supported format (JPEG, PNG, or GIF).',
    'invalid-content-type': 'Unfortunately your image upload failed. Please verify that the file is in a supported format (JPEG, PNG, or GIF).',
    'file-too-large': 'Unfortunately your image upload failed. Please verify that your image is under 5MB.',
    'not-authenticated': 'You must be logged in to upload an image.',
    'default': 'Unfortunately your image upload failed. Please verify that your image is in a supported format (JPEG, PNG, or GIF) and under 5MB. If you continue seeing this error, please try again later.'
  }
});
var _extends = Object.assign || function (a) {
  for (var b = 1; b < arguments.length; b++) {
    var c = arguments[b];
    for (var d in c) Object.prototype.hasOwnProperty.call(c, d) && (a[d] = c[d])
  }
  return a
};
define('core/templates/react/ReactionItemsPartial', [
  'react',
  'core/constants/reactionConstants'
], function (a, b) {
  'use strict';
  var c = function (c) {
    var d = c.reactionsList,
    e = c.onSubmitReaction,
    f = c.showVoteCount,
    g = c.readonly,
    h = c.isRefreshEnabled,
    i = c.isRefreshV2Enabled,
    j = h ? 'reaction-items__container--refresh' : '',
    k = h ? 'reaction-item reaction-item--refresh' : 'reaction-item align align--column align--middle spacing-bottom-narrow',
    l = h ? 'reaction-item__button reaction-item__button--refresh' : 'align align--middle align--column reaction-item__button',
    m = h ? 'reaction-item__votes reaction-item__votes--refresh' : 'reaction-item__votes',
    n = h ? 'reaction-item__votes-wrapper reaction-item__votes-wrapper--refresh' : 'reaction-item__votes-wrapper',
    o = h ? 'reaction-item__image-wrapper reaction-item__image-wrapper--refresh' : 'reaction-item__image-wrapper',
    p = h ? 'reaction-item__image reaction-item__image--refresh' : 'reaction-item__image',
    q = 'reaction-vote',
    r = function (a, b) {
      e && !g && e(a, b)
    },
    s = function (a, b, c) {
      var d = 13;
      a.keyCode === d && r(b, c)
    },
    t = d.map(function (a) {
      if (!a.imageUrl) return a;
      var c = a.imageUrl.split('/'),
      d = b.DEFAULT_REACTIONS.filter(function (a) {
        var b = a.imageUrl.split('/');
        return b[b.length - 1].split('-') [0].split('.') [0] === c[c.length - 1].split('-') [0].split('.') [0]
      }),
      e = (d.length ? d[0] : a).imageUrl;
      return _extends({
      }, a, {
        imageUrl: e
      })
    }),
    u = function (a) {
      if (a > 999) {
        var b = a.toString();
        return a < 9999 ? b[0] + '.' + b[1] + 'k' : a < 99999 ? b.slice(0, 2) + '.' + b[2] + 'k' : a < 999999 ? b.slice(0, 3) + '.' + b[3] + 'k' : b[0] + '.' + b[1] + 'm'
      }
      return a
    },
    v = function (a) {
      return (!h || i) && a.text && a.text.trim()
    };
    return a.createElement('div', {
      className: 'align align--center align--wrap reaction-items__container ' + j
    }, t.map(function (b, c) {
      return a.createElement('div', {
        key: c,
        className: [
          k,
          e ? 'reaction-item__enabled' : 'reaction-item__disabled',
          b.isSelected ? 'reaction-item__selected' : ''
        ].join(' ').trim()
      }, a.createElement('div', {
        className: l,
        tabIndex: g ? '-1' : '0',
        onKeyPress: function (a) {
          return s(a, c, b)
        },
        onClick: function () {
          return r(c, b)
        }
      }, a.createElement('div', {
        className: o
      }, b.imageUrl ? a.createElement('img', {
        className: p,
        src: b.imageUrl,
        title: b.text || 'reaction ' + c,
        alt: b.text || 'reaction ' + c
      }) : null, !i && f ? a.createElement('div', {
        className: n
      }, void 0 !== b.votes && f ? a.createElement('div', {
        className: m
      }, b.votes || 0) : a.createElement('div', {
        className: m
      }, ' ')) : null), i ? a.createElement('div', {
        className: q
      }, f ? a.createElement('div', {
        className: n
      }, void 0 !== b.votes && f ? a.createElement('div', {
        className: m
      }, u(b.votes) || 0) : a.createElement('div', {
        className: m
      }, ' ')) : null) : null, v(b) ? a.createElement('div', {
        className: 'reaction-item__text'
      }, b.text) : null), h && !i ? a.createElement('div', {
        className: 'reaction-tooltip'
      }, a.createElement('span', {
        className: 'reaction-tooltip__text'
      }, b.text), a.createElement('div', {
        className: 'reaction-tooltip__triangle'
      }, a.createElement('div', {
        className: 'reaction-tooltip__inner-triangle'
      }))) : null)
    }))
  };
  return c
}),
define('core/templates/react/ReactionsTemplate', [
  'react',
  'core/strings',
  'core/templates/react/ReactionItemsPartial',
  'core/constants/reactionConstants',
  'core/switches'
], function (a, b, c, d, e) {
  'use strict';
  var f = function (f) {
    var g = f.reactionsList,
    h = f.prompt,
    i = f.onSubmitReaction,
    j = f.error,
    k = f.readonly,
    l = f.userCanModerate,
    m = f.forum,
    n = e.isFeatureActive('embed_refresh', {
      forum: m
    }),
    o = n && e.isFeatureActive('embed_refresh_v2', {
      forum: m
    }),
    p = n ? 'reactions-refresh' : '',
    q = g.reduce(function (a, b) {
      return a + ('number' == typeof b.votes ? b.votes : 0)
    }, 0),
    r = g.some(function (a) {
      return a.isSelected
    });
    return a.createElement('div', {
      id: 'reactions',
      className: p
    }, a.createElement('div', {
      className: 'text-bold align align--center spacing-bottom-small prompt'
    }, h && h.trim() || d.DEFAULT_PROMPT), a.createElement('div', {
      className: 'align align--center spacing-bottom'
    }, 1 === q ? b.gettext('1 Response') : b.gettext('%(voteCount)s Responses', {
      voteCount: q
    })), a.createElement('div', {
      className: [
        'reaction-items',
        k ? 'readonly' : '',
        r ? 'has-selection' : '',
        l || r || k ? 'counts-visible' : ''
      ].join(' ').trim()
    }, a.createElement(c, {
      reactionsList: g,
      onSubmitReaction: i,
      showVoteCount: l || r || k,
      readonly: k,
      isRefreshEnabled: n,
      isRefreshV2Enabled: o
    })), a.createElement('div', {
      className: 'err text-semibold'
    }, j || ''))
  };
  return f
}),
define('lounge/views/reactions', [
  'backbone',
  'react',
  'react-dom',
  'core/bus',
  'core/utils/reactions',
  'core/switches',
  'core/templates/react/ReactionsTemplate'
], function (a, b, c, d, e, f, g) {
  'use strict';
  var h = a.View.extend({
    initialize: function (a) {
      this.reactions = a.reactions,
      this.readonly = a.readonly,
      this.session = a.session,
      this.forum = a.forum,
      this.userCanModerate = this.session.get('canModerate'),
      this.isRefreshEnabled = f.isFeatureActive('embed_refresh', {
        forum: this.forum
      }),
      this.listenTo(this.reactions, 'sync', this.render),
      this.listenTo(this.reactions, 'vote:start', this.handleSubmitStart),
      this.listenTo(this.reactions, 'vote:end', this.handleSubmitEnd),
      this.listenTo(this.session, 'change:canModerate', this.handleCanModerateChange),
      e.attachReactionsListener(this)
    },
    handleSubmitStart: function () {
      this.isSubmitting = !0,
      this.$('.reaction-items').addClass('is-submitting'),
      this.$('.err').html()
    },
    handleSubmitEnd: function () {
      this.isSubmitting = !1,
      this.$('.reaction-items').removeClass('is-submitting')
    },
    handleCanModerateChange: function () {
      this.userCanModerate = this.session.get('canModerate'),
      this.render()
    },
    vote: function (a) {
      if (!this.isSubmitting && !this.readonly) {
        var b = this;
        this.reactions.vote(a, {
          success: this.render.bind(this),
          error: function () {
            b.$('.err').html('An error has occurred while saving your reaction. Please try again later.')
          }
        }),
        d.trigger('uiAction:reactionsVote', this.reactions.at(a))
      }
    },
    render: function () {
      return this.reactions.length ? (c.render(b.createElement(g, {
        reactionsList: this.reactions.toJSON(),
        prompt: this.reactions.prompt,
        onSubmitReaction: this.vote.bind(this),
        readonly: this.readonly,
        userCanModerate: this.userCanModerate,
        forum: this.forum
      }), this.el), this.isRefreshEnabled && e.formatReactionsItems(this.forum)) : this.$el.html(''),
      this
    }
  });
  return h
}),
define('templates/lounge/reactionsPromotion', [
  'react',
  'core/strings',
  'core/templates/react/ReactionItemsPartial',
  'core/constants/reactionConstants'
], function (a, b, c, d) {
  'use strict';
  var e = b.gettext,
  f = function (b) {
    var f = b.onConfirm,
    g = b.onDefer,
    h = b.forumShortname;
    return a.createElement('div', {
      id: 'reactions-promotion'
    }, a.createElement('div', {
      className: 'striped-bar'
    }), a.createElement('div', {
      className: 'align align--center private'
    }, a.createElement('span', {
      className: 'icon icon-lock'
    }), e('Only you can see this')), a.createElement('div', {
      className: 'promotion-title text-bold align align--center spacing-top-narrow spacing-bottom'
    }, e('Want to increase engagement? Add Reactions to your articles.')), a.createElement('div', {
      className: 'reaction-items'
    }, a.createElement(c, {
      reactionsList: d.DEFAULT_REACTIONS,
      readonly: !0
    })), a.createElement('div', {
      className: 'align align--center'
    }, a.createElement('button', {
      className: 'btn btn-info',
      onClick: g
    }, e('Maybe later')), a.createElement('a', {
      className: 'btn btn-primary spacing-left',
      onClick: f,
      target: '_blank',
      rel: 'noopener noreferrer',
      href: 'https://' + h + '.disqus.com/admin/settings/reactions/'
    }, 'Enable Reactions')))
  };
  return f
}),
define('lounge/views/reactions-promotion', [
  'backbone',
  'stance',
  'react',
  'react-dom',
  'core/api',
  'lounge/common',
  'templates/lounge/reactionsPromotion'
], function (a, b, c, d, e, f, g) {
  'use strict';
  var h = a.View.extend({
    initialize: function (a) {
      this.forum = a.forum,
      this.listenToOnce(b(this), 'visible', this.trackView)
    },
    onConfirm: function () {
      f.getLounge().trigger('uiAction:reactionsEnable'),
      this.onDismiss()
    },
    onDefer: function () {
      f.getLounge().trigger('uiAction:reactionsDefer'),
      this.onDismiss()
    },
    onDismiss: function () {
      this.dismissed = !0,
      this.render(),
      e.call('announcements/messages/view', {
        method: 'POST',
        data: {
          message: 'reactionsEmbedPromotion'
        }
      })
    },
    trackView: function () {
      f.getLounge().trigger('uiAction:viewReactionsPromotion')
    },
    render: function () {
      return this.dismissed ? this.$el.html('') : d.render(c.createElement(g, {
        onDefer: this.onDefer.bind(this),
        onConfirm: this.onConfirm.bind(this),
        forumShortname: this.forum.id
      }), this.el),
      this
    }
  });
  return h
}),
define('templates/lounge/partials/postCount', [
  'react',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.gettext,
  d = function (b) {
    return a.createElement('a', {
      className: 'publisher-nav-color'
    }, a.createElement('span', {
      className: 'comment-count'
    }, 1 === b.count ? c('1 comment') : c('%(numPosts)s comments', {
      numPosts: b.count
    })))
  };
  return d
}),
define('templates/lounge/partials/topNavigation', [
  'react',
  'core/utils/object/get',
  'templates/lounge/partials/postCount',
  'core/switches'
], function (a, b, c, d) {
  'use strict';
  var e = function (e) {
    var f = d.isFeatureActive('embed_refresh', {
      forum: e.thread.attributes.forum
    }),
    g = f ? 'nav-primary nav-primary--refresh' : 'nav-primary',
    h = f ? 'tab-conversation tab-conversation--refresh' : 'tab-conversation';
    return a.createElement('nav', {
      className: 'nav ' + g
    }, a.createElement('ul', null, a.createElement('li', {
      className: 'nav-tab nav-tab--primary ' + h + ' active',
      'data-role': 'post-count'
    }, e.inHome ? null : a.createElement(c, {
      count: b(e.thread, [
        'attributes',
        'posts'
      ], null)
    })), a.createElement('li', {
      className: 'nav-tab nav-tab--primary tab-user'
    }, a.createElement('ul', null, a.createElement('li', {
      className: 'nav-tab nav-tab--primary notification-menu',
      'data-role': 'notification-menu'
    }), a.createElement('li', {
      className: 'nav-tab nav-tab--primary dropdown user-menu',
      'data-role': 'logout'
    })))))
  };
  return e
}),
define('lounge/views/top-navigation', [
  'backbone',
  'templates/lounge/partials/topNavigation'
], function (a, b) {
  'use strict';
  var c = a.View.extend({
    initialize: function (a) {
      this.inHome = a.inHome,
      this.thread = a.thread
    },
    render: function () {
      return this.$el.html(b({
        inHome: this.inHome,
        thread: this.thread
      })),
      this
    }
  });
  return c
}),
define('templates/lounge/partials/threadFooter', [
  'react',
  'core/strings',
  'core/switches',
  'core/utils/object/get'
], function (a, b, c, d) {
  'use strict';
  var e = b.gettext,
  f = function (b) {
    var f = c.isFeatureActive('embed_refresh', {
      forum: b.forum.id
    }),
    g = f ? 'disqus-footer__link disqus-footer__link--refresh' : 'disqus-footer__link',
    h = f ? 'disqus-footer__item disqus-footer__item--refresh' : 'disqus-footer__item',
    i = f ? 'text-item' : 'clip',
    j = f ? 'disqus-footer disqus-footer--refresh' : 'disqus-footer';
    return a.createElement('div', {
      className: j
    }, a.createElement('ul', {
      className: 'disqus-footer__list'
    }, c.isFeatureActive('sso_less_branding', {
      forum: b.forum.id
    }) ? null : a.createElement('li', {
      id: 'thread-subscribe-button',
      className: 'email ' + h
    }, a.createElement('div', {
      className: 'default'
    }, a.createElement('a', {
      href: '#',
      rel: 'nofollow',
      'data-action': 'subscribe',
      title: e('Subscribe and get email updates from this discussion'),
      className: g
    }, f ? a.createElement('div', {
      className: 'icon-wrapper'
    }, a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon-subscribe-refresh'
    })) : a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon icon-mail'
    }), a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon icon-checkmark'
    }), a.createElement('span', {
      id: 'thread-subscribe-text-default',
      className: i
    }, e('Subscribe')), a.createElement('span', {
      id: 'thread-subscribe-text-subscribed',
      className: i
    }, e('Subscribed'))))), c.isFeatureActive('removePrivacyPolicy', {
      forum: b.forum.id
    }) ? null : a.createElement('li', {
      className: 'privacy ' + h
    }, a.createElement('a', {
      href: 'https://disqus.com/privacy-policy',
      rel: 'nofollow noopener noreferrer',
      target: '_blank',
      className: g,
      title: 'Privacy'
    }, f ? a.createElement('div', {
      className: 'icon-wrapper'
    }, a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon-privacy-refresh'
    })) : a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon icon-lock'
    }), a.createElement('span', {
      className: i
    }, e('Privacy')))), c.isFeatureActive('removePrivacyPolicy', {
      forum: b.forum.id
    }) ? '' : a.createElement('li', {
      className: 'do-not-sell ' + h
    }, a.createElement('a', {
      href: 'https://disqus.com/data-sharing-settings/',
      rel: 'nofollow noopener noreferrer',
      target: '_blank',
      className: g
    }, f ? a.createElement('div', {
      className: 'icon-wrapper'
    }, a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon-warning-refresh'
    })) : a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon icon-warning'
    }), a.createElement('span', {
      className: i
    }, e('Do Not Sell My Data'))))), d(b.forum, [
      'attributes',
      'disableDisqusBranding'
    ], null) ? null : a.createElement('span', {
      className: 'disqus-footer__logo'
    }, a.createElement('a', {
      href: 'https://disqus.com',
      rel: 'nofollow',
      title: e('Powered by Disqus'),
      className: g
    }, e('Powered by Disqus'))))
  };
  return f
}),
define('lounge/views/thread-footer', [
  'backbone',
  'templates/lounge/partials/threadFooter'
], function (a, b) {
  'use strict';
  var c = a.View.extend({
    initialize: function (a) {
      this.forum = a.forum
    },
    render: function () {
      return this.$el.html(b({
        forum: this.forum
      })),
      this
    }
  });
  return c
}),
define('templates/lounge/partials/postSort', [
  'react',
  'core/strings',
  'core/switches'
], function (a, b, c) {
  'use strict';
  var d = b.gettext,
  e = function (b) {
    var e = b.votingDisabled && 'popular' === b.order ? 'desc' : b.order,
    f = c.isFeatureActive('embed_refresh', {
      forum: b.forum
    }),
    g = f ? '' : 'nav-tab nav-tab--secondary dropdown sorting pull-left spacing-right-large',
    h = f ? 'sort-menu-refresh' : 'dropdown-menu',
    i = f ? 'sort-menu-refresh__item' : '';
    return a.createElement('li', {
      'data-role': 'post-sort',
      className: g
    }, f ? null : a.createElement('a', {
      href: '#',
      className: 'dropdown-toggle',
      'data-toggle': 'dropdown'
    }, 'popular' === e ? d('Sort by Best') : null, 'desc' === e ? d('Sort by Newest') : null, 'asc' === e ? d('Sort by Oldest') : null, a.createElement('span', {
      className: 'caret'
    })), a.createElement('ul', {
      className: h
    }, a.createElement('li', {
      className: i + ' ' + ('popular' === e ? 'selected' : '')
    }, b.votingDisabled ? null : a.createElement('a', {
      href: '#',
      'data-action': 'sort',
      'data-sort': 'popular'
    }, d('Best'), f ? null : a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon-checkmark'
    }))), a.createElement('li', {
      className: i + ' ' + ('desc' === e ? 'selected' : '')
    }, a.createElement('a', {
      href: '#',
      'data-action': 'sort',
      'data-sort': 'desc'
    }, d('Newest'), f ? null : a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon-checkmark'
    }))), a.createElement('li', {
      className: i + ' ' + ('asc' === e ? 'selected' : '')
    }, a.createElement('a', {
      href: '#',
      'data-action': 'sort',
      'data-sort': 'asc'
    }, d('Oldest'), f ? null : a.createElement('i', {
      'aria-hidden': 'true',
      className: 'icon-checkmark'
    })))))
  };
  return e
}),
define('templates/lounge/partials/secondaryNavigation', [
  'react',
  'templates/lounge/partials/postSort',
  'core/switches'
], function (a, b, c) {
  'use strict';
  var d = function (d) {
    var e = d.forum,
    f = c.isFeatureActive('embed_refresh', {
      forum: e
    }),
    g = f ? 'nav-secondary-refresh__list' : '',
    h = d.inHome ? null : a.createElement(b, {
      order: d.order,
      votingDisabled: d.votingDisabled,
      forum: e
    }),
    i = a.createElement('li', {
      id: 'thread-share-bar',
      className: 'nav-tab nav-tab--secondary share-bar pull-left'
    }),
    j = a.createElement('li', {
      id: 'favorite-button',
      className: 'nav-tab nav-tab--secondary favorite dropdown pull-left',
      'aria-label': 'Favorite this discussion'
    }),
    k = a.createElement('li', {
      className: 'nav-secondary-refresh__list-item'
    }, a.createElement('div', {
      id: 'favorite-button'
    }), a.createElement('div', {
      id: 'thread-share-bar',
      className: 'share-bar-refresh'
    })),
    l = f ? [
      k,
      h
    ] : [
      h,
      j,
      i
    ];
    return a.createElement('ul', {
      className: g
    }, l)
  };
  return d
}),
define('lounge/views/secondary-navigation', [
  'backbone',
  'core/utils/storage',
  'core/switches',
  'templates/lounge/partials/secondaryNavigation'
], function (a, b, c, d) {
  'use strict';
  var e = a.View.extend({
    attributes: {
      'data-tracking-area': 'secondary-nav'
    },
    initialize: function (a) {
      this.inHome = a.inHome,
      this.order = a.order,
      this.votingDisabled = a.votingDisabled,
      this.forum = a.forum,
      this.isRefreshEnabled = c.isFeatureActive('embed_refresh', {
        forum: this.forum
      }),
      this.$el.addClass(this.isRefreshEnabled ? 'nav-secondary-refresh' : 'nav nav-secondary')
    },
    render: function () {
      return this.$el.html(d({
        inHome: this.inHome,
        order: this.order,
        votingDisabled: this.votingDisabled,
        forum: this.forum
      })),
      this
    }
  });
  return e
}),
define('templates/lounge/userMenu', [
  'react',
  'core/config/urls',
  'core/strings',
  'core/switches',
  'core/utils/object/get',
  'core/utils/threadRatingsHelpers',
  'core/utils/storage',
  'templates/lounge/partials/profileLink'
], function (a, b, c, d, e, f, g, h) {
  'use strict';
  var i = c.gettext,
  j = function (c) {
    var j = d.isFeatureActive('embed_refresh', {
      forum: c.forum.id
    }),
    k = d.isFeatureActive('embed_refresh_v2', {
      forum: c.forum.id
    }),
    l = j ? 'username username--refresh' : 'username',
    m = j ? 'avatar avatar--refresh' : 'avatar',
    n = j ? 'dropdown-toggle dropdown-toggle--refresh' : 'dropdown-toggle',
    o = j ? 'dropdown-menu dropdown-menu--refresh' : 'dropdown-menu',
    p = j ? 'caret caret--refresh' : 'caret',
    q = i(null === g.get('switch:embed_refresh') || g.get('switch:embed_refresh') === !0 ? 'Classic Disqus' : 'New Disqus');
    return [!e(c.user, [
      'thread',
      'canReply'
    ]) || !e(c.user, [
      'thread',
      'canModerate'
    ]) && d.isFeatureActive('sso_less_branding', {
      forum: c.thread.forum
    }) ? null : a.createElement('a', {
      key: 'user-menu-dropdown',
      href: '#',
      className: n,
      'data-toggle': 'dropdown',
      role: 'menuitem',
      name: e(c.user, [
        'isRegistered'
      ]) ? 'User Menu' : i('Login')
    }, a.createElement('span', {
      className: 'dropdown-toggle-wrapper'
    }, e(c.user, [
      'isRegistered'
    ]) ? a.createElement('span', null, a.createElement('span', {
      className: m
    }, a.createElement('img', {
      'data-role': 'user-avatar',
      'data-user': e(c.user, [
        'id'
      ], ''),
      'data-src': e(c.user, [
        'avatar',
        'cache'
      ], ''),
      alt: i('Avatar')
    })), a.createElement('span', {
      className: l,
      'data-role': 'username',
      'data-username': e(c.user, [
        'username'
      ], '')
    }, e(c.user, [
      'name'
    ]) || e(c.user, [
      'username'
    ]) || null)) : a.createElement('span', {
      className: l
    }, i('Login')), ' '), ' ', a.createElement('span', {
      className: p
    })),
    a.createElement('ul', {
      key: 'user-menu-menu',
      className: o
    }, e(c.user, [
      'isRegistered'
    ]) ? [
      e(c.user, [
        'thread',
        'canModerate'
      ]) && d.isFeatureActive('sso_less_branding', {
        forum: c.thread.forum
      }) ? null : a.createElement('li', {
        key: 'menu-profile'
      }, a.createElement(h, {
        user: c.user,
        forum: c.forum
      }, i('Your Profile'))),
      d.isFeatureActive('sso_less_branding', {
        forum: c.thread.forum
      }) || e(c.forum, [
        'disableDisqusBranding'
      ], null) ? null : a.createElement('li', {
        key: 'menu-channels'
      }, a.createElement('a', {
        href: '/channels/',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, i('Channels'))),
      j && k && !c.isInHome && !d.isFeatureActive('sso_less_branding', {
        forum: c.thread.forum
      }) ? a.createElement('li', {
        key: 'menu-community'
      }, a.createElement('a', {
        href: e(c.forum, [
          'homeUrl'
        ], ''),
        'data-action': 'community-sidebar',
        'data-forum': e(c.forum, [
          'id'
        ], ''),
        id: 'community-tab',
        name: e(c.forum, [
          'name'
        ], null)
      }, i('Community'))) : null,
      a.createElement('li', {
        key: 'menu-media'
      }, a.createElement('a', {
        href: '#',
        className: 'media-toggle-on',
        'data-action': 'toggle-media'
      }, i('Display Media')), a.createElement('a', {
        href: '#',
        className: 'media-toggle-off',
        'data-action': 'toggle-media'
      }, i('Hide Media'))),
      e(c.user, [
        'remote'
      ]) ? null : a.createElement('li', {
        key: 'menu-settings'
      }, a.createElement('a', {
        href: e(b, [
          'editProfile'
        ], '')
      }, i('Edit Settings')))
    ] : [
      e(c.sso, [
        'url'
      ]) ? a.createElement('li', {
        key: 'menu-auth-sso',
        className: 'sso'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'auth:sso'
      }, e(c.sso, [
        'name'
      ], null))) : null,
      a.createElement('li', {
        key: 'menu-auth-disqus'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'auth:disqus'
      }, 'Disqus')),
      a.createElement('li', {
        key: 'menu-auth-facebook'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'auth:facebook'
      }, 'Facebook')),
      a.createElement('li', {
        key: 'menu-auth-twitter'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'auth:twitter'
      }, 'X (Twitter)')),
      a.createElement('li', {
        key: 'menu-auth-google'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'auth:google'
      }, 'Google')),
      a.createElement('li', {
        key: 'menu-auth-microsoft'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'auth:microsoft'
      }, 'Microsoft')),
      a.createElement('li', {
        key: 'menu-auth-apple'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'auth:apple'
      }, 'Apple'))
    ], e(c.user, [
      'thread',
      'canModerate'
    ]) ? [
      c.forum.settings.validateAllPosts ? null : a.createElement('li', {
        key: 'menu-toggle-thread-premoderate'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'toggle-thread-premoderate'
      }, i(c.thread.validateAllPosts ? 'Don\'t Premoderate Thread' : 'Premoderate Thread'))),
      a.createElement('li', {
        key: 'menu-toggle-thread'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'toggle-thread'
      }, i(e(c.thread, [
        'isClosed'
      ]) ? 'Open Thread' : 'Close Thread'))),
      e(c.forum, [
        'settings',
        'threadReactionsEnabled'
      ]) && e(c.user, [
        'thread',
        'canModerate'
      ]) && c.thread.reactions.eligible ? a.createElement('li', {
        key: 'menu-toggle-reactions'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'toggle-reactions'
      }, i(c.thread.reactions && c.thread.reactions.enabled ? 'Remove Reactions' : 'Restore Reactions'))) : null,
      f.isForumRatingsEnabled(c.forum) ? a.createElement('li', {
        key: 'menu-toggle-thread-ratings'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'toggle-thread-ratings'
      }, i(c.thread.ratingsEnabled ? 'Disable Ratings' : 'Enable Ratings'))) : null,
      e(c.user, [
        'isGlobalAdmin'
      ]) ? null : a.createElement('li', {
        key: 'menu-help'
      }, a.createElement('a', {
        href: 'https://help.disqus.com/customer/portal/articles/2538045-commenter-launch-pad'
      }, i('Help')))
    ] : null, e(c.user, [
      'isGlobalAdmin'
    ]) ? [
      a.createElement('li', {
        key: 'menu-debug'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'debug'
      }, i('Debug'))),
      a.createElement('li', {
        key: 'menu-repair'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'repair'
      }, i('Repair')))
    ] : null, e(c.user, [
      'isRegistered'
    ]) && e(c.user, [
      'thread',
      'canReply'
    ]) ? [
      a.createElement('li', {
        key: 'menu-toggle-embed-refresh'
      }, d.isFeatureActive('toggle_embed_refresh') && !d.isFeatureActive('sso_less_branding', {
        forum: c.thread.forum
      }) ? a.createElement('a', {
        href: '#',
        'data-action': 'toggle-embed-refresh'
      }, q) : null),
      a.createElement('li', {
        key: 'menu-logout'
      }, a.createElement('a', {
        href: '#',
        'data-action': 'logout'
      }, i('Logout')))
    ] : null)]
  };
  return j
}),
define('templates/lounge/threadShareBar', [
  'react',
  'core/strings',
  'core/switches'
], function (a, b, c) {
  'use strict';
  var d = b.gettext,
  e = function (b) {
    var e = b.forum,
    f = c.isFeatureActive('embed_refresh', {
      forum: e
    }),
    g = f && c.isFeatureActive('embed_refresh_v2', {
      forum: e
    }),
    h = f ? 'thread-share-bar-buttons-refresh' : 'thread-share-bar-buttons dropdown',
    i = f ? 'share-dropdown-refresh' : 'dropdown-menu pull-right',
    j = f ? 'share-button-toggle' : 'dropdown-toggle icon icon-share',
    k = f ? 'share-dropdown-refresh__item' : 'thread-share__item';
    return a.createElement('div', {
      className: 'thread-share-wrapper'
    }, f ? a.createElement('div', {
      className: 'round-delimiter'
    }) : null, a.createElement('span', {
      'data-role': 'thread-share',
      className: h
    }, a.createElement('a', {
      href: '#',
      className: j + ' ' + (g ? j + '--v2' : ''),
      'data-toggle': 'dropdown',
      'aria-label': d('Share')
    }, f ? d('Share') : ''), a.createElement('ul', {
      className: i
    }, f ? null : a.createElement('div', {
      className: 'thread-share__text'
    }, 'Share this discussion'), a.createElement('li', {
      className: k
    }, f ? a.createElement('div', {
      className: 'share-icons-wrapper share-icons-wrapper--twitter',
      'data-action': 'share:twitter'
    }, a.createElement('span', {
      className: 'icon-twitter-x',
      'aria-hidden': 'true'
    }), a.createElement('span', {
      className: 'visually-hidden'
    }, d('Tweet this discussion'))) : a.createElement('span', {
      className: 'share-twitter',
      'data-action': 'share:twitter',
      tabIndex: '0'
    }, a.createElement('span', {
      className: 'icon-twitter-circle',
      'aria-hidden': 'true'
    }), a.createElement('span', {
      className: 'visually-hidden'
    }, d('Tweet this discussion')))), a.createElement('li', {
      className: k
    }, f ? a.createElement('div', {
      className: 'share-icons-wrapper share-icons-wrapper--facebook',
      'data-action': 'share:facebook'
    }, a.createElement('span', {
      className: 'icon-facebook',
      'aria-hidden': 'true'
    }), a.createElement('span', {
      className: 'visually-hidden'
    }, d('Share this discussion on Facebook'))) : a.createElement('span', {
      className: 'share-facebook',
      'data-action': 'share:facebook',
      tabIndex: '0'
    }, a.createElement('span', {
      className: 'icon-facebook-circle',
      'aria-hidden': 'true'
    }), a.createElement('span', {
      className: 'visually-hidden'
    }, d('Share this discussion on Facebook')))), a.createElement('li', {
      className: k
    }, f ? a.createElement('div', {
      className: 'share-icons-wrapper share-icons-wrapper--email',
      'data-action': 'share:email'
    }, a.createElement('span', {
      className: 'icon-mail',
      'aria-hidden': 'true'
    }), a.createElement('span', {
      className: 'visually-hidden'
    }, d('Share this discussion via email'))) : a.createElement('span', {
      className: 'share-email',
      'data-action': 'share:email',
      tabIndex: '0'
    }, a.createElement('span', {
      className: 'icon-mail',
      'aria-hidden': 'true'
    }), a.createElement('span', {
      className: 'visually-hidden'
    }, d('Share this discussion via email')))), a.createElement('li', {
      className: k
    }, f ? a.createElement('div', {
      className: 'share-icons-wrapper share-icons-wrapper--link',
      'data-action': 'copy-link',
      title: d('Click to copy discussion link')
    }, a.createElement('span', {
      className: 'icon-link',
      'aria-hidden': 'true'
    }), a.createElement('span', {
      className: 'visually-hidden'
    }, d('Copy link to discussion'))) : a.createElement('span', {
      className: 'share-link',
      'data-action': 'copy-link',
      title: d('Click to copy discussion link'),
      tabIndex: '0'
    }, a.createElement('span', {
      className: 'icon-link',
      'aria-hidden': 'true'
    }), a.createElement('span', {
      className: 'visually-hidden'
    }, d('Copy link to discussion')))))))
  };
  return e
}),
define('templates/lounge/layout', [
  'react'
], function (a) {
  'use strict';
  var b = function (b) {
    var c = b.forum;
    return a.createElement('div', {
      id: 'layout',
      'data-tracking-area': 'layout'
    }, c.settings.behindClickEnabled ? a.createElement('div', {
      id: 'behindclick__container'
    }) : null, a.createElement('div', {
      id: 'thread__container'
    }), a.createElement('div', {
      id: 'embed_v2-root'
    }))
  };
  return b
}),
define('templates/lounge/inEmbedAd', [
  'react'
], function (a) {
  'use strict';
  return function () {
    return a.createElement('div', {
      className: 'ad-content',
      role: 'ad-content'
    })
  }
}),
define('templates/lounge/inthreadAd', [
  'react'
], function (a) {
  'use strict';
  var b = function () {
    return a.createElement('li', {
      className: 'post advertisement'
    }, a.createElement('div', {
      className: 'post-content',
      'data-role': 'post-content'
    }))
  };
  return b
}),
define('templates/lounge/termsOfService', [
  'react',
  'core/strings'
], function (a, b) {
  'use strict';
  var c = b.gettext,
  d = function () {
    return a.createElement('div', null, a.createElement('div', {
      className: 'checkbox-wrapper'
    }, a.createElement('p', null, a.createElement('label', null, a.createElement('input', {
      type: 'checkbox',
      name: 'tos'
    }), a.createElement('span', {
      className: 'spacing-left-small'
    }, c('I agree to Disqus\' %(terms)s', {
      terms: a.createElement('a', {
        href: 'https://help.disqus.com/customer/portal/articles/466260-terms-of-service',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, c('Terms of Service'))
    })))), a.createElement('p', null, a.createElement('label', null, a.createElement('input', {
      type: 'checkbox',
      name: 'privacy-policy'
    }), a.createElement('span', {
      className: 'spacing-left-small'
    }, c('I agree to Disqus\' processing of email and IP address, and the use of cookies, to facilitate my authentication and posting of comments, explained further in the %(policy)s', {
      policy: a.createElement('a', {
        href: 'https://disqus.com/privacy-policy',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, c('Privacy Policy'))
    })))), a.createElement('p', null, a.createElement('label', null, a.createElement('input', {
      type: 'checkbox',
      name: 'data-sharing'
    }), a.createElement('span', {
      className: 'spacing-left-small'
    }, c('I agree to additional processing of my information, including first and third party cookies, for personalized content and advertising as outlined in our %(policy)s', {
      policy: a.createElement('a', {
        href: 'https://disqus.com/data-sharing-settings/'
      }, c('Data Sharing Policy'))
    }))))))
  },
  e = function (b) {
    var e = b.onAccept,
    f = b.isPrivate;
    return a.createElement('div', {
      id: 'tos__message',
      className: 'align align--column align--middle'
    }, a.createElement('h1', null, c('Important Update')), a.createElement('p', null, c('When you log in with Disqus, we process personal data to facilitate your authentication and posting of comments. We also store the comments you post and those comments are immediately viewable and searchable by anyone around the world.')), f ? a.createElement(d, null) : a.createElement('p', null, a.createElement('label', null, a.createElement('span', null, c('Please access our %(policy)s to learn what personal data Disqus collects and your choices about how it is used.  All users of our service are also subject to our %(terms)s.', {
      policy: a.createElement('a', {
        href: 'https://disqus.com/privacy-policy',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, c('Privacy Policy')),
      terms: a.createElement('a', {
        href: 'https://help.disqus.com/customer/portal/articles/466260-terms-of-service',
        target: '_blank',
        rel: 'noopener noreferrer'
      }, c('Terms of Service'))
    })))), a.createElement('p', {
      className: 'align'
    }, a.createElement('button', {
      className: 'button button-large',
      onClick: e,
      id: 'accept_tos'
    }, c('Proceed'))))
  };
  return e
}),
define('common/collections/profile', [
  'core/api',
  'common/models',
  'common/collections'
], function (a, b, c) {
  'use strict';
  var d = c.PaginatedCollection.extend({
    initialize: function (a, b) {
      this.user = b.user,
      c.PaginatedCollection.prototype.initialize.apply(this, arguments)
    },
    fetch: function (a) {
      return a = a || {
      },
      a.data = a.data || {
      },
      a.data.user = this.user.id,
      c.PaginatedCollection.prototype.fetch.call(this, a)
    }
  }),
  e = d.extend({
    model: b.SyncedUser,
    url: a.getURL('users/listFollowing'),
    PER_PAGE: 20
  });
  return {
    SessionPaginatedCollection: d,
    FollowingCollection: e
  }
});
var _typeof = 'function' == typeof Symbol && 'symbol' == typeof Symbol.iterator ? function (a) {
  return typeof a
}
 : function (a) {
  return a && 'function' == typeof Symbol && a.constructor === Symbol && a !== Symbol.prototype ? 'symbol' : typeof a
};
define('lounge/views', [
  'jquery',
  'underscore',
  'backbone',
  'loglevel',
  'raven',
  'stance',
  'moment',
  'react',
  'react-dom',
  'core/ads/ads',
  'core/analytics/identity',
  'core/api',
  'core/mediaConfig',
  'core/UniqueModel',
  'core/mixins/appliesPublisherClasses',
  'core/mixins/withAlert',
  'core/models/ThreadVote',
  'core/models/Vote',
  'core/constants/voteConstants',
  'core/config',
  'remote/config',
  'common/models',
  'common/collections',
  'common/utils',
  'core/bus',
  'core/strings',
  'common/urls',
  'core/analytics/jester',
  'common/views/mixins',
  'common/Session',
  'common/keys',
  'core/utils',
  'core/utils/isIframed',
  'core/utils/html/toRGBColorString',
  'core/utils/threadRatingsHelpers',
  'core/utils/url/serialize',
  'core/utils/storage',
  'core/utils/isMediaTradecraftAdEnabled',
  'core/switches',
  'core/viglink',
  'core/WindowBus',
  'common/outboundlinkhandler',
  'core/mixins/withEmailVerifyLink',
  'core/templates/react/BehindClickTemplate',
  'core/templates/react/ThreadTemplate',
  'core/shared/urls',
  'lounge/common',
  'lounge/menu-handler',
  'lounge/mixins',
  'lounge/realtime',
  'lounge/views/badges-message',
  'lounge/views/email-signup',
  'lounge/views/posts/PostReplyView',
  'lounge/views/posts/collection',
  'lounge/views/media',
  'lounge/views/onboard-alert',
  'lounge/views/notification-menu',
  'lounge/views/highlighted-post',
  'lounge/views/realtime',
  'lounge/views/posts/UserSuggestionsManager',
  'lounge/views/sidebar',
  'lounge/views/ratings',
  'lounge/views/reactions',
  'lounge/views/reactions-promotion',
  'lounge/views/favorite-button',
  'lounge/views/top-navigation',
  'lounge/views/thread-footer',
  'lounge/views/secondary-navigation',
  'lounge/tracking',
  'templates/lounge/userMenu',
  'templates/lounge/threadShareBar',
  'templates/lounge/layout',
  'templates/lounge/inEmbedAd',
  'templates/lounge/inthreadAd',
  'templates/lounge/termsOfService',
  'templates/lounge/partials/postCount',
  'templates/lounge/partials/postSort',
  'common/main',
  'common/collections/profile'
], function (a, b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u, v, w, x, y, z, A, B, C, D, E, F, G, H, I, J, K, L, M, N, O, P, Q, R, S, T, U, V, W, X, Y, Z, $, _, aa, ba, ca, da, ea, fa, ga, ha, ia, ja, ka, la, ma, na, oa, pa, qa, ra, sa, ta, ua, va, wa, xa) {
  'use strict';
  var ya = window.document,
  za = z.get,
  Aa = F.preventDefaultHandler,
  Ba = new O,
  Ca = c.View.extend({
    events: {
      'click [data-action=subscribe]': 'subscribe'
    },
    initialize: function (a) {
      this.thread = a.thread,
      this.session = a.session,
      this.listenTo(this.thread, 'change:userSubscription', this.updateStatus),
      this.updateStatus()
    },
    updateStatus: function () {
      this.thread.get('userSubscription') ? (this.$el.addClass('subscribed'), this.$el.find('#thread-subscribe-text-default').addClass('hidden'), this.$el.find('#thread-subscribe-text-subscribed').removeClass('hidden')) : (this.$el.removeClass('subscribed'), this.$el.find('#thread-subscribe-text-default').removeClass('hidden'), this.$el.find('#thread-subscribe-text-subscribed').addClass('hidden'))
    },
    subscribe: Aa(function () {
      var a = this.thread.get('userSubscription');
      this.session.isLoggedOut() ? this.subscribeAfterAuthentication() : this.thread.subscribe(!a)
    }),
    subscribeAfterAuthentication: function () {
      this.listenToOnce(this.session, 'fetchThreadDetails:success', function () {
        this.session.isLoggedIn() && this.thread.subscribe()
      }),
      this.session.get('sso') && this.session.get('sso').url ? this.session.authenticate('sso') : this.session.authenticate('disqusDotcom')
    }
  }),
  Da = c.View.extend({
    topEdgeOffset: function () {
      return - U.getLounge().getPosition().height
    },
    initialize: function (a) {
      this.options = a,
      this.hasLoaded = null,
      this.listenToOnce(f(this), 'enter', this.loadImage)
    },
    loadImage: function () {
      var a = this;
      if (!a.hasLoaded) {
        var b = function (b) {
          return function () {
            a.trigger(b),
            a.$el.off('.deferredMediaView'),
            a.relatedPost && U.getLounge().postsView.onDeferredViewReady(a.relatedPost)
          }
        };
        a.$el.on('load.deferredMediaView', b('load')),
        a.$el.on('error.deferredMediaView', b('error')),
        a.$el.attr('src', a.options.url),
        a.hasLoaded = !0
      }
    }
  }),
  Ea = c.View.extend({
    tagName: 'ul',
    className: 'debug',
    initialize: function (a) {
      this.values = a
    },
    render: function () {
      return this.$el.html(b.reduce(this.values, function (a, b, c) {
        return a + '<li><strong>' + c + '</strong>: ' + b + '</li>'
      }, '')),
      this
    }
  }),
  Fa = c.View.extend({
    initialize: function (a) {
      this.forum = a.forum,
      this.session = a.session,
      this.thread = a.thread,
      this.isInHome = a.isInHome,
      this.listenTo(this.session, 'change:id', this.render),
      this.listenTo(this.thread, 'change', this.render),
      this.listenTo(aa.settings, 'change:collapsed', this.onMediaCollapseChange),
      this.listenToReactions()
    },
    listenToReactions: function () {
      this.thread.get('reactions') ? this.listenTo(this.thread.get('reactions'), 'sync change:enabled', this.render) : this.listenToOnce(this.thread, 'change:reactions', this.listenToReactions)
    },
    render: function () {
      return i.render(h.createElement(pa, {
        user: this.session.toJSON(),
        forum: this.forum.toJSON(),
        thread: this.thread.toJSON(),
        sso: this.session.get('sso'),
        isInHome: this.isInHome
      }), this.el),
      this.onMediaCollapseChange(),
      this
    },
    onMediaCollapseChange: function () {
      aa.settings.get('collapsed') ? this.$el.addClass('media-collapsed') : this.$el.removeClass('media-collapsed')
    }
  }),
  Ga = c.View.extend({
    events: {
      'click [data-action=share\\:twitter]': '_onShare',
      'keyup [data-action=share\\:twitter]': '_onShare',
      'click [data-action=share\\:facebook]': '_onShare',
      'keyup [data-action=share\\:facebook]': '_onShare',
      'click [data-action=share\\:email]': '_onShare',
      'keyup [data-action=share\\:email]': '_onShare',
      'click [data-action=copy-link]': '_onCopyLink',
      'keyup [data-action=copy-link]': '_onCopyLink'
    },
    _onCopyLink: Aa(function () {
      M.isFeatureActive('sso_less_branding', {
        forum: this.model.forum.id
      }) ? F.copyToClipboard(this.model.permalink()) : F.copyToClipboard(this.model.shortLink())
    }),
    _onShare: Aa(function (a) {
      var b = 13;
      if (!a.keyCode || a.keyCode === b) {
        var c = x.extractService(a.target, 'share');
        c && this.sharers[c] && (U.getLounge().trigger('uiAction:threadShare', c), this.share(c))
      }
    }),
    render: function () {
      return i.render(h.createElement(qa, {
        forum: this.model.forum.id
      }), this.el),
      this
    }
  });
  b.extend(Ga.prototype, W.ShareMixin);
  var Ha = c.View.extend({
    events: {
      'change input[name=tos], input[name=privacy-policy]': 'updateEnabled'
    },
    initialize: function (a) {
      this.isPrivate = a.isPrivate,
      this.session = a.session
    },
    updateEnabled: function () {
      this.$('#accept_tos').prop('disabled', !!this.isPrivate && !this.areTosAccepted())
    },
    areTosAccepted: function () {
      return this.$('input[name=tos]').prop('checked') && this.$('input[name=privacy-policy]').prop('checked')
    },
    onAccept: function () {
      if (!this.isPrivate || this.areTosAccepted()) {
        var a = this.$('input[name=data-sharing]');
        a.length && l.call('internal/users/setDNT', {
          method: 'POST',
          data: {
            value: a.prop('checked') ? 0 : 1
          }
        }),
        l.call('users/acceptTerms', {
          method: 'POST'
        }),
        this.close()
      }
    },
    close: function () {
      this.remove()
    },
    render: function () {
      return i.render(h.createElement(ua, {
        onAccept: this.onAccept.bind(this),
        isPrivate: this.isPrivate
      }), this.el),
      this.updateEnabled(),
      this
    }
  }),
  Ia = c.View.extend({
    initialize: function (a) {
      this.thread = a.thread,
      this.postCount = a.thread.get('posts') || 0,
      this.settings = a.settings
    },
    render: function () {
      return i.render(h.createElement(R, {
        postCount: this.postCount,
        titleEnabled: this.settings.title_enabled,
        titleText: this.settings.title_text,
        titleCSS: this.settings.title_css,
        buttonText: this.settings.button_text,
        buttonCSS: this.settings.button_css
      }), this.el),
      this
    }
  }),
  Ja = c.View.extend({
    initialize: function (a) {
      this.thread = a.thread,
      this.forum = a.forum,
      this.inHome = a.inHome,
      this.hideFooter = a.hideFooter,
      this.posts = a.posts
    },
    render: function () {
      return i.render(h.createElement(S, {
        thread: this.thread.toJSON(),
        forum: this.forum.toJSON(),
        inHome: this.inHome,
        hideFooter: this.hideFooter,
        isPolicyAccepted: Boolean(K.get('isPolicyAccepted:' + this.forum.id)),
        posts: this.posts
      }), this.el),
      this
    }
  }),
  Ka = c.View.extend({
    events: {
      'click [data-action^=auth\\:]': 'handleAuth',
      'click [data-action=logout]': 'handleLogout',
      'click [data-action=audiencesync]': 'audienceSync',
      'click [data-action=profile]': 'handleShowProfile',
      'click [data-action=community-sidebar]': 'handleShowCommunitySidebar',
      'click [data-action=sort]': 'handleSort',
      'click [data-action=toggle-thread-premoderate]': 'toggleThreadPremoderate',
      'click [data-action=toggle-thread]': 'toggleThread',
      'click [data-action=toggle-thread-ratings]': 'toggleThreadRatingsEnabled',
      'click [data-action=toggle-thread-visibility]': 'toggleBehindClick',
      'click [data-action=debug]': 'renderDebugInfo',
      'click [data-action=repair]': 'repairThread',
      'click [data-action=toggle-media]': 'toggleMedia',
      'click [data-action=toggle-reactions]': 'toggleReactions',
      'click a': 'handleLinkClick',
      'click [data-action=accept-comment-policy]': 'setPolicyAccepted',
      'click [data-action=toggle-embed-refresh]': 'toggleEmbedRefresh'
    },
    initialize: function (c) {
      U.setLounge(this),
      c = c || {
      };
      var d = c.jsonData || {
      };
      this.language = ya.documentElement.lang,
      this.initialData = d.response || {
      },
      this.cleanInitialData(this.initialData),
      this.onboardWindowName = x.globalUniqueId('disqus_'),
      this.initialData.forum && this.initialData.forum.id && (A.moderate = x.updateURL(A.moderate, {
        hostname: this.initialData.forum.id + '.'
      })),
      this.deferredViews = [
      ],
      this.unsortedDeferredViews = [
      ],
      this.inthreadAdApps = [
      ],
      this.adPromise = a.Deferred().resolve(),
      D.setDefaults(this.initialData.session),
      this.session = D.get(),
      this.forum = new v.Forum,
      this.forum.set(this.initialData.forum),
      this.thread = new v.Thread(this.initialData.thread, {
        forum: this.forum,
        postCursor: d.cursor,
        moderators: (this.initialData.thread || {
        }).moderators,
        order: d.order
      }),
      this.initUserSuggestionsManager();
      this.postsView = new _.PostCollectionView({
        posts: this.thread.posts,
        thread: this.thread,
        lounge: this,
        session: this.session,
        el: this.el,
        userSuggestions: this.userSuggestions
      }),
      this.states = {
        fullyVisible: !1,
        realtimeIndicatorsCreated: !1,
        streamingPaused: !1,
        inViewport: !1,
        behindClick: !1
      },
      this.meta = {
        topics: null
      },
      xa.timings.loungeStart = Number(new Date);
      var e = b.bind(this.bootstrap, this);
      G(window) ? (this.listenTo(y.frame, 'init', e), this.initThreadView()) : b.defer(e),
      this.setAlertSelector('#layout'),
      this.initResizeHandler(),
      this.initAlertListeners(),
      this.initTopics()
    },
    setPolicyAccepted: function () {
      K.set('isPolicyAccepted:' + this.forum.id, !0),
      this.$el.find('#comment-policy').addClass('hidden')
    },
    cleanInitialData: function (a) {
      var c = a.thread && a.thread.highlightedPost;
      c && (c.isHighlighted = !0),
      b.each(a.posts, function (a) {
        c ? a.isHighlighted = a.id === c.id : a.isHighlighted = !1
      })
    },
    initAlertListeners: function () {
      this.listenTo(this.session, 'alert', this.alert)
    },
    initOnboardAlert: function () {
      var a = this.onboardAlert = new ba.OnboardAlert({
        session: this.session,
        forum: this.forum
      });
      this.proxyViewEvents(this.onboardAlert),
      this.listenTo(this.session, 'change:id', function () {
        a.setInitialCookie(),
        a.render().$el.appendTo('#onboard')
      })
    },
    bootstrap: function (a) {
      var c,
      d = this,
      e = {
      };
      d.config = a = a || x.getConfigFromHash(window),
      a.forceSwitch && M.forceFeature(a.forceSwitch),
      a.loaderVersion = xa.version,
      d.states.fullyVisible = a.startedFullyVisible,
      k.init({
        isPrivate: a.isPrivate
      });
      var f = a.experiment;
      if (f) {
        if (f.experiment && f.variant) {
          var g = f,
          h = g.experiment,
          i = g.variant;
          h = h.replace(/_hidden$/, ''),
          M.forceFeature(['experiment',
          h,
          i].join(':'))
        }
      } else a.experiment = f = {
      };
      a.apiKey && (e['X-Disqus-Publisher-API-Key'] = a.apiKey),
      b.isObject(a.remoteAuthS3) && b.isEmpty(a.remoteAuthS3) ? a.remoteAuthS3 = null : e['X-Disqus-Remote-Auth'] = a.remoteAuthS3,
      b.isEmpty(e) || l.headers(e),
      a.anchorColor && (c = H(a.anchorColor), x.setPublisherColor(c), x.addStylesheetRules([['.publisher-anchor-color a',
      [
        'color',
        c,
        !0
      ]],
      [
        'a.publisher-anchor-color',
        [
          'color',
          c,
          !0
        ]
      ],
      [
        '.publisher-anchor-hover a:hover',
        [
          'color',
          c,
          !0
        ]
      ],
      [
        'a.publisher-anchor-hover:hover',
        [
          'color',
          c,
          !0
        ]
      ],
      [
        '.active .publisher-nav-color:after',
        [
          'background',
          c,
          !0
        ]
      ],
      [
        '.media-preview .active.publisher-border-color',
        [
          'border-color',
          c,
          !0
        ]
      ],
      [
        '.publisher-color',
        [
          'color',
          c,
          !1
        ]
      ],
      [
        '.publisher-color:hover',
        [
          'color',
          c,
          !1
        ]
      ],
      [
        '.publisher-background-color',
        [
          'background-color',
          c,
          !1
        ]
      ],
      [
        '.publisher-border-color',
        [
          'border-color',
          c,
          !1
        ]
      ],
      [
        '.publisher-color-refresh',
        [
          'color',
          c,
          !0
        ]
      ],
      [
        '.publisher-color-refresh:hover',
        [
          'color',
          c,
          !0
        ]
      ],
      [
        '.publisher-background-color-refresh',
        [
          'background-color',
          c,
          !0
        ]
      ],
      [
        '.publisher-background-color-hover-refresh:hover',
        [
          'background-color',
          c,
          !0
        ]
      ],
      [
        '.publisher-border-color-refresh',
        [
          'border-color',
          c,
          !0
        ]
      ]])),
      a.impressionId && k.impression.setImpressionId(a.impressionId),
      x.injectBaseElement(),
      a.referrer && (d.thread.currentUrl = a.referrer),
      this.config.inthreadLeadingCommentCount && (this.config.inthreadLeadingCommentCount = Number(this.config.inthreadLeadingCommentCount), this.config.inthreadRepeatCommentCount = Number(this.config.inthreadRepeatCommentCount), this.config.inthreadTrailingCommentCount = Number(this.config.inthreadTrailingCommentCount));
      var j = this.getPermalinkOptions(a.parentWindowHash);
      j && y.frame.once('embed.rendered', b.bind(d.scrollToPost, d, j.postId, j.options)),
      a.sso && d.session.set('sso', a.sso),
      M.isFeatureActive('embed_v2', {
        forum: this.forum.id
      }) && (window.embedv2 = window.embedv2 || {
      }, window.embedv2.embedConfig = a, window.embedv2.TLDS = t.TLDS),
      a.initialPosition ? d.position = a.initialPosition : d.position = x.calculatePositionFullscreen(),
      d.initPrivacySettings(),
      d.initLinkAffiliation(),
      d.initLiveRamp(),
      d.updateModeratorBadgeText(),
      d.bindBusListeners();
      var m = xa.timings;
      m.hostStart = a.timestamp || m.initStart,
      m.embedLoadTime = a.loadTime,
      this.once('threadView:prep', function () {
        d.listenToOnce(d.postsView, 'render:start', function () {
          m.renderStart = Number(new Date)
        }),
        d.listenToOnce(d.postsView, 'render:end', d.sendTelemetry),
        m.bootstrapStart = Number(new Date),
        d.postsView.bootstrap(d.initialData, j),
        d.initAfterPostCreateHandler(),
        d.initSession()
      }),
      d.initUI(),
      d.initLinkHandler(),
      d.initialized = !0,
      d.trigger('bootstrap:complete', d)
    },
    _isInHome: function (a, b) {
      var c = /^(?:https?:)?\/\/(?:www.)?/;
      return a = a.replace(c, ''),
      b = b.replace(c, ''),
      0 === a.indexOf(b)
    },
    isInHome: function () {
      return !(!this.config || !this.config.referrer) && this._isInHome(this.config.referrer, T.apps.home + 'home/')
    },
    isOnChannel: function () {
      return !(!this.forum || !this.forum.id) && 0 === this.forum.id.indexOf('channel-')
    },
    initSession: function () {
      var a = this.config,
      b = this.session,
      c = this.thread;
      b.start({
        remoteAuthS3: a.remoteAuthS3,
        sso: a.sso,
        apiKey: a.apiKey,
        thread: c
      })
    },
    initPrivacySettings: function () {
      this.listenToOnce(this.session, 'change:id', function (a) {
        oa.isPrivate(a) && m.set({
          collapsed: {
            value: !0,
            persist: !1
          }
        })
      })
    },
    initLiveRamp: function () {
      var a = this.forum.get('settings') || {
      };
      a.userIdentityDisabled || this.listenTo(this.session, 'change:id', function (a) {
        var b = a.get('email');
        b && y.frame.sendHostMessage('liveramp:init', {
          email: a.get('email'),
          launchpad: A.liveRampAtsV2
        })
      })
    },
    initLinkAffiliation: function () {
      var a = N.getVersion();
      if (M.isFeatureActive('viglink_experiment', {
        forum: this.forum.id,
        forumPercent: this.forum.id
      }) && (a = N.getExperimentVersion()), this.isLinkAffiliatorEnabled() && !this.initLinkAffiliatorCalled && 'none' !== a) {
        this.initLinkAffiliatorCalled = !0;
        var b = A.linkAffiliatorClientV4;
        oa.shouldTrack(this.forum, this.session.user) && 'v5' === a && (b = A.linkAffiliatorClientV5),
        y.frame.sendHostMessage('viglink:init', {
          clientUrl: b,
          apiUrl: A.linkAffiliatorAPI,
          key: E.viglinkAPI,
          id: this.forum.get('pk')
        })
      }
    },
    initAfterPostCreateHandler: function () {
      this.listenTo(this.thread, 'create', function (a) {
        var c = a.toJSON();
        y.frame.sendHostMessage('posts.create', c),
        Ba.broadcast('posts.create', b.pick(c, 'forum', 'parent', 'id'))
      })
    },
    sendTelemetry: function () {
      if (x.shouldSample(u.lounge.telemetry_sample_percent)) {
        var c = a.now(),
        d = xa.timings,
        e = {
          embed: d.embedLoadTime,
          frame: d.initStart - d.hostStart,
          asset: d.downloadEnd - d.initStart,
          render: c - d.renderStart,
          total: c - d.hostStart - (d.renderStart - d.bootstrapStart)
        },
        f = window.performance;
        if (f) {
          var g = f.timing;
          g.responseStart && (e.frame_rtt = g.responseStart - g.navigationStart);
          var h = b.find(f.getEntries && f.getEntries() || [
          ], function (a) {
            return a.name.indexOf('/next/config.js') > - 1
          });
          h && h.responseStart && (e.config_rtt = h.responseStart - h.startTime)
        }
        var i = 'lounge_' + ('static' === this.config.experiment.service ? 'static' : 'dynamic');
        return B.telemetry(i, e)
      }
    },
    initUI: function () {
      this.applyPublisherClasses(),
      this.renderLayout(),
      this.setAlertSelector('#global-alert'),
      this.bindUIUpdateHandlers(),
      this.initDeferredViews(),
      this.postsView.once('render:end', function () {
        var a = x.getPageHeight();
        y.frame.sendHostMessage('rendered', {
          height: a
        }),
        this._lastHeight = a,
        this.initRealtime()
      }, this),
      this.once('threadView:prep', this.initUIComponents),
      this.initThreadView()
    },
    initUIComponents: function () {
      this.initMainPostBox(),
      this.initTermsOfService(),
      this.initReactions(),
      this.initStarRatings(),
      this.initThreadFooter(),
      this.initSecondaryNavigation(),
      this.isInHome() || (this.initTopNavigation(), this.initUserMenu(), this.initOnboardAlert(), this.initNotificationMenu(), this.initFavoriteButton(), this.initThreadShareBar()),
      M.isFeatureActive('embed_refresh_v2', {
        forum: this.forum.id
      }) || this.initBadgesMessage(),
      this.initHighlightedPost(),
      this.initEmailSignup(),
      this.initThreadSubscribe(),
      this.bindProfileUIListeners(this.session),
      this.updatePostCount(),
      this.trigger('threadView:render')
    },
    initHighlightedPost: function () {
      var a = this.thread.get('highlightedPost');
      a && !M.isFeatureActive('embed_refresh', {
        forum: this.forum.id
      }) && this.thread.posts.add(a),
      this.highlightedPostView = new da.HighlightedPostView({
        el: this.threadView.$el.find('#highlighted-post'),
        thread: this.thread,
        session: this.session,
        userSuggestions: this.userSuggestions,
        config: this.config
      }),
      this.highlightedPostView.reset()
    },
    initReactions: function () {
      if (this.forum.get('settings')) {
        if (!this.forum.get('settings').threadReactionsEnabled && !this.forum.channel) return void this.initReactionsPromotion();
        var a = new w.ReactionsCollection([], {
          thread: this.thread,
          userIsAnonymous: this.session.user.isAnonymous()
        });
        this.listenTo(a, 'sync', function () {
          a.length ? this.showReactions(a) : this.removeReactions()
        }),
        this.listenTo(a, 'change:enabled', function () {
          a.enabled ? this.showReactions(a) : this.removeReactions()
        }),
        this.thread.set('reactions', a),
        a.fetch()
      }
    },
    showReactions: function (a) {
      if (!this.reactionsView) {
        var b = this.reactionsView = new ia({
          reactions: a,
          readonly: this.thread.get('isClosed'),
          session: this.session,
          forum: this.thread.forum.id
        });
        b.render(),
        this.threadView.$el.find('#reactions__container').prepend(b.$el)
      }
    },
    removeReactions: function () {
      this.reactionsView && (this.reactionsView.remove(), this.reactionsView = null)
    },
    initReactionsPromotion: function () {
      if (!this.thread.isModerator(this.session.user)) return void this.listenToOnce(this.session, 'change:id', this.initReactionsPromotion);
      var b = 'reactionsEmbedPromotion',
      c = this;
      l.call('announcements/messages/checkViewed', {
        data: {
          message: b
        }
      }).success(function (d) {
        var e = d.response;
        if (!e[b]) {
          var f = c.reactionsPromotionView = new ja({
            forum: c.forum
          });
          f.render(),
          a('#reactions__container').prepend(f.$el)
        }
      })
    },
    initStarRatings: function () {
      this.forum.get('features') ? I.isForumModelRatingsEnabled(this.forum) && (this.thread.get('ratingsEnabled') && this.thread.fetchRatings(), this.listenTo(this.thread, 'change', this.showRatings), this.showRatings()) : this.listenToOnce(this.thread.forum, 'change:features', this.initStarRatings)
    },
    showRatings: function () {
      var a = M.isFeatureActive('star_ratings_total_hidden', {
        forum: this.forum.id
      });
      if (!this.ratingsView && this.thread && this.session && !a) {
        var b = this.ratingsView = new ha({
          thread: this.thread,
          session: this.session
        });
        b.render(),
        this.threadView.$el.find('#ratings__container').html(b.$el)
      }
    },
    bindUIUpdateHandlers: function () {
      var a = this,
      b = a.thread,
      c = a.session;
      a.listenTo(b, {
        'change:posts': a.updatePostCount
      }),
      a.listenTo(b.queue, 'add reset', a.toggleRealtimeNotifications),
      a.postsView.bindUIUpdateHandlers(),
      a.listenTo(c, 'change:id', a.updateThreadSessionData),
      a.listenTo(a, 'scrollOffViewport', function () {
        this.states.realtimeIndicatorsCreated && y.frame.sendHostMessage('indicator:hide')
      }),
      a.listenTo(a, 'scroll', function (a) {
        this.position = a
      }),
      a.listenTo(a, 'scroll', a.handleRealtimeScroll),
      a.listenTo(a.postsView, 'render:end', function () {
        a.toggleRealtimeNotifications(),
        a.config.inthreadPlacementUrl && a.loadInthreadAd()
      }),
      a.listenToOnce(a, 'threadView:render', function () {
        a.loadInEmbedAd()
      })
    },
    whenFullyVisible: function () {
      var b = a.Deferred();
      return this.states.fullyVisible ? b.resolve() : this.listenTo(this, 'frame.visible', function () {
        b.resolve()
      }),
      b.promise()
    },
    canShowInthreadAd: function (a, b) {
      if (!this.config.inthreadMultipleAds && a > 0) return !1;
      var c = this.config.inthreadLeadingCommentCount + this.config.inthreadRepeatCommentCount * a,
      d = c + this.config.inthreadTrailingCommentCount;
      return b >= d
    },
    inthreadAdInit: function (b, c) {
      var d = a.Deferred();
      return this.inthreadAdApps[b].init(),
      this.listenToOnce(this.inthreadAdApps[b], 'frame:ready', function () {
        c.css({
          height: 'auto',
          'margin-bottom': '24px'
        }),
        d.resolve()
      }),
      this.listenToOnce(this.inthreadAdApps[b], 'ad-placement-empty', function () {
        c.css({
          height: '',
          'margin-bottom': ''
        })
      }),
      d.promise()
    },
    loadInEmbedAd: function () {
      var c = this.config.topInEmbedPlacementUrl;
      if (c) {
        var d = a(sa());
        d.prependTo(this.postsView.$el);
        var e = j.Ads(b.extend({
          adUrl: c,
          placement: 'top_in_embed',
          container: d[0],
          isInHome: !1,
          isOnHostPage: !1,
          forumId: this.forum.get('pk'),
          version: this.config.version
        }, this.config));
        e.init()
      }
      var f = this.config.bottomInEmbedPlacementUrl;
      if (f) {
        var g = a(sa());
        g.appendTo(this.postsView.$el);
        var h = j.Ads(b.extend({
          adUrl: f,
          placement: 'bottom_in_embed',
          container: g[0],
          isInHome: !1,
          isOnHostPage: !1,
          forumId: this.forum.get('pk'),
          version: this.config.version
        }, this.config));
        h.init()
      }
    },
    loadInthreadAd: function () {
      var c = this.postsView.$el.find('#post-list');
      if (!(this.config.adBlockEnabled && !this.config.defaultPlacementUrl || c.hasClass('loading'))) {
        var d = this.config.inthreadCountChildren ? c.find('.post:not(.advertisement)') : c.children(':not(.advertisement)'),
        e = {
        };
        0 === this.config.experiment.experiment.indexOf('googlewidemargins') && 'fallthrough' !== this.config.experiment.variant && (e.margin = '0 ' + this.config.experiment.variant, e['min-width'] = 'calc(100% - ' + 2 * parseInt(this.config.experiment.variant, 10) + 'px)');
        var f;
        f = this.config.adBlockEnabled && this.config.defaultPlacementUrl ? J(this.config.defaultPlacementUrl, {
          position: 'inthread'
        }) : this.config.inthreadPlacementUrl;
        for (var g = this.inthreadAdApps.length; this.canShowInthreadAd(g, d.length); g++) {
          var h = this.config.inthreadLeadingCommentCount + this.config.inthreadRepeatCommentCount * g,
          i = a(ta());
          d && d.length && d[h] ? i.insertBefore(d[h]) : i.appendTo(a('#post-list')),
          this.inthreadAdApps[g] = j.Ads(b.extend({
            adUrl: f,
            placement: 'inthread',
            container: i.find('[data-role=post-content]') [0],
            isInHome: this.isInHome(),
            isOnHostPage: !1,
            forumId: this.forum.get('pk'),
            version: this.config.version,
            styles: e
          }, this.config));
          var k = this.inthreadAdInit.bind(this, g, i);
          0 === g ? this.adPromise = this.whenFullyVisible().then(k) : this.adPromise = this.adPromise.then(k)
        }
      }
    },
    relayScrollToStance: function (a) {
      f.scroll({
        top: a.pageOffset - a.frameOffset.top,
        height: a.height
      })
    },
    initDeferredViews: function () {
      this.listenTo(this, 'scroll', this.createDeferredViewsForImages),
      this.listenTo(this, 'domReflow', function () {
        f.invalidate(),
        this.position && (this.createDeferredViewsForImages(), this.relayScrollToStance(this.position))
      })
    },
    bindBusListeners: function () {
      this.listenTo(y.frame, {
        'window.hashchange': function (a) {
          var b = this.getPermalinkOptions(a);
          b && this.scrollToPost(b.postId, b.options)
        },
        'window.scroll': function (a) {
          this.trigger('scroll', a),
          this.relayScrollToStance(a)
        },
        'window.inViewport': function () {
          this.states.behindClick || (this.states.inViewport = !0, this.trigger('inViewport'))
        },
        'window.scrollOffViewport': function () {
          this.states.inViewport = !1,
          this.trigger('scrollOffViewport')
        },
        'frame.visible': function () {
          this.states.fullyVisible = !0,
          this.trigger('frame.visible')
        },
        error: function (a) {
          a = JSON.parse(a),
          e.captureException(a.error, {
            extra: {
              details: a.details
            },
            culprit: a.culprit
          })
        },
        'window.resize': this.resize,
        'indicator:click': this.handleRealtimeClick
      }),
      this.listenToOnce(this.session, 'change:id', this.initSidebar)
    },
    isLinkAffiliatorEnabled: function () {
      return this.forum.get('settings').linkAffiliationEnabled && !this.isInHome()
    },
    initLinkHandler: function () {
      this.outboundLinkHandler = new P,
      this.outboundLinkHandler.registerBeforeNavigationHandler(this.logLinkClick, this)
    },
    handleLinkClick: function (a) {
      this.outboundLinkHandler.handleClick(a)
    },
    initRealtimeIndicators: function () {
      var a = this;
      if (!a.states.realtimeIndicatorsCreated) {
        var c = [
          'north',
          'south'
        ].reduce(function (c, d) {
          return c[d] = {
            contents: '\n<!DOCTYPE html>\n<html lang="' + b.escape(a.language) + '">\n    <head>\n        <meta charset="utf-8">\n        <title>Disqus Realtime Notification</title>\n    </head>\n    <body>\n        <link rel="stylesheet" href="' + b.escape('https://c.disquscdn.com/next/embed/styles/realtime.b23ff3c36dd0169627f8e54ca1621eca.css') + '">\n        <div class="' + b.escape(d) + '" id="message">-</div>\n    </body>\n</html>\n'
          },
          c
        }, {
        });
        y.frame.sendHostMessage('indicator:init', c),
        a.states.realtimeIndicatorsCreated = !0
      }
    },
    insertStreamingComments: b.throttle(function () {
      var a = this.thread.queue;
      a.drain(),
      b.each(a.counters.replies, function (b, c) {
        a.drain(c)
      })
    }, 1000),
    updateModeratorBadgeText: function () {
      var a = this.forum.get('moderatorBadgeText');
      a && (z.translations.Mod = a)
    },
    logLinkClick: function (b) {
      var c = a(b.currentTarget);
      if (F.clickShouldBeLogged(b, c)) return B.client.emit({
        verb: 'click',
        object_type: 'link',
        object_id: c[0].href,
        area: oa.getEventTrackingArea(b)
      })
    },
    handleRealtimeScroll: function (a) {
      if (this.states.inViewport && this.states.realtimeIndicatorsCreated) {
        var c = b.union([this.queueView], b.values(this.postsView.subViews)),
        d = 0,
        e = 0;
        b.each(c, function (b) {
          if (b && !b.getDirection && (b = b.queueView), b && !(b.options.count <= 0)) {
            var c = b.getDirection(a);
            1 === c ? d += b.options.count : c === - 1 && (e += b.options.count)
          }
        });
        var f,
        g,
        h = function (a) {
          var c = a.orientation,
          d = a.num,
          e = void 0;
          return e = 'north' === c ? 1 === d ? za('One new comment above.') : z.interpolate(za('%(num)s new comments above.'), {
            num: d
          }) : 1 === d ? za('One new comment below.') : z.interpolate(za('%(num)s new comments below.'), {
            num: d
          }),
          '<p>' + b.escape(e) + '</p>'
        };
        g = {
          type: 'north'
        },
        d > 0 ? (f = 'indicator:show', g.content = h({
          num: d,
          orientation: 'north'
        })) : f = 'indicator:hide',
        y.frame.sendHostMessage(f, g),
        g = {
          type: 'south'
        },
        e > 0 ? (g.content = h({
          num: e,
          orientation: 'south'
        }), f = 'indicator:show') : f = 'indicator:hide',
        y.frame.sendHostMessage(f, g)
      }
    },
    handleRealtimeClick: function (a) {
      var c = this;
      y.frame.sendHostMessage('indicator:hide', {
        type: a
      });
      var d,
      e,
      f,
      g = b.union([c], b.toArray(c.postsView.subViews));
      g = b.filter(g, function (b) {
        if (b = b.queueView, !b || b.options.count <= 0) return !1;
        var d = 'north' === a ? 1 : - 1;
        return b.getDirection(c.position) === d
      }),
      g = b.sortBy(g, function (a) {
        return a === c ? 0 : a.offset.top
      }),
      d = 'north' === a ? b.last(g) : b.first(g),
      e = d.queueView,
      d === c ? (f = 0, e.handleDrain()) : (f = d.offset.top - 100, e.handleDrain()),
      U.getLounge().once('domReflow', b.bind(y.frame.sendHostMessage, y.frame, 'scrollTo', {
        top: f
      }))
    },
    toggleRealtimeNotifications: function () {
      var a = this,
      c = a.thread.queue;
      if (b.defer(function () {
        y.frame.sendHostMessage('fakeScroll')
      }), !c.length) return void a.$el.find('[data-role=realtime-notification]').hide();
      if (a.thread.get('hasStreaming')) return void a.insertStreamingComments();
      if (c.counters.comments) {
        var d = a.queueView || new ea.QueuedPostView({
          model: a.thread,
          el: a.$el.find('button[data-role=realtime-notification]')
        });
        a.queueView = d,
        d.setCount(c.counters.comments),
        d.render()
      }
      b.each(c.counters.replies, function (b, c) {
        var d = a.thread.posts.get(c);
        if (d) {
          var e = a.postsView.getPostView(d.cid);
          if (e) {
            var f = e.queueView;
            f || (f = new ea.QueuedReplyView({
              thread: a.thread,
              postView: e,
              model: d,
              el: e.$el.find('[data-role=realtime-notification\\:' + c + '] a')
            }), e.queueView = f),
            f.setCount(b),
            f.render()
          }
        }
      })
    },
    initBehindClick: function () {
      var c = this;
      if (!c.behindClickView && c.thread && a('#behindclick__container').length) {
        var d = {
          title_enabled: !1,
          title_text: null,
          title_css: null,
          button_text: null,
          button_css: null
        };
        l.call('forums/behindClick/details', {
          data: {
            forum: this.forum.id
          }
        }).success(function (a) {
          var e = a.response;
          c.showBehindClick(b.defaults({
          }, e, d))
        })
      }
    },
    showBehindClick: function (b) {
      var c = a('#behindclick__container'),
      d = new Ia({
        thread: this.thread,
        settings: b
      });
      d.render(),
      c.html(d.$el),
      y.frame.sendHostMessage('rendered', {
        height: x.getPageHeight()
      })
    },
    toggleBehindClick: function () {
      this.$('#behindclick__container').hide(),
      this.states.behindClick = !1,
      y.frame.trigger('window.inViewport'),
      y.trigger('uiAction:behindClickButton'),
      this.trigger('threadView:prep')
    },
    initThreadView: function () {
      this.createThreadView(),
      this.forum.get('settings').behindClickEnabled ? (this.initBehindClick(), this.states.behindClick = !0) : this.trigger('threadView:prep')
    },
    createThreadView: function () {
      if (!this.threadView && this.thread && this.session) {
        var a,
        b = this.isInHome();
        this.thread.posts.buffer && (a = this.thread.posts.getOrder());
        var c = this.threadView = new Ja({
          thread: this.thread,
          forum: this.forum,
          order: a,
          inHome: b,
          hideFooter: b,
          posts: this.initialData.posts
        });
        c.render(),
        this.trigger('threadView:init'),
        this.once('threadView:render', function () {
          this.$('#thread__container').html(this.threadView.$el)
        })
      }
    },
    renderDebugInfo: Aa(function () {
      if (this.session.user.get('isGlobalAdmin')) {
        var a = this.thread.forum.get('settings', {
        }),
        b = new Ea({
          Shortname: this.thread.get('forum'),
          'Thread ID': this.thread.get('id'),
          'Org ID': this.forum.get('organizationId'),
          'Thread slug': this.thread.get('slug'),
          'Anchor color': H(this.config.anchorColor),
          Language: this.thread.forum.get('language'),
          Recommendations: a.organicDiscoveryEnabled,
          'Ads enabled': a.adsEnabled,
          'Ads top enabled': a.adsPositionTopEnabled,
          'Ads bottom enabled': a.adsPositionBottomEnabled,
          'Ads in-thread enabled': a.adsPositionInthreadEnabled,
          'Ads recommendations enabled': a.adsPositionRecommendationsEnabled,
          'Ads Product Display enabled': a.adsProductDisplayEnabled,
          'Ads Product Links enabled': a.adsProductLinksEnabled,
          'Ads Product Video enabled': a.adsProductVideoEnabled,
          'In iframe': this.config.isHostIframed,
          'Behind click': this.config.isBehindClick,
          'Height restricted': this.config.isHeightRestricted
        });
        b.render();
        var c = ya.body;
        c.insertBefore(b.el, c.firstChild)
      }
    }),
    repairThread: Aa(function () {
      this.session.user.get('isGlobalAdmin') && l.call('internal/threads/repair.json', {
        method: 'GET',
        data: {
          thread: this.thread.get('id')
        },
        success: b.bind(this.alert, this, 'Thread repair has been queued. Refresh in a few seconds.'),
        error: b.bind(this.alert, this, 'An error occurred while repairing thread. Please try again.', {
          type: 'error'
        })
      })
    }),
    getPermalinkOptions: function (a) {
      var b = a && a.match(/(comment|reply|edit)-([0-9]+)/);
      if (b) return {
        postId: b[2],
        options: {
          highlight: !0,
          openReply: 'reply' === b[1],
          openEdit: 'edit' === b[1]
        }
      }
    },
    scrollToPost: function (a, c) {
      c = c || {
      },
      c.padding = c.padding || 90;
      var d = this,
      e = d.$el.find('#post-' + a);
      if (M.isFeatureActive('embed_refresh', {
        forum: this.forum.id
      }) && !e.length && d.highlightedPostView && d.highlightedPostView.post && d.highlightedPostView.post.id === a) e = d.highlightedPostView.$el.find('.post');
       else if (!e.length) return void v.Post.fetchContext(a, d.thread, {
        requestedByPermalink: !0
      }).done(function () {
        d.postsView.once('render:end', b.bind(d.scrollToPost, d, a, c)),
        y.frame.once('embed.resized', b.bind(d.scrollToPost, d, a, c))
      });
      c.highlight && (d.$el.find('.post-content.target').removeClass('target'), e.find('.post-content').first().addClass('target')),
      c.openReply && d.postsView.openReply(a),
      c.openEdit && d.postsView.openEdit(a),
      y.frame.sendHostMessage('scrollTo', {
        top: e.offset().top - c.padding,
        force: c.force || null
      })
    },
    updateThreadSessionData: function (a) {
      if (a) {
        a.get('thread') && this.thread.set(a.get('thread'));
        var c = a.get('votes');
        c && 'object' === ('undefined' == typeof c ? 'undefined' : _typeof(c)) && b.each(c, function (a, b) {
          var c = this.postsView.posts.get(b);
          c && c.set('userScore', a)
        }, this);
        var d = a.get('blockedUserIdSet');
        if (d && 0 !== d.size) {
          var e = this.postsView.posts.models;
          if (e && 'object' === ('undefined' == typeof e ? 'undefined' : _typeof(e))) {
            var f = {
            };
            b.each(e, function (a) {
              var b = a.attributes.id,
              c = a.author.id;
              if (f[b] = c, a.attributes.parent) {
                var e = a.attributes.parent,
                g = f[e];
                d.has(g) && a.set('hideReplyPreview', !0)
              }
            }, this)
          }
        }
      }
    },
    initSidebar: function () {
      this.sidebar = new ga({
        session: this.session,
        forum: this.forum,
        config: this.config
      })
    },
    initNotificationMenu: function () {
      var a = this.notificationMenu = new ca.NotificationMenuView({
        el: this.threadView.$el.find('[data-role=notification-menu]') [0],
        session: this.session,
        forum: this.forum
      });
      a.render()
    },
    initUserMenu: function () {
      var a = this.userMenu = new Fa({
        el: this.threadView.$el.find('[data-role=logout]') [0],
        forum: this.forum,
        session: this.session,
        thread: this.thread,
        isInHome: this.isInHome()
      });
      a.render()
    },
    initThreadShareBar: function () {
      if (!this.thread.forum.get('settings').disableSocialShare) {
        var a = this.threadShareBar = new Ga({
          el: this.threadView.$el.find('#thread-share-bar') [0],
          model: this.thread
        });
        a.render()
      }
    },
    isRealtimeEnabled: function () {
      var a = u.lounge.REALTIME || {
      },
      b = a.THREAD_STALE_DAYS || 7,
      c = g.unix(this.initialData.lastModified);
      return !this.thread.get('isClosed') && g().diff(c, 'days') <= b
    },
    realtimeHandlers: {
      Post: function (a) {
        var b = a.data,
        c = this.thread;
        if (!this.thread.get('hasStreaming') || !this.states.streamingPaused) {
          if (!b.id) return void d.warn('RT: no post ID');
          if (!b.author || !b.author.id) return void d.warn('RT: no author or author ID');
          if (!b.author.name) return void d.warn('RT: no author name or email hash');
          if (!b.author.username) return void d.warn('RT: no author username');
          if (!b.post || !b.post.message) return void d.warn('RT: no post message');
          if (c.posts.get(b.id) || c.queue.get(b.id)) return void d.info('RT: duplicate: ', b.id);
          if ('approved' !== b.type) return void d.info('RT: unapproved: ', b.id);
          if (b.sb) return void d.info('RT: shadowbanned: ', b.id);
          if (b.type === b.type_prev) return void d.info('RT: Post change message, ignoring for now ', b.id);
          this.thread.incrementPostCount(1);
          var e = b.post.parent_post.id;
          if ('0' === e && (e = null), e && !c.posts.get(e) && !c.queue.get(e)) return void d.info('RT: parent is not on this page: ', b.id);
          var f = b.author.name,
          g = b.author.username,
          h = b.author.avatar,
          i = b.author.id,
          j = b.author.is_private;
          '0' === i && (i = void 0);
          var k = new n(v.User, {
            id: i,
            name: f,
            username: g,
            profileUrl: A.root + '/by/' + g + '/',
            isAnonymous: !i,
            isPrivate: j,
            avatar: {
              cache: h,
              permalink: h
            }
          });
          if (k.get('isBlocked')) return void d.info('RT: blocked: ', b.id);
          c.users.add(k, {
            merge: !0
          }),
          c.queue.add({
            id: b.id,
            user: k,
            parentId: e,
            message: b.post.message,
            createdAt: b.date,
            media: b.post.media
          })
        }
      },
      Vote: function (a) {
        var b = a.data;
        if (b.id && b.vote) {
          var c = this.thread,
          e = c.posts.get(b.vote.recipient_post_id);
          if (e) {
            d.debug('RT: Vote for post ', e.id);
            var f = e.votes.get(b.id);
            f || (d.debug('RT: Creating new vote with id ', b.id), f = new r({
              id: b.id
            }), e.votes.add(f));
            var g = e._vote(b.vote.vote, f.get('score'), b.voter);
            0 !== g && f.set('score', g)
          }
        }
      },
      ThreadVote: function (a) {
        var b = a.data,
        c = this.thread;
        if (b.id && b.vote && (!this.session.user.id || b.vote.voter_id !== this.session.user.id)) {
          var d = c.votes.get(b.id);
          if (d || (d = new q({
            id: b.id
          }), c.votes.add(d)), !d.get('currentUser')) {
            var e = c._vote(b.vote.vote, d.get('score'));
            0 !== e && d.set('score', e)
          }
        }
      },
      typing: function (a) {
        var c = a.data,
        d = this.thread,
        e = c.typing,
        f = c.post;
        if (c.thread === d.id && f) {
          var g = d.posts.get(f);
          g && (g.usersTyping.count() <= 0 && !e || g.usersTyping.add(v.TypingUser.make(b.extend({
            client_context: a.lastEventId
          }, c))))
        }
      }
    },
    initRealtime: function () {
      var a = X.Manager;
      if (!a.pipe && this.isRealtimeEnabled()) {
        this.initRealtimeIndicators(),
        a.initialize('thread/' + this.thread.id, this.realtimeHandlers, this);
        var b = function (a) {
          return 'POST' === a.method
        },
        c = 0;
        this.listenTo(l, 'call', function (d) {
          b(d) && (c += 1, a.pause())
        }),
        this.listenTo(l, 'complete', function (d) {
          !b(d) || c <= 0 || (c -= 1, c || a.resume())
        })
      }
    },
    initTopNavigation: function () {
      var a = this.topNavigation = new la({
        inHome: this.isInHome(),
        thread: this.thread
      });
      a.render(),
      this.threadView.$el.find('#main-nav').append(a.el)
    },
    initThreadFooter: function () {
      var a = this.threadFooter = new ma({
        forum: this.forum
      });
      a.render(),
      this.threadView.$el.find('#footer').append(a.el)
    },
    initSecondaryNavigation: function () {
      var a,
      b = this.forum.get('votingType') || s.VOTING_TYPES.DEFAULT_VOTING_TYPE,
      c = b === s.VOTING_TYPES.DISABLED;
      this.thread.posts.buffer && (a = this.thread.posts.getOrder());
      var d = this.secondaryNavigation = new na({
        inHome: this.isInHome(),
        order: a,
        votingDisabled: c,
        forum: this.thread.forum.id
      });
      d.render(),
      this.threadView.$el.find('#secondary-navigation').append(d.el)
    },
    initFavoriteButton: function () {
      if (this.favoriteButton && this.favoriteButton.remove(), !M.isFeatureActive('sso_less_branding', {
        forum: this.forum.id
      })) {
        var a = this.favoriteButton = new ka({
          thread: this.thread,
          session: this.session
        });
        this.listenTo(a, {
          'vote:like': b.bind(this.trigger, this, 'uiAction:threadLike'),
          'vote:unlike': b.bind(this.trigger, this, 'uiAction:threadUnlike')
        }),
        a.render(),
        this.threadView.$el.find('#favorite-button').append(a.el)
      }
    },
    initThreadSubscribe: function () {
      this.threadSubscribeButton = new Ca({
        session: this.session,
        thread: this.thread,
        el: this.threadView.$el.find('#thread-subscribe-button') [0]
      })
    },
    initBadgesMessage: function () {
      this.badgesMessageView = new Y({
        forum: this.forum,
        session: this.session,
        el: this.threadView.$el.find('#badges-message__container') [0]
      }).render()
    },
    initEmailSignup: function () {
      this.emailSignupForm = new Z({
        forum: this.forum,
        session: this.session,
        el: this.threadView.$el.find('#email-signup') [0]
      }).render()
    },
    updatePostCount: function () {
      var a = this.thread.get('posts');
      this.isInHome() || (this.$postCountContainer = this.$postCountContainer || this.threadView.$el.find('li[data-role=post-count]'), this.$postCountContainer.html(va({
        count: a
      }))),
      y.frame.sendHostMessage('posts.count', a)
    },
    renderLayout: function () {
      this.addFeatureDetectionClasses(),
      V.init(this);
      var b = a(ra({
        forum: this.forum.toJSON(),
        thread: this.thread.toJSON()
      }));
      b.appendTo(this.$el),
      this.postsView.renderLayout(),
      u.readonly ? this.alert(za('The Disqus comment system is temporarily in maintenance mode. You can still read comments during this time, however posting comments and other actions are temporarily delayed.'), {
        type: 'info'
      }) : this.listenToOnce(this.session, 'change:id', this.showPremoderationAlert)
    },
    showPremoderationAlert: function () {
      this.thread.isModerator(this.session.user) && !this.getAlert() && (this.forum.get('settings').validateAllPosts ? this.alert(b.escape(za('Comments on this entire site are premoderated (only moderators can see this message).')) + (' <a href="' + b.escape('https://' + this.forum.id + '.disqus.com/admin/settings/community/') + '" target="_blank" rel="noopener noreferrer">' + b.escape(za('Change site settings.')) + '</a>'), {
        safe: !0,
        isPremoderateStatus: !0
      }) : this.thread.get('validateAllPosts') && this.alert(za('Comments on this thread are premoderated (only moderators can see this message).'), {
        isPremoderateStatus: !0
      }))
    },
    dismissPremoderationAlert: function () {
      this.dismissAlert(function (a) {
        return a.options && a.options.isPremoderateStatus
      })
    },
    addFeatureDetectionClasses: function () {
      var b = a(ya.documentElement);
      (this.config.forceMobile || F.isMobileUserAgent()) && b.addClass('mobile'),
      F.isMobileUserAgent() || b.addClass('use-opacity-transitions'),
      M.isFeatureActive('embed_refresh', {
        forum: this.forum.id
      }) && (b.addClass('embed-refresh'), M.isFeatureActive('embed_refresh_v2', {
        forum: this.forum.id
      }) && b.addClass('embed-refresh-v2'))
    },
    initMainPostBox: function () {
      if (this.form && (this.form.remove(), this.form = null), this.thread.get('isClosed')) return this.threadView.$el.find('#secondary-navigation').addClass('no-postbox'),
      void this.showClosedAlert();
      if (!this.session.get('canReply')) return this.threadView.$el.find('#secondary-navigation').addClass('no-postbox'),
      void this.session.once('change:id', this.initMainPostBox, this);
      this.threadView.$el.find('#secondary-navigation').removeClass('no-postbox');
      var a = this.form = new $({
        thread: this.thread,
        userSuggestions: this.userSuggestions,
        session: this.session
      });
      a.render(),
      this.threadView.$el.find('#form').prepend(a.$el),
      a.resize()
    },
    showClosedAlert: function () {
      if (this.thread.get('isClosed')) {
        var a = this.thread.get('reactions');
        a ? (this.listenToOnce(a, 'sync change:enabled', this.showClosedAlert), this.alert(za(a.enabled ? 'Comments and reactions for this thread are now closed.' : 'Comments for this thread are now closed'))) : (this.listenToOnce(this.thread, 'change:reactions', this.showClosedAlert), this.alert(za('Comments for this thread are now closed')))
      }
    },
    initTermsOfService: function () {
      if (this.tos && (this.tos.remove(), this.tos = null), this.listenToOnce(this.session, 'change:id', this.initTermsOfService), !(this.session.user.isAnonymous() || this.session.user.get('hasAcceptedGdprTerms') || !this.config.isPrivate && this.session.isSSO() || u.tos_exempt_forums_shortnames.includes(this.forum.id))) {
        var a = this.tos = new Ha({
          isPrivate: this.config.isPrivate,
          session: this.session
        });
        a.render(),
        this.threadView.$el.find('#tos__container').prepend(a.$el)
      }
    },
    initUserSuggestionsManager: function () {
      this.userSuggestions = new fa({
        threadId: this.thread.id
      }),
      this.userSuggestions.addRemote(this.thread.users),
      this.listenTo(this.session, 'change:id', function () {
        this.session.isLoggedIn() && (this.session.user.getFollowing(), this.session.user.following.PER_PAGE = 100, this.userSuggestions.addRemote(this.session.user.following))
      })
    },
    handleShowProfile: function (b) {
      if (!(b.ctrlKey || b.metaKey || b.shiftKey || b.altKey || !this.isInHome() && !this.sidebar)) {
        b.preventDefault();
        var c = a(b.currentTarget).attr('data-username'),
        d = a(b.currentTarget).attr('data-tab') || '';
        this.isInHome() ? y.frame.sendHostMessage('home.open', T.apps.home + 'by/' + c + '/' + d) : this.showProfileSidebar(c, d)
      }
    },
    handleShowCommunitySidebar: function (b) {
      if (!F.willOpenNewWindow(b)) {
        b.preventDefault();
        var c = a(b.currentTarget).attr('data-forum');
        y.trigger('sidebar:open', 'home/forums/' + c + '/')
      }
    },
    handleSort: Aa(function (b) {
      var c = a(b.currentTarget).attr('data-sort'),
      d = this.forum.get('votingType') === s.VOTING_TYPES.DISABLED;
      'popular' === c && d && (c = 'desc'),
      this.$el.find('[data-role="post-sort"]').replaceWith(wa({
        order: c,
        votingDisabled: d,
        forum: this.thread.forum.id
      })),
      this.thread.posts.setOrder(c),
      this.thread.posts.fetch({
        reset: !0
      }),
      y.frame.sendHostMessage('change:sort', c),
      this.inthreadAdApps = [
      ],
      this.postsView.handleSort()
    }),
    toggleThread: Aa(function () {
      var a = this.thread.get('isClosed'),
      c = za(a ? 'An error occurred while opening the thread. Please try again.' : 'An error occurred while closing the thread. Please try again.'),
      d = {
        success: function () {
          window.location.reload(!0)
        },
        error: b.bind(this.alert, this, c, {
          type: 'error'
        })
      };
      a ? this.thread.open(d) : this.thread.close(d)
    }),
    toggleThreadPremoderate: Aa(function () {
      var a = this;
      this.dismissAlert(function (a) {
        return a.options && a.options.isPremoderateError
      });
      var b = this.thread.get('validateAllPosts');
      this.thread.premoderate(!b).then(function () {
        b ? a.dismissPremoderationAlert() : a.showPremoderationAlert()
      }, function () {
        a.alert(za('An error occurred while updating the thread. Please try again.'), {
          type: 'error',
          isPremoderateError: !0
        }),
        a.thread.set('validateAllPosts', b)
      }),
      y.trigger('uiAction:clickThreadPremoderate')
    }),
    toggleThreadRatingsEnabled: Aa(function () {
      var a = this;
      I.isForumModelRatingsEnabled(this.forum) && this.thread.toggleRatingsEnabled().then(function () {
        I.isThreadModelRatingsEnabled(a.thread) && (a.session.fetchThreadDetails({
          thread: a.thread
        }), a.thread.fetchRatings())
      })
    }),
    createDeferredViewsForImages: function () {
      a('img[data-src]').each(function (b, c) {
        var d = a(c),
        e = new Da({
          el: c,
          url: d.attr('data-src')
        });
        e.relatedPost = d.attr('data-post'),
        d.removeAttr('data-src')
      })
    },
    getPosition: function () {
      return this.position
    },
    showProfileSidebar: function (a, b) {
      y.trigger('sidebar:open', 'by/' + a + '/' + b)
    },
    initResizeHandler: function () {
      var a,
      b = this;
      if (window.MutationObserver) new window.MutationObserver(function () {
        a || (a = window.requestAnimationFrame(function () {
          a = null,
          b.resize()
        }))
      }).observe(ya.body, {
        attributes: !0,
        characterData: !0,
        childList: !0,
        subtree: !0,
        attributeFilter: [
          'class',
          'style'
        ]
      });
       else {
        var c = function d() {
          b.resize(),
          window.requestAnimationFrame(d)
        };
        window.requestAnimationFrame(c)
      }
    },
    resize: function () {
      var a = x.getPageHeight();
      this._lastHeight !== a && (this._lastHeight = a, this.trigger('domReflow'), y.frame.sendHostMessage('resize', {
        height: a
      }))
    },
    handleAuth: Aa(function (a) {
      this.session.authenticate(x.extractService(a.target, 'auth'))
    }),
    handleLogout: Aa(function () {
      this.session.logout()
    }),
    audienceSync: Aa(function () {
      this.session.audienceSync()
    }),
    toggleMedia: Aa(function () {
      var a = aa.settings,
      b = !a.get('collapsed');
      a.set('collapsed', b)
    }),
    toggleReactions: Aa(function () {
      this.thread.get('reactions').toggleEnabled()
    }),
    toggleEmbedRefresh: Aa(function () {
      null === K.get('switch:embed_refresh') || K.get('switch:embed_refresh') === !0 ? (K.set('switch:embed_refresh', !1), y.trigger('uiAction:toggleClassicDisqus', !0)) : (K.remove('switch:embed_refresh'), y.trigger('uiAction:toggleClassicDisqus', !1)),
      y.frame.sendHostMessage('reset', {
        reload: !0
      })
    }),
    initTopics: function () {
      var a = this;
      if ('browsingTopics' in ya && ya.featurePolicy && ya.featurePolicy.allowsFeature && ya.featurePolicy.allowsFeature('browsing-topics')) try {
        ya.browsingTopics().then(function (b) {
          a.meta.topics = b
        })
      } catch (b) {
      }
    }
  });
  return b.extend(Ka.prototype, W.ShareMixin),
  p.call(Ka.prototype),
  x.mixin(Ka, C.UiActionEventProxy),
  o.call(Ka.prototype),
  x.mixin(Ka, C.ProfileHtmlHelpers),
  Q.call(Ka.prototype),
  {
    Lounge: Ka,
    UserMenuView: Fa,
    ThreadSubscribeButton: Ca,
    RatingsView: ha,
    ReactionsView: ia,
    BehindClickView: Ia,
    ThreadView: Ja,
    DeferredMediaView: Da,
    DebugInfoView: Ea
  }
}),
define('lounge/main', [
  'jquery',
  'core/utils/getEmbeddedData',
  'lounge/tracking',
  'lounge/views'
], function (a, b, c, d) {
  'use strict';
  return {
    init: function () {
      var e = b('threadData');
      if (!e) return {
        code: 'no_thread_data'
      };
      if (e.code) return 2 === e.code ? 'Endpoint resource not valid.' === e.response && (e.code = 'invalid_endpoint_resource') : 15 === e.code && 'Thread creations from embed disabled.' === e.response && (e.code = 'thread_creations_disabled'),
      e;
      a.extend(e.response, b('forumData')),
      a('#postCompatContainer').remove();
      var f = new d.Lounge({
        jsonData: e,
        el: window.document.body
      });
      c.init(f)
    }
  }
}),
define('lounge.bundle', function () {
});
 
Invalid Email or Password