document.addEventListener("DOMContentLoaded", function(event) { const themes = require('./themes.js') const themeList = $('#theme-list'); const menuResponsive = require('./menu-responsive') const debounceResize = menuResponsive({ menuList: themeList, }) const Cookies = require('js-cookie') const themeCookieName = 'gitlist-bootstrap-theme' function getThemeCookie() { const theme = Cookies.get(themeCookieName) return theme || 'bootstrap-cosmo'; } gitlist.getThemeCookie = getThemeCookie; function setThemeCookie(theme) { Cookies.set(themeCookieName, theme, { expires: 3650, path: '/' }); } const currentCookie = getThemeCookie('gitlist-bootstrap-theme'); for(let key in themes) { const menu = '
  • ' + key.substring(10) + '
  • '; themeList.append(menu); } gitlist.setTheme() const themesheet = $('#bootstrap-theme'); $('.theme-link').click(function(event){ if (window.gitlist.lastloadSpan !== undefined && window.gitlist.lastloadSpan > 1000) { $('body').prepend(`
    For a big page, it takes some time to switch the theme...
    The page rendering took about ${Math.ceil(window.gitlist.lastloadSpan / 1000)} seconds ...
    It means the theme will take about the same time ...
    `) } debounceResize(); themeList.find('.active').removeClass('active'); const $this = $(this); $this.parent().addClass('active'); const themeurl = themes[$this.attr('data-theme')]; setThemeCookie($this.attr('data-theme')); const href = (gitlist.basepath === '/' ? '' : gitlist.basepath) + themeurl; themesheet.attr('href', href); gitlist.setTheme() event.preventDefault(); }); });