|
1 |
| -<!-- The Disqus lazy loading. --> |
2 |
| - |
3 |
| -<div id="disqus_thread"> |
4 |
| - <p class="text-center text-muted small">Comments powered by <a href="https://disqus.com/">Disqus</a>.</p> |
5 |
| -</div> |
6 |
| - |
7 |
| -<script type="text/javascript"> |
| 1 | +<script> |
8 | 2 | var disqus_config = function () {
|
9 | 3 | this.page.url = '{{ page.url | absolute_url }}';
|
10 | 4 | this.page.identifier = '{{ page.url }}';
|
11 | 5 | };
|
12 | 6 |
|
13 |
| - {%- comment -%} Lazy loading {%- endcomment -%} |
14 |
| - var disqus_observer = new IntersectionObserver( |
15 |
| - function (entries) { |
16 |
| - if (entries[0].isIntersecting) { |
17 |
| - (function () { |
18 |
| - var d = document, |
19 |
| - s = d.createElement('script'); |
20 |
| - s.src = 'https://{{ site.comments.disqus.shortname }}.disqus.com/embed.js'; |
21 |
| - s.setAttribute('data-timestamp', +new Date()); |
22 |
| - (d.head || d.body).appendChild(s); |
23 |
| - })(); |
24 |
| - |
25 |
| - disqus_observer.disconnect(); |
26 |
| - } |
27 |
| - }, |
28 |
| - { threshold: [0] } |
29 |
| - ); |
| 7 | + function addDisqus() { |
| 8 | + let disqusThread = document.createElement('div'); |
| 9 | + let paragraph = document.createElement('p'); |
30 | 10 |
|
31 |
| - disqus_observer.observe(document.getElementById('disqus_thread')); |
| 11 | + disqusThread.id = 'disqus_thread'; |
| 12 | + paragraph.className = 'text-center text-muted small'; |
| 13 | + paragraph.innerHTML = 'Comments powered by <a href="https://disqus.com/">Disqus</a>.'; |
| 14 | + disqusThread.appendChild(paragraph); |
| 15 | + |
| 16 | + const footer = document.querySelector('footer'); |
| 17 | + footer.insertAdjacentElement("beforebegin", disqusThread); |
| 18 | + } |
32 | 19 |
|
33 | 20 | {%- comment -%} Auto switch theme {%- endcomment -%}
|
34 |
| - function reloadDisqus() { |
35 |
| - if (event.source === window && event.data && event.data.direction === ModeToggle.ID) { |
| 21 | + function reloadDisqus(event) { |
| 22 | + if (event.source === window && event.data && event.data.id === Theme.ID) { |
36 | 23 | {%- comment -%} Disqus hasn't been loaded {%- endcomment -%}
|
37 | 24 | if (typeof DISQUS === 'undefined') {
|
38 | 25 | return;
|
|
44 | 31 | }
|
45 | 32 | }
|
46 | 33 |
|
47 |
| - if (document.getElementById('mode-toggle')) { |
48 |
| - window.addEventListener('message', reloadDisqus); |
| 34 | + addDisqus(); |
| 35 | + |
| 36 | + if (Theme.switchable) { |
| 37 | + addEventListener('message', reloadDisqus); |
49 | 38 | }
|
| 39 | + |
| 40 | + {%- comment -%} Lazy loading {%- endcomment -%} |
| 41 | + var disqusObserver = new IntersectionObserver( |
| 42 | + function (entries) { |
| 43 | + if (entries[0].isIntersecting) { |
| 44 | + var d = document, |
| 45 | + s = d.createElement('script'); |
| 46 | + s.src = 'https://{{ site.comments.disqus.shortname }}.disqus.com/embed.js'; |
| 47 | + s.setAttribute('data-timestamp', +new Date()); |
| 48 | + (d.head || d.body).appendChild(s); |
| 49 | + |
| 50 | + disqusObserver.disconnect(); |
| 51 | + } |
| 52 | + }, |
| 53 | + { threshold: [0] } |
| 54 | + ); |
| 55 | + |
| 56 | + disqusObserver.observe(document.getElementById('disqus_thread')); |
50 | 57 | </script>
|
0 commit comments