/*! * Argon 主题核心 JavaScript */ // ========== 兼容性修复 ========== // 确保 Prism 和 autoloader 存在 if (typeof window.Prism === 'undefined') { window.Prism = { highlightAll: function() {}, highlightElement: function() {}, plugins: {} }; } if (typeof window.Prism.plugins === 'undefined') { window.Prism.plugins = {}; } if (typeof window.Prism.plugins.autoloader === 'undefined') { window.Prism.plugins.autoloader = { languages_path: '', use_minified: true }; } // 确保 Zoomify 存在 if (typeof window.Zoomify === 'undefined') { window.Zoomify = function() {}; window.Zoomify.DEFAULTS = {}; } // 确保 jQuery 插件存在 if (typeof jQuery !== 'undefined') { (function($) { // 确保 zoomify 插件存在 if (typeof $.fn.zoomify === 'undefined') { $.fn.zoomify = function() { return this; }; } // 确保 fancybox 存在 if (typeof $.fancybox === 'undefined') { $.fancybox = { defaults: { transitionEffect: 'slide', buttons: [], lang: 'zh_CN', i18n: {} }, open: function() {}, close: function() {} }; } if (typeof $.fancybox.defaults === 'undefined') { $.fancybox.defaults = { transitionEffect: 'slide', buttons: [], lang: 'zh_CN', i18n: {} }; } // 确保 pjax 存在 if (typeof $.pjax === 'undefined') { $.pjax = function() {}; $.pjax.defaults = { timeout: 10000, container: [], fragment: [] }; } if (typeof $.pjax.defaults === 'undefined') { $.pjax.defaults = { timeout: 10000, container: [], fragment: [] }; } })(jQuery); } // ========== 原有代码 ========== if (typeof(argonConfig) == "undefined"){ var argonConfig = {}; } if (typeof(argonConfig.wp_path) == "undefined"){ argonConfig.wp_path = "/"; } /*Cookies 操作*/ function setCookie(cname, cvalue, exdays) { let d = new Date(); d.setTime(d.getTime() + (exdays * 24 * 60 * 60 * 1000)); let expires = "expires=" + d.toUTCString(); document.cookie = cname + "=" + cvalue + ";" + expires + ";path=/"; } function getCookie(cname) { let name = cname + "="; let decodedCookie = decodeURIComponent(document.cookie); let ca = decodedCookie.split(';'); for (let i = 0; i < ca.length; i++) { let c = ca[i]; while (c.charAt(0) == ' ') { c = c.substring(1); } if (c.indexOf(name) == 0) { return c.substring(name.length, c.length); } } return ""; } /*多语言支持*/ var translation = {}; translation['en_US'] = { "确定": "OK", "清除": "Clear", "恢复博客默认": "Set To Default", "评论内容不能为空": "Comment content cannot be empty", "昵称不能为空": "Name cannot be empty", "邮箱或 QQ 号格式错误": "Incorrect email or QQ format", "邮箱格式错误": "Incorrect email format", "网站格式错误 (不是 http(s):// 开头)": "Website URL format error", "验证码未输入": "CAPTCHA cannot be empty", "验证码格式错误": "Incorrect CAPTCHA format", "请完成验证码验证": "Please complete CAPTCHA verification", "评论格式错误": "Comment format error", "发送中": "Sending", "正在发送": "Sending", "评论正在发送中...": "Comment is sending...", "发送": "Send", "评论发送失败": "Comment failed", "发送成功": "Success", "您的评论已发送": "Your comment has been sent", "评论": "Comments", "未知原因": "Unknown Error", "编辑中": "Editing", "正在编辑": "Editing", "评论正在编辑中...": "Comment is being edited...", "编辑": "Edit", "评论编辑失败": "Comment editing failed", "已编辑": "Edited", "编辑成功": "Success", "您的评论已编辑": "Your comment has been edited", "评论 #": "Comment #", "的编辑记录": "- Edit History", "加载失败": "Failed to load", "展开": "Show", "没有更多了": "No more comments", "找不到该 Repo": "Can't find the repository", "获取 Repo 信息失败": "Failed to get repository information", "点赞失败": "Vote failed", "Hitokoto 获取失败": "Failed to get Hitokoto", "复制成功": "Copied", "代码已复制到剪贴板": "Code has been copied to the clipboard", "复制失败": "Failed", "请手动复制代码": "Please copy the code manually", "刚刚": "Now", "分钟前": "minutes ago", "小时前": "hours ago", "昨天": "Yesterday", "前天": "The day before yesterday", "天前": "days ago", "隐藏行号": "Hide Line Numbers", "显示行号": "Show Line Numbers", "开启折行": "Enable Break Line", "关闭折行": "Disable Break Line", "复制": "Copy", "全屏": "Fullscreen", "退出全屏": "Exit Fullscreen", "置顶评论": "Pin Comment", "取消置顶评论": "Unpin Comment", "是否要取消置顶评论 #": "Do you want to unpin the comment #", "是否要置顶评论 #": "Do you want to pin the comment #", "确认": "Confirm", "取消": "取消", "置顶": "Pin", "取消置顶": "Unpin", "置顶成功": "Pinned", "取消置顶成功": "Unpinned", "该评论已置顶": "The comment has been pinned", "该评论已取消置顶": "The comment has been unpinned", "置顶失败": "Failed to pin", "取消置顶失败": "Failed to unpin", }; translation['ru_RU'] = { "确定": "ОК", "清除": "Очистить", "恢复博客默认": "Восстановить по умолчанию", "评论内容不能为空": "Содержимое комментария не может быть пустым", "昵称不能为空": "Имя не может быть пустым", "邮箱或 QQ 号格式错误": "Неверный формат электронной почты или QQ", "邮箱格式错误": "Неправильный формат электронной почты", "网站格式错误 (不是 http(s):// 开头)": "Сайт ошибка формата URL-адреса ", "验证码未输入": "Вы не решили капчу", "验证码格式错误": "Ошибка проверки капчи", "评论格式错误": "Неправильный формат комментария", "发送中": "Отправка", "正在发送": "Отправка", "评论正在发送中...": "Комментарий отправляется...", "发送": "Отправить", "评论发送失败": "Не удалось отправить комментарий", "发送成功": "Комментарий отправлен", "您的评论已发送": "Ваш комментарий был отправлен", "评论": "Комментарии", "未知原因": "Неизвестная ошибка", "编辑中": "Редактируется", "正在编辑": "Редактируется", "评论正在编辑中...": "Комментарий редактируется", "编辑": "Редактировать", "评论编辑失败": "Не удалось отредактировать комментарий", "已编辑": "Изменено", "编辑成功": "Успешно", "您的评论已编辑": "Ваш комментарий был изменен", "评论 #": "Комментарий #", "的编辑记录": "- История изменений", "加载失败": "Ошибка загрузки", "展开": "Показать", "没有更多了": "Комментариев больше нет", "找不到该 Repo": "Невозможно найти репозиторий", "获取 Repo 信息失败": "Неудалось получить информацию репозитория", "点赞失败": "Ошибка голосования", "Hitokoto 获取失败": "Проблемы с вызовом Hitokoto", "复制成功": "Скопировано", "代码已复制到剪贴板": "Код скопирован в буфер обмена", "复制失败": "Неудалось", "请手动复制代码": "Скопируйте код вручную", "刚刚": "Сейчас", "分钟前": "минут назад", "小时前": "часов назад", "昨天": "Вчера", "前天": "Позавчера", "天前": "дней назад", "隐藏行号": "Скрыть номера строк", "显示行号": "Показать номера строк", "开启折行": "Включить перенос строк", "关闭折行": "Выключить перенос строк", "复制": "Скопировать", "全屏": "Полноэкранный режим", "退出全屏": "Выход из полноэкранного режима", }; translation['zh_TW'] = { "确定": "確定", "清除": "清除", "恢复博客默认": "恢復博客默認", "评论内容不能为空": "評論內容不能為空", "昵称不能为空": "昵稱不能為空", "邮箱或 QQ 号格式错误": "郵箱或 QQ 號格式錯誤", "邮箱格式错误": "郵箱格式錯誤", "网站格式错误 (不是 http(s):// 开头)": "網站格式錯誤 (不是 http(s):// 開頭)", "验证码未输入": "驗證碼未輸入", "验证码格式错误": "驗證碼格式錯誤", "评论格式错误": "評論格式錯誤", "发送中": "發送中", "正在发送": "正在發送", "评论正在发送中...": "評論正在發送中...", "发送": "發送", "评论发送失败": "評論發送失敗", "发送成功": "發送成功", "您的评论已发送": "您的評論已發送", "评论": "評論", "未知原因": "未知原因", "编辑中": "編輯中", "正在编辑": "正在編輯", "评论正在编辑中...": "評論正在編輯中...", "编辑": "編輯", "评论编辑失败": "評論編輯失敗", "已编辑": "已編輯", "编辑成功": "編輯成功", "您的评论已编辑": "您的評論已編輯", "评论 #": "評論 #", "的编辑记录": "的編輯記錄", "加载失败": "加載失敗", "展开": "展開", "没有更多了": "沒有更多了", "找不到该 Repo": "找不到該 Repo", "获取 Repo 信息失败": "獲取 Repo 信息失敗", "点赞失败": "點贊失敗", "Hitokoto 获取失败": "Hitokoto 獲取失敗", "复制成功": "復制成功", "代码已复制到剪贴板": "代碼已復制到剪貼板", "复制失败": "復制失敗", "请手动复制代码": "請手動復制代碼", "刚刚": "剛剛", "分钟前": "分鐘前", "小时前": "小時前", "昨天": "昨天", "前天": "前天", "天前": "天前", "隐藏行号": "隱藏行號", "显示行号": "顯示行號", "开启折行": "開啟折行", "关闭折行": "關閉折行", "复制": "復制", "全屏": "全屏", "退出全屏": "退出全屏" }; function __(text){ let lang = argonConfig.language; if (typeof(translation[lang]) == "undefined"){ return text; } if (typeof(translation[lang][text]) == "undefined"){ return text; } return translation[lang][text]; } /*根据滚动高度改变顶栏透明度*/ !function(){ let toolbar = document.getElementById("navbar-main"); let $bannerContainer = $("#banner_container"); let $content = $("#content"); let startTransitionHeight; let endTransitionHeight; let maxOpacity = 0.85; startTransitionHeight = $bannerContainer.offset().top - 75; endTransitionHeight = $content.offset().top - 75; $(window).resize(function(){ startTransitionHeight = $bannerContainer.offset().top - 75; endTransitionHeight = $content.offset().top - 75; }); function changeToolbarTransparency(){ let scrollTop = document.documentElement.scrollTop || document.body.scrollTop; if (scrollTop < startTransitionHeight){ toolbar.style.setProperty('background-color', 'rgba(var(--toolbar-color), 0)', 'important'); toolbar.style.setProperty('box-shadow', 'none'); if (argonConfig.toolbar_blur){ toolbar.style.setProperty('backdrop-filter', 'blur(0px)'); } toolbar.classList.add("navbar-ontop"); return; } if (scrollTop > endTransitionHeight){ toolbar.style.setProperty('background-color', 'rgba(var(--toolbar-color), ' + maxOpacity + ')', 'important'); toolbar.style.setProperty('box-shadow', ''); if (argonConfig.toolbar_blur){ toolbar.style.setProperty('backdrop-filter', 'blur(16px)'); } toolbar.classList.remove("navbar-ontop"); return; } let transparency = (scrollTop - startTransitionHeight) / (endTransitionHeight - startTransitionHeight) * maxOpacity; toolbar.style.setProperty('background-color', 'rgba(var(--toolbar-color), ' + transparency, 'important'); toolbar.style.setProperty('box-shadow', ''); if (argonConfig.toolbar_blur){ if ((scrollTop - startTransitionHeight) / (endTransitionHeight - startTransitionHeight) > 0.3){ toolbar.style.setProperty('backdrop-filter', 'blur(16px)'); }else{ toolbar.style.setProperty('backdrop-filter', 'blur(0px)'); } } toolbar.classList.remove("navbar-ontop"); } function changeToolbarOnTopClass(){ let scrollTop = document.documentElement.scrollTop || document.body.scrollTop; if (scrollTop < 30){ toolbar.classList.add("navbar-no-blur"); }else{ toolbar.classList.remove("navbar-no-blur"); } } if ($("html").hasClass("no-banner")) { changeToolbarOnTopClass(); document.addEventListener("scroll", changeToolbarOnTopClass, {passive: true}); return; } if (argonConfig.headroom == "absolute") { toolbar.classList.add("navbar-ontop"); return; } if ($("html").hasClass("toolbar-blur")) { argonConfig.toolbar_blur = true; maxOpacity = 0.65; }else{ argonConfig.toolbar_blur = false; } changeToolbarTransparency(); document.addEventListener("scroll", changeToolbarTransparency, {passive: true}); }(); /*搜索*/ function searchPosts(word){ if ($(".search-result").length > 0){ let url = new URL(window.location.href); url.searchParams.set("s", word); $.pjax({ url: url.href }); }else{ $.pjax({ url: argonConfig.wp_path + "?s=" + encodeURI(word) }); } } /*顶栏搜索*/ $(document).on("click" , "#navbar_search_input_container" , function(){ $(this).addClass("open"); $("#navbar_search_input").focus(); }); $(document).on("blur" , "#navbar_search_input_container" , function(){ // 如果有文字则保持has-text类 if ($("#navbar_search_input").val().trim() !== "") { $(this).addClass("has-text"); } else { $(this).removeClass("has-text"); } $(this).removeClass("open"); }); // 监听输入变化来切换has-text类 $(document).on("input" , "#navbar_search_input" , function(){ var container = $("#navbar_search_input_container"); if ($(this).val().trim() !== "") { container.addClass("has-text"); } else { container.removeClass("has-text"); } }); $(document).on("keydown" , "#navbar_search_input_container #navbar_search_input" , function(e){ if (e.keyCode != 13){ return; } let word = $(this).val(); if (word == ""){ $("#navbar_search_input_container").blur(); return; } let scrolltop = $(document).scrollTop(); searchPosts(word); }); /*顶栏搜索 (Mobile)*/ $(document).on("keydown" , "#navbar_search_input_mobile" , function(e){ if (e.keyCode != 13){ return; } let word = $(this).val(); $("#navbar_global .collapse-close button").click(); if (word == ""){ return; } let scrolltop = $(document).scrollTop(); searchPosts(word); }); /*侧栏搜索*/ $(document).on("click" , "#leftbar_search_container" , function(){ $(".leftbar-search-button").addClass("open"); $("#leftbar_search_input").removeAttr("readonly").focus(); $("#leftbar_search_input").focus(); $("#leftbar_search_input").select(); return false; }); $(document).on("blur" , "#leftbar_search_container" , function(){ $(".leftbar-search-button").removeClass("open"); $("#leftbar_search_input").attr("readonly", "readonly"); }); $(document).on("keydown" , "#leftbar_search_input" , function(e){ if (e.keyCode != 13){ return; } let word = $(this).val(); if (word == ""){ $("#leftbar_search_container").blur(); return; } $("html").removeClass("leftbar-opened"); searchPosts(word); }); /*搜索过滤器*/ $(document).on("change" , ".search-filter" , function(e){ if (pjaxLoading){ $(this).prop("checked", !$(this).prop("checked")); e.preventDefault(); return; } pjaxLoading = true; let postTypes = []; $(".search-filter:checked").each(function(){ postTypes.push($(this).attr("name")); }); if (postTypes.length == 0){ postTypes = ["none"]; } let url = new URL(document.location.href); url.searchParams.set("post_type", postTypes.join(",")); url.pathname = url.pathname.replace(/\/page\/\d+$/, ''); $.pjax({ url: url.href }); }); /*左侧栏随页面滚动浮动*/ !function(){ if ($("#leftbar").length == 0){ let contentOffsetTop = $('#content').offset().top; function changeLeftbarStickyStatusWithoutSidebar(){ let scrollTop = document.documentElement.scrollTop || document.body.scrollTop; if( contentOffsetTop - 10 - scrollTop <= 20 ){ document.body.classList.add('leftbar-can-headroom'); }else{ document.body.classList.remove('leftbar-can-headroom'); } } changeLeftbarStickyStatusWithoutSidebar(); document.addEventListener("scroll", changeLeftbarStickyStatusWithoutSidebar, {passive: true}); $(window).resize(function(){ contentOffsetTop = $('#content').offset().top; changeLeftbarStickyStatusWithoutSidebar(); }); return; } let $leftbarPart1 = $('#leftbar_part1'); let $leftbarPart2 = $('#leftbar_part2'); let leftbarPart1 = document.getElementById('leftbar_part1'); let leftbarPart2 = document.getElementById('leftbar_part2'); let leftbarPart3 = document.getElementById('leftbar_part3'); let part1OffsetTop = $('#leftbar_part1').offset().top; let part1OuterHeight = $('#leftbar_part1').outerHeight(); function changeLeftbarStickyStatus(){ let scrollTop = document.documentElement.scrollTop || document.body.scrollTop; if( part1OffsetTop + part1OuterHeight + 10 - scrollTop <= (argonConfig.headroom != "absolute" ? 90 : 18) ){ //滚动条在页面中间浮动状态 leftbarPart2.classList.add('sticky'); if (leftbarPart3) { leftbarPart3.classList.add('sticky'); // 计算可用空间并分配给 part2 和 part3 let viewportHeight = window.innerHeight; let topOffset = argonConfig.headroom !== 'absolute' ? 90 : 20; let availableHeight = viewportHeight - topOffset - 20; // 20px 底部边距 // 获取 part3 的自然高度(不受限制时的高度) leftbarPart3.style.maxHeight = 'none'; let part3NaturalHeight = leftbarPart3.scrollHeight; leftbarPart3.style.maxHeight = ''; // 最小高度限制 let minPart2Height = 150; let minPart3Height = 100; // 计算分配 let part2Height, part3MaxHeight; if (part3NaturalHeight + minPart2Height <= availableHeight) { // part3 可以完全显示 part3MaxHeight = part3NaturalHeight; part2Height = availableHeight - part3NaturalHeight - 10; } else { // 需要按比例分配,part2 占 60%,part3 占 40% part2Height = Math.max(minPart2Height, availableHeight * 0.6); part3MaxHeight = Math.max(minPart3Height, availableHeight - part2Height - 10); } document.documentElement.style.setProperty('--leftbar-part2-height', leftbarPart2.offsetHeight + 10 + 'px'); document.documentElement.style.setProperty('--leftbar-part3-height', part3MaxHeight + 'px'); document.documentElement.style.setProperty('--leftbar-part3-max-height', part3MaxHeight + 'px'); } }else{ //滚动条在顶部 不浮动状态 leftbarPart2.classList.remove('sticky'); if (leftbarPart3) leftbarPart3.classList.remove('sticky'); } if( part1OffsetTop + part1OuterHeight + 10 - scrollTop <= 20 ){//侧栏下部分是否可以随 Headroom 一起向上移动 document.body.classList.add('leftbar-can-headroom'); }else{ document.body.classList.remove('leftbar-can-headroom'); } } changeLeftbarStickyStatus(); document.addEventListener("scroll", changeLeftbarStickyStatus, {passive: true}); $(window).resize(function(){ part1OffsetTop = $leftbarPart1.offset().top; part1OuterHeight = $leftbarPart1.outerHeight(); changeLeftbarStickyStatus(); }); new MutationObserver(function(){ part1OffsetTop = $leftbarPart1.offset().top; part1OuterHeight = $leftbarPart1.outerHeight(); changeLeftbarStickyStatus(); }).observe(leftbarPart1, {attributes: true, childList: true, subtree: true}); }(); /*Headroom*/ if (argonConfig.headroom == "true"){ var headroom = new Headroom(document.querySelector("body"),{ "tolerance" : { up : 0, down : 0 }, "offset": 0, "classes": { "initial": "with-headroom", "pinned": "headroom---pinned", "unpinned": "headroom---unpinned", "top": "headroom---top", "notTop": "headroom---not-top", "bottom": "headroom---bottom", "notBottom": "headroom---not-bottom", "frozen": "headroom---frozen" } }).init(); } /*瀑布流布局*/ function waterflowInit() { if (argonConfig.waterflow_columns == "1") { return; } $("#main.article-list img").each(function(index, ele){ ele.onload = function(){ waterflowInit(); } }); let columns; if (argonConfig.waterflow_columns == "2and3") { if ($("#main").outerWidth() > 1000) { columns = 3; } else { columns = 2; } }else{ columns = parseInt(argonConfig.waterflow_columns); } if ($("#main").outerWidth() < 650 && columns == 2) { columns = 1; }else if ($("#main").outerWidth() < 800 && columns == 3) { columns = 1; } let heights = [0, 0, 0]; function getMinHeightPosition(){ let res = 0, minn = 2147483647; for (var i = 0; i < columns; i++) { if (heights[i] < minn) { minn = heights[i]; res = i; } } return res; } function getMaxHeight(){ let res = 0; for (let i in heights) { res = Math.max(res, heights[i]); } return res; } $("#primary").css("transition", "none") .addClass("waterflow"); let $container = $("#main.article-list"); if (!$container.length){ return; } let $items = $container.find("article.post:not(.no-results), .shuoshuo-preview-container"); columns = Math.max(Math.min(columns, $items.length), 1); if (columns == 1) { $container.removeClass("waterflow"); $items.css("transition", "").css("position", "").css("width", "").css("top", "").css("left", "").css("margin", ""); $(".waterflow-placeholder").remove(); }else{ $container.addClass("waterflow"); $items.each(function(index, item) { let $item = $(item); $item.css("transition", "none") .css("position", "absolute") .css("width", "calc(" + (100 / columns) + "% - " + (10 * (columns - 1) / columns) + "px)").css("margin", 0); let itemHeight = $item.outerHeight() + 10; let pos = getMinHeightPosition(); $item.css("top", heights[getMinHeightPosition()] + "px") .css("left", (pos * $item.outerWidth() + 10 * pos) + "px"); heights[pos] += itemHeight; }); } if ($(".waterflow-placeholder").length) { $(".waterflow-placeholder").css("height", getMaxHeight() + "px"); }else{ $container.prepend("
"); } } waterflowInit(); if (argonConfig.waterflow_columns != "1") { $(window).resize(function(){ waterflowInit(); }); new MutationObserver(function(mutations, observer){ waterflowInit(); }).observe(document.querySelector("#primary"), { 'childList': true }); } /*移动端文章列表布局切换*/ !function(){ var mobileLayout = argonConfig.article_list_layout_mobile || "1"; var isMobile = window.innerWidth <= 900; function applyMobileLayout() { var nowMobile = window.innerWidth <= 900; if (nowMobile) { $("html").addClass("mobile-layout-" + mobileLayout); } else { $("html").removeClass("mobile-layout-1 mobile-layout-2 mobile-layout-3"); } } applyMobileLayout(); $(window).resize(function(){ applyMobileLayout(); }); }(); /*浮动按钮栏相关 (回顶等)*/ !function(){ // 确保 DOM 和 jQuery 已加载 if (typeof jQuery === 'undefined') { console.warn('jQuery not loaded, retrying...'); setTimeout(arguments.callee, 50); return; } let $fabtns = $('#float_action_buttons'); if ($fabtns.length === 0) { console.warn('Float action buttons not found, retrying...'); setTimeout(arguments.callee, 50); return; } let $backToTopBtn = $('#fabtn_back_to_top'); let $toggleSidesBtn = $('#fabtn_toggle_sides'); let $toggleDarkmode = $('#fabtn_toggle_darkmode'); let $toggleAmoledMode = $('#blog_setting_toggle_darkmode_and_amoledarkmode'); let $toggleBlogSettings = $('#fabtn_toggle_blog_settings_popup'); let $goToComment = $('#fabtn_go_to_comment'); let $readingProgressBtn = $('#fabtn_reading_progress'); let $readingProgressBar = $('#fabtn_reading_progress_bar'); let $readingProgressDetails = $('#fabtn_reading_progress_details'); $backToTopBtn.on("click" , function(){ $("body,html").stop().animate({ scrollTop: 0 }, 600); }); $toggleDarkmode.on("click" , function(){ toggleDarkmode(); }); $toggleAmoledMode.on("click" , function(){ toggleAmoledDarkMode(); }) if ($("#post_comment").length > 0){ $("#fabtn_go_to_comment").removeClass("fabtn-hidden"); }else{ $("#fabtn_go_to_comment").addClass("fabtn-hidden"); } $goToComment.on("click" , function(){ var commentsArea = $("#comments"); var postCommentArea = $("#post_comment"); var wasCollapsed = commentsArea.hasClass("comments-collapsed"); var toggleBtn = $("#comments_toggle"); if (wasCollapsed && toggleBtn.length > 0) { // 折叠状态:先滚动到评论切换按钮位置,再展开 $("body,html").stop().animate({ scrollTop: toggleBtn.offset().top - 80 }, 600); toggleBtn.find("i").removeClass("fa-comments").addClass("fa-comment-o"); toggleBtn.find(".btn-inner--text").text("折叠评论"); toggleBtn.addClass("expanded"); commentsArea.removeClass("comments-collapsed"); setTimeout(function() { postCommentArea.removeClass("comments-collapsed"); $("#post_comment_content").focus(); }, 150); } else { // 已展开或无切换按钮:直接滚动到评论框 $("body,html").stop().animate({ scrollTop: postCommentArea.offset().top - 80 }, 600); $("#post_comment_content").focus(); } }); if (localStorage['Argon_fabs_Floating_Status'] == "left"){ $fabtns.addClass("fabtns-float-left"); } $toggleSidesBtn.on("click" , function(){ $fabtns.addClass("fabtns-unloaded"); setTimeout(function(){ $fabtns.toggleClass("fabtns-float-left"); if ($fabtns.hasClass("fabtns-float-left")){ localStorage['Argon_fabs_Floating_Status'] = "left"; }else{ localStorage['Argon_fabs_Floating_Status'] = "right"; } $fabtns.removeClass("fabtns-unloaded"); } , 300); }); //博客设置 $toggleBlogSettings.on("click" , function(){ $("#float_action_buttons").toggleClass("blog_settings_opened"); }); $("#close_blog_settings").on("click" , function(){ $("#float_action_buttons").removeClass("blog_settings_opened"); }); $("#blog_setting_darkmode_switch .custom-toggle-slider").on("click" , function(){ toggleDarkmode(); }); //字体 $("#blog_setting_font_sans_serif").on("click" , function(){ $("html").removeClass("use-serif"); localStorage['Argon_Use_Serif'] = "false"; }); $("#blog_setting_font_serif").on("click" , function(){ $("html").addClass("use-serif"); localStorage['Argon_Use_Serif'] = "true"; }); if (localStorage['Argon_Use_Serif'] == "true"){ $("html").addClass("use-serif"); }else if (localStorage['Argon_Use_Serif'] == "false"){ $("html").removeClass("use-serif"); } //阴影 $("#blog_setting_shadow_small").on("click" , function(){ $("html").removeClass("use-big-shadow"); localStorage['Argon_Use_Big_Shadow'] = "false"; }); $("#blog_setting_shadow_big").on("click" , function(){ $("html").addClass("use-big-shadow"); localStorage['Argon_Use_Big_Shadow'] = "true"; }); if (localStorage['Argon_Use_Big_Shadow'] == "true"){ $("html").addClass("use-big-shadow"); }else if (localStorage['Argon_Use_Big_Shadow'] == "false"){ $("html").removeClass("use-big-shadow"); } //滤镜 function setBlogFilter(name){ if (name == undefined || name == ""){ name = "off"; } if (!$("html").hasClass("filter-" + name)){ $("html").removeClass("filter-sunset filter-darkness filter-grayscale"); if (name != "off"){ $("html").addClass("filter-" + name); } } $("#blog_setting_filters .blog-setting-filter-btn").removeClass("active"); $("#blog_setting_filters .blog-setting-filter-btn[filter-name='" + name + "']").addClass("active"); localStorage['Argon_Filter'] = name; } setBlogFilter(localStorage['Argon_Filter']); $(".blog-setting-filter-btn").on("click" , function(){ setBlogFilter(this.getAttribute("filter-name")); }); //UI 样式切换 (玻璃拟态/新拟态) function setUIStyle(style){ if (style == undefined || style == ""){ style = "default"; } $("html").removeClass("style-glass style-neumorphism"); if (style != "default"){ $("html").addClass("style-" + style); } $(".blog-setting-style-btn").removeClass("active"); $(".blog-setting-style-btn[style-name='" + style + "']").addClass("active"); localStorage['Argon_UI_Style'] = style; } setUIStyle(localStorage['Argon_UI_Style']); $(".blog-setting-style-btn").on("click" , function(){ setUIStyle(this.getAttribute("style-name")); }); let $window = $(window); function changefabtnDisplayStatus(){ //阅读进度 function hideReadingProgress(){ $readingProgressBtn.addClass("fabtn-hidden"); } function setReadingProgress(percent){ $readingProgressBtn.removeClass("fabtn-hidden"); $readingProgressDetails.html((percent * 100).toFixed(0) + "%"); $readingProgressBar.css("width" , (percent * 100).toFixed(0) + "%"); } if ($("article.post.post-full").length == 0){ hideReadingProgress(); }else{ let a = $window.scrollTop() - ($("article.post.post-full").offset().top - 80); let b = $("article.post.post-full").outerHeight() + 50 - $window.height(); if (b <= 0){ hideReadingProgress(); }else{ readingProgress = a / b; if (isNaN(readingProgress) || readingProgress < 0 || readingProgress > 1){ hideReadingProgress(); }else{ setReadingProgress(readingProgress); } } } //是否显示回顶 if ($(window).scrollTop() >= 400){ $backToTopBtn.removeClass("fabtn-hidden"); }else{ $backToTopBtn.addClass("fabtn-hidden"); } } changefabtnDisplayStatus(); $(window).scroll(function(){ changefabtnDisplayStatus(); }); $(window).resize(function(){ changefabtnDisplayStatus(); }); $fabtns.removeClass("fabtns-unloaded"); }(); /*卡片圆角大小调整*/ !function(){ function setCardRadius(radius, setcookie){ document.documentElement.style.setProperty('--card-radius', radius + "px"); if (setcookie){ setCookie("argon_card_radius", radius, 365); } } let slider = document.getElementById('blog_setting_card_radius'); noUiSlider.create(slider, { start: [$("meta[name='theme-card-radius']").attr("content")], step: 0.5, connect: [true, false], range: { 'min': [0], 'max': [30] } }); slider.noUiSlider.on('update', function (values){ let value = values[0]; setCardRadius(value, false); }); slider.noUiSlider.on('set', function (values){ let value = values[0]; setCardRadius(value, true); }); $(document).on("click" , "#blog_setting_card_radius_to_default" , function(){ slider.noUiSlider.set($("meta[name='theme-card-radius-origin']").attr("content")); setCardRadius($("meta[name='theme-card-radius-origin']").attr("content"), false); setCookie("argon_card_radius", $("meta[name='theme-card-radius-origin']").attr("content"), 0); }); }(); /*评论区 & 发送评论*/ !function(){ //回复评论 let replying = false , replyID = 0; function reply(commentID){ cancelEdit(false); replying = true; replyID = commentID; let nameEl = $("#comment-" + commentID + " .comment-item-title > .comment-name")[0]; let textEl = $("#comment-" + commentID + " .comment-item-text")[0]; let sourceEl = $("#comment-" + commentID + " .comment-item-source")[0]; if (nameEl) { $("#post_comment_reply_name").text(nameEl.textContent); } let preview = textEl ? textEl.textContent : ''; if (sourceEl && sourceEl.innerHTML !== '') { preview = sourceEl.textContent; } $("#post_comment_reply_preview").text(preview); if ($("#comment-" + commentID + " .comment-item-title .badge-private-comment").length > 0){ $("#post_comment").addClass("post-comment-force-privatemode-on"); }else{ $("#post_comment").addClass("post-comment-force-privatemode-off"); } $("body,html").animate({ scrollTop: $('#post_comment').offset().top - 100 }, 400, 'easeOutCirc'); $('#post_comment_reply_info').slideDown(350, 'easeOutCirc'); setTimeout(function(){ $("#post_comment_content").focus(); }, 350); } function cancelReply(){ replying = false; replyID = 0; $('#post_comment_reply_info').slideUp(250, 'easeOutCirc'); $("#post_comment").removeClass("post-comment-force-privatemode-on post-comment-force-privatemode-off"); } $(document).on("click" , ".comment-reply" , function(){ reply(this.getAttribute("data-id")); }); $(document).on("click pjax:click" , "#post_comment_reply_cancel" , function(){ cancelReply(); }); $(document).on("pjax:click" , function(){ replying = false; replyID = 0; $('#post_comment_reply_info').css("display", "none"); $("#post_comment").removeClass("post-comment-force-privatemode-on post-comment-force-privatemode-off"); }); //编辑评论 let editing = false , editID = 0; function edit(commentID){ cancelReply(); editing = true; editID = commentID; $('#post_comment').addClass("editing"); $("#post_comment_content").val($("#comment-" + editID + " .comment-item-source").text()); $("#post_comment_content").trigger("change"); if ($("#comment-" + editID).data("use-markdown") == true && document.getElementById("comment_post_use_markdown") != null){ document.getElementById("comment_post_use_markdown").checked = true; }else{ document.getElementById("comment_post_use_markdown").checked = false; } if ($("#comment-" + commentID + " .comment-item-title .badge-private-comment").length > 0){ $("#post_comment").addClass("post-comment-force-privatemode-on"); }else{ $("#post_comment").addClass("post-comment-force-privatemode-off"); } $("body,html").animate({ scrollTop: $('#post_comment').offset().top - 100 }, 400, 'easeOutCirc'); $("#post_comment_content").focus(); } function cancelEdit(clear){ editing = false; editID = 0; $("#post_comment").removeClass("post-comment-force-privatemode-on post-comment-force-privatemode-off"); if (clear == true) $("#post_comment_content").val(""); $("#post_comment_content").trigger("change"); $('#post_comment').removeClass("editing"); } $(document).on("click", ".comment-edit", function(){ edit(this.getAttribute("data-id")); }); $(document).on("click", "#post_comment_edit_cancel", function(){ $("body,html").animate({ scrollTop: $("#comment-" + editID).offset().top - 100 }, 400, 'easeOutCirc'); cancelEdit(true); }); $(document).on("pjax:click", function(){ cancelEdit(true); }); $(document).on("click", ".comment-pin, .comment-unpin", function(){ toogleCommentPin(this.getAttribute("data-id"), !this.classList.contains("comment-pin")); }); $(document).on("mouseenter", ".comment-parent-info", function(){ $("#comment-" + this.getAttribute("data-parent-id")).addClass("highlight"); }); $(document).on("mouseleave", ".comment-parent-info", function(){ $("#comment-" + this.getAttribute("data-parent-id")).removeClass("highlight"); }); //切换评论置顶状态 function toogleCommentPin(commentID, pinned){ $("#comment_pin_comfirm_dialog .modal-title").html(pinned ? __("取消置顶评论") : __("置顶评论")); $("#comment_pin_comfirm_dialog .modal-body").html(pinned ? __("是否要取消置顶评论 #") + commentID + "?" : __("是否要置顶评论 #") + commentID + "?"); $("#comment_pin_comfirm_dialog .btn-comfirm").html(__("确认")).attr("disabled", false); $("#comment_pin_comfirm_dialog .btn-dismiss").html(__("取消")).attr("disabled", false); $("#comment_pin_comfirm_dialog .btn-comfirm").off("click").on("click", function(){ $("#comment_pin_comfirm_dialog .btn-dismiss").attr("disabled", true) $("#comment_pin_comfirm_dialog .btn-comfirm").attr("disabled", true).prepend(__(``)); $.ajax({ type: 'POST', url: argonConfig.wp_path + "wp-admin/admin-ajax.php", dataType : "json", data: { action: "pin_comment", id: commentID, pinned: pinned ? "false" : "true" }, success: function(result){ $("#comment_pin_comfirm_dialog").modal('hide'); if (result.status == "success"){ if (pinned){ $("#comment-" + commentID + " .comment-name .badge-pinned").remove(); $("#comment-" + commentID + " .comment-unpin").removeClass("comment-unpin").addClass("comment-pin").html(__("置顶")); }else{ $("#comment-" + commentID + " .comment-name").append(`${__("置顶")}`); $("#comment-" + commentID + " .comment-pin").removeClass("comment-pin").addClass("comment-unpin").html(__("取消置顶")); } iziToast.show({ title: pinned ? __("取消置顶成功") : __("置顶成功"), message: pinned ? __("该评论已取消置顶") : __("该评论已置顶"), class: 'shadow-sm', position: 'topRight', backgroundColor: '#2dce89', titleColor: '#ffffff', messageColor: '#ffffff', iconColor: '#ffffff', progressBarColor: '#ffffff', icon: 'fa fa-check', timeout: 5000 }); } else { iziToast.show({ title: pinned ? __("取消置顶失败") : __("置顶失败"), message: result.msg, class: 'shadow-sm', position: 'topRight', backgroundColor: '#f5365c', titleColor: '#ffffff', messageColor: '#ffffff', iconColor: '#ffffff', progressBarColor: '#ffffff', icon: 'fa fa-close', timeout: 5000 }); } }, error: function(result){ $("#comment_pin_comfirm_dialog").modal('hide'); iziToast.show({ title: pinned ? __("取消置顶失败") : __("置顶失败"), message: __("未知错误"), class: 'shadow-sm', position: 'topRight', backgroundColor: '#f5365c', titleColor: '#ffffff', messageColor: '#ffffff', iconColor: '#ffffff', progressBarColor: '#ffffff', icon: 'fa fa-close', timeout: 5000 }); } }); }); $("#comment_pin_comfirm_dialog").modal(null); } //显示/隐藏额外输入框 (评论者网站) $(document).on("click" , "#post_comment_toggle_extra_input" , function(){ $("#post_comment").toggleClass("show-extra-input"); if ($("#post_comment").hasClass("show-extra-input")){ $("#post_comment_extra_input").slideDown(250, 'easeOutCirc'); }else{ $("#post_comment_extra_input").slideUp(200, 'easeOutCirc'); } }); //输入框细节 $(document).on("change input keydown keyup propertychange" , "#post_comment_content" , function(){ $("#post_comment_content_hidden")[0].innerText = $("#post_comment_content").val() + "\n"; $("#post_comment_content").css("height" , $("#post_comment_content_hidden").outerHeight()); }); $(document).on("focus" , "#post_comment_link" , function(){ $(".post-comment-link-container").addClass("active"); }); $(document).on("blur" , "#post_comment_link" , function(){ $(".post-comment-link-container").removeClass("active"); }); $(document).on("focus" , "#post_comment_captcha" , function(){ $(".post-comment-captcha-container").addClass("active"); }); $(document).on("blur" , "#post_comment_captcha" , function(){ $(".post-comment-captcha-container").removeClass("active"); }); //发送评论 window.postComment = function postComment(){ let commentContent = $("#post_comment_content").val(); let commentName = $("#post_comment_name").val(); let commentEmail = $("#post_comment_email").val(); let commentLink = $("#post_comment_link").val(); let commentCaptcha = $("#post_comment_captcha").val(); let useMarkdown = false; let privateMode = false; let mailNotice = false; if ($("#comment_post_use_markdown").length > 0){ useMarkdown = $("#comment_post_use_markdown")[0].checked; } if ($("#comment_post_privatemode").length > 0){ privateMode = $("#comment_post_privatemode")[0].checked; } if ($("#comment_post_mailnotice").length > 0){ mailNotice = $("#comment_post_mailnotice")[0].checked; } let postID = $("#post_comment_post_id").val(); let commentCaptchaSeed = $("#post_comment_captcha_seed").val(); let isError = false; let errorMsg = ""; //检查表单合法性 if (commentContent.match(/^\s*$/)){ isError = true; errorMsg += __("评论内容不能为空") + ""; } if (!$("#post_comment").hasClass("no-need-name-email")){ if (commentName.match(/^\s*$/)){ isError = true; errorMsg += __("昵称不能为空") + ""; } if ($("#post_comment").hasClass("enable-qq-avatar")){ if (!(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/).test(commentEmail) && !(/^[1-9][0-9]{4,10}$/).test(commentEmail)){ isError = true; errorMsg += __("邮箱或 QQ 号格式错误") + ""; } }else{ if (!(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/).test(commentEmail)){ isError = true; errorMsg += __("邮箱格式错误") + ""; } } }else{ if (commentEmail.length || (document.getElementById("comment_post_mailnotice") != null && document.getElementById("comment_post_mailnotice").checked == true)){ if ($("#post_comment").hasClass("enable-qq-avatar")){ if (!(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/).test(commentEmail) && !(/^[1-9][0-9]{4,10}$/).test(commentEmail)){ isError = true; errorMsg += __("邮箱或 QQ 号格式错误") + ""; } }else{ if (!(/^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/).test(commentEmail)){ isError = true; errorMsg += __("邮箱格式错误") + ""; } } } } if (commentLink != "" && !(/https?:\/\//).test(commentLink)){ isError = true; errorMsg += __("网站格式错误 (不是 http(s):// 开头)") + ""; } if (!$("#post_comment").hasClass("no-need-captcha")){ // 检查是否使用Geetest验证码 if ($("#geetest-captcha").length > 0) { // 检查Geetest库是否加载成功 if (typeof window.geetestLoadFailed !== 'undefined' && window.geetestLoadFailed) { isError = true; errorMsg += __("验证码服务不可用,请刷新页面重试"); } else if (typeof window.geetestCaptcha === 'undefined' || !window.geetestCaptcha) { isError = true; errorMsg += __("验证码未初始化,请稍后重试"); } else { // Geetest验证码检查 let lotNumber = $("#geetest_lot_number").val(); let captchaOutput = $("#geetest_captcha_output").val(); let passToken = $("#geetest_pass_token").val(); let genTime = $("#geetest_gen_time").val(); if (!lotNumber || !captchaOutput || !passToken || !genTime) { isError = true; errorMsg += __("请完成验证码验证"); } } } else { // 原有的数学验证码检查 if (commentCaptcha == ""){ isError = true; errorMsg += __("验证码未输入"); } if (commentCaptcha != "" && !(/^[0-9]+$/).test(commentCaptcha)){ isError = true; errorMsg += __("验证码格式错误"); } } } if (isError){ // 确保按钮和表单元素处于可用状态 $("#post_comment_send").removeAttr("disabled"); $("#post_comment_content").removeAttr("disabled"); $("#post_comment_name").removeAttr("disabled"); $("#post_comment_email").removeAttr("disabled"); $("#post_comment_link").removeAttr("disabled"); $("#post_comment_captcha").removeAttr("disabled"); $("#post_comment_reply_cancel").removeAttr("disabled"); $("#post_comment").removeClass("sending"); $("#post_comment_send .btn-inner--icon.hide-on-comment-editing").html(""); $("#post_comment_send .btn-inner--text.hide-on-comment-editing").html(__("发送")); iziToast.show({ title: __("评论格式错误"), message: errorMsg, class: 'shadow-sm', position: 'topRight', backgroundColor: '#f5365c', titleColor: '#ffffff', messageColor: '#ffffff', iconColor: '#ffffff', progressBarColor: '#ffffff', icon: 'fa fa-close', timeout: 5000 }); return; } //增加 disabled 属性和其他的表单提示 $("#post_comment").addClass("sending"); $("#post_comment_content").attr("disabled","disabled"); $("#post_comment_name").attr("disabled","disabled"); $("#post_comment_email").attr("disabled","disabled"); $("#post_comment_captcha").attr("disabled","disabled"); $("#post_comment_link").attr("disabled","disabled"); $("#post_comment_send").attr("disabled","disabled"); $("#post_comment_reply_cancel").attr("disabled","disabled"); $("#post_comment_send .btn-inner--icon.hide-on-comment-editing").html(""); $("#post_comment_send .btn-inner--text.hide-on-comment-editing").html(__("发送中")); iziToast.show({ title: __("正在发送"), message: __("评论正在发送中..."), class: 'shadow-sm iziToast-noprogressbar', position: 'topRight', backgroundColor: 'var(--themecolor)', titleColor: '#ffffff', messageColor: '#ffffff', iconColor: '#ffffff', progressBarColor: '#ffffff', icon: 'fa fa-spinner fa-spin', close: false, timeout: 999999999 }); // 准备数据 var ajaxData = { action: "ajax_post_comment", comment: commentContent, author: commentName, email: commentEmail, url: commentLink, comment_post_ID: postID, comment_parent: replyID, "wp-comment-cookies-consent": "yes", use_markdown: useMarkdown, private_mode: privateMode, enable_mailnotice: mailNotice, argon_nonce: $("#argon_comment_nonce").val() }; // 根据验证码类型添加相应参数 if ($("#geetest-captcha").length > 0) { // 检查Geetest库加载状态 if (typeof window.geetestLoadFailed !== 'undefined' && window.geetestLoadFailed) { // 重新启用按钮和表单元素 $("#post_comment").removeClass("sending"); $("#post_comment_content").removeAttr("disabled"); $("#post_comment_name").removeAttr("disabled"); $("#post_comment_email").removeAttr("disabled"); $("#post_comment_captcha").removeAttr("disabled"); $("#post_comment_link").removeAttr("disabled"); $("#post_comment_send").removeAttr("disabled"); $("#post_comment_reply_cancel").removeAttr("disabled"); $("#post_comment_send .btn-inner--icon.hide-on-comment-editing").html(""); $("#post_comment_send .btn-inner--text.hide-on-comment-editing").html(__("发送")); setTimeout(function() { try { iziToast.destroy(); iziToast.error({ title: __('评论发送失败'), message: __('验证码服务不可用,请刷新页面重试'), position: 'topRight' }); } catch (e) { console.warn('iziToast error:', e); } }, 0); return false; } // Geetest验证码参数 - 使用后端期望的参数名 ajaxData.lot_number = $("#geetest_lot_number").val(); ajaxData.captcha_output = $("#geetest_captcha_output").val(); ajaxData.pass_token = $("#geetest_pass_token").val(); ajaxData.gen_time = $("#geetest_gen_time").val(); // 验证Geetest参数是否完整 if (!ajaxData.lot_number || !ajaxData.captcha_output || !ajaxData.pass_token || !ajaxData.gen_time) { // 重新启用按钮和表单元素 $("#post_comment").removeClass("sending"); $("#post_comment_content").removeAttr("disabled"); $("#post_comment_name").removeAttr("disabled"); $("#post_comment_email").removeAttr("disabled"); $("#post_comment_captcha").removeAttr("disabled"); $("#post_comment_link").removeAttr("disabled"); $("#post_comment_send").removeAttr("disabled"); $("#post_comment_reply_cancel").removeAttr("disabled"); $("#post_comment_send .btn-inner--icon.hide-on-comment-editing").html(""); $("#post_comment_send .btn-inner--text.hide-on-comment-editing").html(__("发送")); // 使用 setTimeout 确保 iziToast 操作在下一个事件循环中执行 setTimeout(function() { try { iziToast.destroy(); iziToast.error({ title: __('评论发送失败'), message: __('请完成验证码验证'), position: 'topRight' }); } catch (e) { console.warn('iziToast error:', e); } }, 0); return false; } } else { // 原有数学验证码参数 ajaxData.comment_captcha_seed = commentCaptchaSeed; ajaxData.comment_captcha = commentCaptcha; } $.ajax({ type: 'POST', url: argonConfig.wp_path + "wp-admin/admin-ajax.php", dataType : "json", data: ajaxData, success: function(result){ $("#post_comment").removeClass("sending"); $("#post_comment_content").removeAttr("disabled"); $("#post_comment_name").removeAttr("disabled"); $("#post_comment_email").removeAttr("disabled"); $("#post_comment_link").removeAttr("disabled"); $("#post_comment_send").removeAttr("disabled"); $("#post_comment_reply_cancel").removeAttr("disabled"); $("#post_comment_send .btn-inner--icon.hide-on-comment-editing").html(""); $("#post_comment_send .btn-inner--text.hide-on-comment-editing").html(__("发送")); $("#post_comment").removeClass("show-extra-input post-comment-force-privatemode-on post-comment-force-privatemode-off"); if (!result.isAdmin){ $("#post_comment_captcha").removeAttr("disabled"); } //判断是否有错误 if (result.status == "failed"){ // 使用 setTimeout 确保 iziToast 操作在下一个事件循环中执行 setTimeout(function() { try { iziToast.destroy(); iziToast.show({ title: __("评论发送失败"), message: result.msg, class: 'shadow-sm', position: 'topRight', backgroundColor: '#f5365c', titleColor: '#ffffff', messageColor: '#ffffff', iconColor: '#ffffff', progressBarColor: '#ffffff', icon: 'fa fa-close', timeout: 5000 }); } catch (e) { console.warn('iziToast error:', e); } }, 0); return; } //发送成功 // 使用 setTimeout 确保 iziToast 操作在下一个事件循环中执行 setTimeout(function() { try { iziToast.destroy(); iziToast.show({ title: __("发送成功"), message: __("您的评论已发送"), class: 'shadow-sm', position: 'topRight', backgroundColor: '#2dce89', titleColor: '#ffffff', messageColor: '#ffffff', iconColor: '#ffffff', progressBarColor: '#ffffff', icon: 'fa fa-check', timeout: 5000 }); //插入新评论 result.html = result.html.replace(/<(\/).noscript>/g, ""); let parentID = result.parentID; if (parentID == "" || parentID == null){ parentID = 0; } parentID = parseInt(parentID); if (parentID == 0){ if ($("#comments > .card-body > ol.comment-list").length == 0){ $("#comments > .card-body").html("" + $(block).html() + "");
});
$("article pre > code").each(function(index, block) {
if ($(block).hasClass("no-hljs")){
return;
}
$(block).parent().attr("id", randomString());
hljs.highlightBlock(block);
hljs.lineNumbersBlock(block, {singleLine: true});
$(block).parent().addClass("hljs-codeblock");
if (argonConfig.code_highlight.hide_linenumber){
$(block).parent().addClass("hljs-hide-linenumber");
}
if (argonConfig.code_highlight.break_line){
$(block).parent().addClass("hljs-break-line");
}
if (argonConfig.code_highlight.transparent_linenumber){
$(block).parent().addClass("hljs-transparent-linenumber");
}
$(block).attr("hljs-codeblock-inner", "");
let copyBtnID = "copy_btn_" + randomString();
$(block).parent().append(`