/* eslint-disable no-unused-vars */ var btf = { debounce: function (func, wait, immediate) { let timeout return function () { const context = this const args = arguments const later = function () { timeout = null if (!immediate) func.apply(context, args) } const callNow = immediate && !timeout clearTimeout(timeout) timeout = setTimeout(later, wait) if (callNow) func.apply(context, args) } }, throttle: function (func, wait, options) { let timeout, context, args let previous = 0 if (!options) options = {} const later = function () { previous = options.leading === false ? 0 : new Date().getTime() timeout = null func.apply(context, args) if (!timeout) context = args = null } const throttled = function () { const now = new Date().getTime() if (!previous && options.leading === false) previous = now const remaining = wait - (now - previous) context = this args = arguments if (remaining <= 0 || remaining > wait) { if (timeout) { clearTimeout(timeout) timeout = null } previous = now func.apply(context, args) if (!timeout) context = args = null } else if (!timeout && options.trailing !== false) { timeout = setTimeout(later, remaining) } } return throttled }, sidebarPaddingR: () => { const innerWidth = window.innerWidth const clientWidth = document.body.clientWidth const paddingRight = innerWidth - clientWidth if (innerWidth !== clientWidth) { $('body').css('padding-right', paddingRight) } }, scrollToDest: name => { const scrollOffset = $(name).offset().top let offset if ($(window).scrollTop() > scrollOffset) { offset = 65 } else { offset = 0 } $('body,html').animate({ scrollTop: scrollOffset - offset }) }, snackbarShow: (text, showAction, duration) => { const sa = (typeof showAction !== 'undefined') ? showAction : false const dur = (typeof duration !== 'undefined') ? duration : 2000 const position = GLOBAL_CONFIG.Snackbar.position const bg = document.documentElement.getAttribute('data-theme') === 'light' ? GLOBAL_CONFIG.Snackbar.bgLight : GLOBAL_CONFIG.Snackbar.bgDark Snackbar.show({ text: text, backgroundColor: bg, showAction: sa, duration: dur, pos: position }) }, initJustifiedGallery: function (selector) { selector.each(function (i, o) { if ($(this).is(':visible')) { $(this).justifiedGallery({ rowHeight: 220, margins: 4 }) } }) }, diffDate: (d, more = false) => { const dateNow = new Date() const datePost = new Date(d) const dateDiff = dateNow.getTime() - datePost.getTime() const minute = 1000 * 60 const hour = minute * 60 const day = hour * 24 const month = day * 30 let result if (more) { const monthCount = dateDiff / month const dayCount = dateDiff / day const hourCount = dateDiff / hour const minuteCount = dateDiff / minute if (monthCount > 12) { result = datePost.toLocaleDateString().replace(/\//g, '-') } else if (monthCount >= 1) { result = parseInt(monthCount) + ' ' + GLOBAL_CONFIG.date_suffix.month } else if (dayCount >= 1) { result = parseInt(dayCount) + ' ' + GLOBAL_CONFIG.date_suffix.day } else if (hourCount >= 1) { result = parseInt(hourCount) + ' ' + GLOBAL_CONFIG.date_suffix.hour } else if (minuteCount >= 1) { result = parseInt(minuteCount) + ' ' + GLOBAL_CONFIG.date_suffix.min } else { result = GLOBAL_CONFIG.date_suffix.just } } else { result = parseInt(dateDiff / day) } return result }, loadComment: (dom, callback) => { if ('IntersectionObserver' in window) { const observerItem = new IntersectionObserver((entries) => { if (entries[0].isIntersecting) { callback() observerItem.disconnect() } }, { threshold: [0] }) observerItem.observe(dom) } else { callback() } } }