document.addEventListener('DOMContentLoaded', () => {
    const encryption = str => window.btoa(unescape(encodeURIComponent(str)));
    const decrypt = str => decodeURIComponent(escape(window.atob(str)));
    /* 当前页的CID */
    const cid = $('.joe_detail').attr('data-cid');
    /* 获取本篇文章百度收录情况 */
    {
        $.ajax({
            url: Joe.BASE_API,
            type: 'POST',
            dataType: 'json',
            data: { routeType: 'baidu_record', site: window.location.href },
            success(res) {
                if (res.data && res.data === '已收录') {
                    $('#Joe_Baidu_Record').css('color', '#67C23A');
                    $('#Joe_Baidu_Record').html('已收录');
                } else {
                    /* 如果填写了Token,则自动推送给百度 */
                    if (Joe.BAIDU_PUSH) {
                        $('#Joe_Baidu_Record').html('未收录,推送中...');
                        const _timer = setTimeout(function () {
                            $.ajax({
                                url: Joe.BASE_API,
                                type: 'POST',
                                dataType: 'json',
                                data: {
                                    routeType: 'baidu_push',
                                    domain: encodeURI(window.location.hostname),
                                    url: encodeURI(window.location.href)
                                },
                                success(res) {
                                    if (res.error) {
                                        $('#Joe_Baidu_Record').html('推送失败,请检查!');
                                    } else {
                                        $('#Joe_Baidu_Record').html('推送成功!');
                                    }
                                }
                            });
                            clearTimeout(_timer);
                        }, 1000);
                    } else {
                        const url = `https://ziyuan.baidu.com/linksubmit/url?sitename=${encodeURI(window.location.href)}`;
                        $('#Joe_Baidu_Record').html(`未收录,提交收录`);
                    }
                }
            }
        });
    }
    /* 激活代码高亮 */
    {
        Prism.highlightAll();
        $("pre[class*='language-']").each(function (index, item) {
            let text = $(item).find("code[class*='language-']").text();
            let span = $(``);
            new ClipboardJS(span[0], { text: () => text }).on('success', () => Qmsg.success('复制成功!'));
            $(item).append(span);
        });
    }
    /* 激活图片预览功能 */
    {
        $('.joe_detail__article img:not(img.owo_image)').each(function () {
            $(this).wrap($(``));
        });
    }
    /* 设置文章内的链接为新窗口打开 */
    {
        $('.joe_detail__article a:not(.joe_detail__article-anote)').each(function () {
            $(this).attr({ target: '_blank', rel: 'noopener noreferrer nofollow' });
        });
    }
    /* 激活浏览功能 */
    {
        let viewsArr = localStorage.getItem(encryption('views')) ? JSON.parse(decrypt(localStorage.getItem(encryption('views')))) : [];
        const flag = viewsArr.includes(cid);
        if (!flag) {
            $.ajax({
                url: Joe.BASE_API,
                type: 'POST',
                dataType: 'json',
                data: { routeType: 'handle_views', cid },
                success(res) {
                    if (res.code !== 1) return;
                    $('#Joe_Article_Views').html(`${res.data.views} 阅读`);
                    viewsArr.push(cid);
                    const name = encryption('views');
                    const val = encryption(JSON.stringify(viewsArr));
                    localStorage.setItem(name, val);
                }
            });
        }
    }
    /* 激活文章点赞功能 */
    {
        let agreeArr = localStorage.getItem(encryption('agree')) ? JSON.parse(decrypt(localStorage.getItem(encryption('agree')))) : [];
        if (agreeArr.includes(cid)) $('.joe_detail__agree .icon-1').addClass('active');
        else $('.joe_detail__agree .icon-2').addClass('active');
        let _loading = false;
        $('.joe_detail__agree .icon').on('click', function () {
            if (_loading) return;
            _loading = true;
            agreeArr = localStorage.getItem(encryption('agree')) ? JSON.parse(decrypt(localStorage.getItem(encryption('agree')))) : [];
            let flag = agreeArr.includes(cid);
            $.ajax({
                url: Joe.BASE_API,
                type: 'POST',
                dataType: 'json',
                data: { routeType: 'handle_agree', cid, type: flag ? 'disagree' : 'agree' },
                success(res) {
                    if (res.code !== 1) return;
                    $('.joe_detail__agree .text').html(res.data.agree);
                    if (flag) {
                        const index = agreeArr.findIndex(_ => _ === cid);
                        agreeArr.splice(index, 1);
                        $('.joe_detail__agree .icon-1').removeClass('active');
                        $('.joe_detail__agree .icon-2').addClass('active');
                        $('.joe_detail__agree .icon').removeClass('active');
                    } else {
                        agreeArr.push(cid);
                        $('.joe_detail__agree .icon-2').removeClass('active');
                        $('.joe_detail__agree .icon-1').addClass('active');
                        $('.joe_detail__agree .icon').addClass('active');
                    }
                    const name = encryption('agree');
                    const val = encryption(JSON.stringify(agreeArr));
                    localStorage.setItem(name, val);
                },
                complete() {
                    _loading = false;
                }
            });
        });
    }
    /* 格式化分页的hash值 */
    {
        $('.joe_comment .joe_pagination a').each((index, item) => {
            const href = $(item).attr('href');
            if (href && href.includes('#')) {
                $(item).attr('href', href.replace('#comments', '?scroll=joe_comment'));
            }
        });
    }
    /* 密码保护文章,输入密码访问 */
    {
        let isSubmit = false;
        $('.joe_detail__article-protected').on('submit', function (e) {
            e.preventDefault();
            const url = $(this).attr('action') + '&time=' + +new Date();
            const protectPassword = $(this).find('input[type="password"]').val();
            if (protectPassword.trim() === '') return Qmsg.info('请输入访问密码!');
            if (isSubmit) return;
            isSubmit = true;
            $.ajax({
                url,
                type: 'POST',
                data: {
                    cid,
                    protectPassword
                },
                dataType: 'text',
                success(res) {
                    let arr = [],
                        str = '';
                    arr = $(res).contents();
                    Array.from(arr).forEach(_ => {
                        if (_.parentNode.className === 'container') str = _;
                    });
                    if (!/Joe/.test(res)) {
                        Qmsg.warning(str.textContent.trim() || '');
                        isSubmit = false;
                        $('.joe_comment__respond-form .foot .submit button').html('发表评论');
                    } else {
                        location.reload();
                    }
                }
            });
        });
    }
    /* 激活文章视频模块 */
    {
        if ($('.joe_detail__article-video').length > 0) {
            const player = $('.joe_detail__article-video .play iframe').attr('data-player');
            $('.joe_detail__article-video .episodes .item').on('click', function () {
                $(this).addClass('active').siblings().removeClass('active');
                const url = $(this).attr('data-src');
                $('.joe_detail__article-video .play iframe').attr({ src: player + url });
            });
            $('.joe_detail__article-video .episodes .item').first().click();
        }
    }
});
/* 写在load事件里,为了解决图片未加载完成,滚动距离获取会不准确的问题 */
window.addEventListener('load', function () {
    /* 判断地址栏是否有锚点链接,有则跳转到对应位置 */
    {
        const scroll = new URLSearchParams(location.search).get('scroll');
        if (scroll) {
            const height = $('.joe_header').height();
            let elementEL = null;
            if ($('#' + scroll).length > 0) {
                elementEL = $('#' + scroll);
            } else {
                elementEL = $('.' + scroll);
            }
            if (elementEL && elementEL.length > 0) {
                const top = elementEL.offset().top - height - 15;
                window.scrollTo({ top, behavior: 'smooth' });
            }
        }
    }
});