Jacky Zhao
2023-02-05 11959de11ce76f0f47284b946a577481c0ffaeaa
feat: add more plausible events
5 files modified
45 ■■■■■ changed files
assets/js/graph.js 11 ●●●●● patch | view | raw | blame | history
assets/js/popover.js 5 ●●●●● patch | view | raw | blame | history
assets/js/router.js 1 ●●●● patch | view | raw | blame | history
assets/js/util.js 5 ●●●●● patch | view | raw | blame | history
layouts/partials/head.html 23 ●●●●● patch | view | raw | blame | history
assets/js/graph.js
@@ -168,7 +168,16 @@
    .style("cursor", "pointer")
    .on("click", (_, d) => {
      // SPA navigation
      window.Million.navigate(new URL(`${baseUrl}${decodeURI(d.id).replace(/\s+/g, "-")}/`), ".singlePage")
      const targ = `${baseUrl}${decodeURI(d.id).replace(/\s+/g, "-")}/`
      window.Million.navigate(new URL(targ), ".singlePage")
      plausible("Link Click", {
        props: {
          href: targ,
          broken: false,
          internal: true,
          graph: true,
        }
      })
    })
    .on("mouseover", function (_, d) {
      d3.selectAll(".node").transition().duration(100).attr("fill", "var(--g-node-inactive)")
assets/js/popover.js
@@ -64,6 +64,11 @@
            })
            el.classList.add("visible")
            plausible("Popover Hover", {
              props: {
                href: li.dataset.src
              }
            })
          })
          li.addEventListener("mouseout", () => {
            el.classList.remove("visible")
assets/js/router.js
@@ -15,7 +15,6 @@
  }
  const render = () => requestAnimationFrame(rerender)
  window.addEventListener("DOMContentLoaded", () => {
    apply((doc) => init(doc))
    init()
assets/js/util.js
@@ -123,6 +123,11 @@
    ".singlePage",
  )
  closeSearch()
  plausible("Search", {
    props: {
      term
    }
  })
}
function openSearch() {
layouts/partials/head.html
@@ -183,6 +183,28 @@
        throwOnError : false
      });
      {{end}}
      // analytics
      function clickHandler(evt) {
        const target = evt.target
        const classNames = target.className.split(" ")
        const broken = classNames.includes("broken")
        const internal = classNames.includes("internal-link")
        plausible("Link Click", {
          props: {
            href: target.href,
            broken,
            internal,
            graph: false,
          }
        })
      }
      const links = document.querySelectorAll("a")
      for (link of links) {
        link.addEventListener('click', clickHandler)
        link.addEventListener('auxclick', clickHandler)
      }
    };
  </script>
  {{if $data.enableSPA | default $.Site.Data.config.enableSPA}}
@@ -207,4 +229,5 @@
  {{end}}
  {{ $trimmedURL := trim (index (split .Site.BaseURL "://") 1) "/" }}
  <script defer data-domain="{{$trimmedURL}}" src="https://plausible.io/js/script.js"></script>
  <script>window.plausible = window.plausible || function() { (window.plausible.q = window.plausible.q || []).push(arguments) }</script>
</head>