/*! * Hugo Theme Stack * * @author: Jimmy Cai * @website: https://jimmycai.com * @link: https://github.com/CaiJimmy/hugo-theme-stack */ import StackGallery from "ts/gallery"; import { getColor } from 'ts/color'; import menu from 'ts/menu'; import createElement from 'ts/createElement'; let Stack = { init: () => { /** * Bind menu event */ menu(); const articleContent = document.querySelector('.article-content') as HTMLElement; if (articleContent) { new StackGallery(articleContent); } /** * Add color to tags */ document.querySelectorAll('.color-tag').forEach(async (tag: HTMLLinkElement) => { const imageURL = tag.getAttribute('data-image'), key = tag.getAttribute('data-key'), hash = tag.getAttribute('data-hash'); const colors = await getColor(key, hash, imageURL); tag.style.color = colors.Vibrant.bodyTextColor; tag.style.background = colors.Vibrant.hex; }) /** * Add linear gradient background to tile style article */ const articleTile = document.querySelector('.article-list--tile'); if (articleTile) { let observer = new IntersectionObserver(async (entries, observer) => { entries.forEach(entry => { if (!entry.isIntersecting) return; observer.unobserve(entry.target); const articles = entry.target.querySelectorAll('article.has-image'); articles.forEach(async articles => { const image = articles.querySelector('img'), imageURL = image.src, key = image.getAttribute('data-key'), hash = image.getAttribute('data-hash'), articleDetails: HTMLDivElement = articles.querySelector('.article-details'); const colors = await getColor(key, hash, imageURL); articleDetails.style.background = ` linear-gradient(0deg, rgba(${colors.DarkMuted.rgb[0]}, ${colors.DarkMuted.rgb[1]}, ${colors.DarkMuted.rgb[2]}, 0.5) 0%, rgba(${colors.Vibrant.rgb[0]}, ${colors.Vibrant.rgb[1]}, ${colors.Vibrant.rgb[2]}, 0.75) 100%)`; }) }) }); observer.observe(articleTile) } } } window.addEventListener('load', () => { setTimeout(function () { Stack.init(); }, 0); }) declare global { interface Window { createElement: any; Stack: any } } window.Stack = Stack; window.createElement = createElement;