您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
对 linux.do 的增强脚本
当前为
- // ==UserScript==
- // @name Linux.po
- // @namespace http://tampermonkey.net/
- // @version 0.1.1
- // @description 对 linux.do 的增强脚本
- // @author PRO-2684
- // @match https://linux.do/*
- // @run-at document-start
- // @icon 
- // @license gpl-3.0
- // @grant GM_setValue
- // @grant GM_getValue
- // @grant GM_deleteValue
- // @grant GM_registerMenuCommand
- // @grant GM_unregisterMenuCommand
- // @grant GM_addValueChangeListener
- // @require https://github.com/PRO-2684/GM_config/releases/download/v1.2.1/config.min.js#md5=525526b8f0b6b8606cedf08c651163c2
- // ==/UserScript==
- (function () {
- 'use strict';
- const { name, version } = GM_info.script;
- const idPrefix = "linux-po-";
- const configDesc = {
- $default: {
- autoClose: false,
- },
- appearance: {
- name: "🎨 外观",
- title: "外观",
- type: "folder",
- items: {
- sidebarManager: {
- name: "⬅️ 侧栏管理",
- title: "允许你隐藏侧栏中的各个部分",
- type: "folder",
- items: {
- $default: {
- value: false,
- title: (prop, value, desc) => desc.name,
- formatter: (prop, value, desc) => `${desc.name}: ${value ? "🫥" : "👀"}`,
- },
- customCategories: {
- name: "自定义板块",
- type: "bool",
- },
- externalLinks: {
- name: "外部链接",
- type: "bool",
- },
- categories: {
- name: "类别",
- type: "bool",
- },
- tags: {
- name: "标签",
- type: "bool",
- },
- messages: {
- name: "消息",
- type: "bool",
- },
- channels: {
- name: "频道",
- type: "bool",
- },
- directMessages: {
- name: "直接消息",
- type: "bool",
- },
- chat: {
- name: "聊天",
- type: "bool",
- },
- bottomMenu: {
- name: "底部菜单",
- type: "bool",
- },
- },
- },
- },
- },
- accessibility: {
- name: "♿ 辅助功能",
- title: "辅助功能",
- type: "folder",
- items: {
- largerClickArea: {
- name: "👆 增大点击区域",
- title: "增大帖子列表中各帖子的可点击区域 (仅支持左键)",
- type: "bool",
- value: true,
- },
- showPostsFloor: {
- name: "🔢 显示楼层",
- title: "在帖子中显示楼层",
- type: "bool",
- value: false,
- },
- },
- },
- };
- const config = new GM_config(configDesc);
- // Helper function for css
- function injectCSS(id, css) {
- const style = document.head.appendChild(document.createElement("style"));
- style.id = idPrefix + id;
- style.textContent = css;
- return style;
- }
- function cssHelper(id, enable) {
- const current = document.getElementById(idPrefix + id);
- if (current) {
- current.disabled = !enable;
- } else if (enable) {
- injectCSS(id, dynamicStyles[id]);
- }
- }
- /**
- * Generates CSS for hiding given sidebar section.
- */
- function hideSidebarSection(section) {
- return `#d-sidebar > .sidebar-sections div.sidebar-section[data-section-name="${section}"] { display: none; }`;
- }
- // Dynamic styles
- const dynamicStyles = {
- "appearance.sidebarManager.customCategories": hideSidebarSection("community"),
- "appearance.sidebarManager.externalLinks": hideSidebarSection("外部链接"),
- "appearance.sidebarManager.categories": hideSidebarSection("categories"),
- "appearance.sidebarManager.tags": hideSidebarSection("tags"),
- "appearance.sidebarManager.messages": hideSidebarSection("messages"),
- "appearance.sidebarManager.channels": hideSidebarSection("chat-channels"),
- "appearance.sidebarManager.directMessages": hideSidebarSection("chat-dms"),
- "appearance.sidebarManager.chat": "#d-sidebar > button[data-key='chat'] { display: none; }",
- "appearance.sidebarManager.bottomMenu": "#d-sidebar > div.sidebar-footer-wrapper { display: none; }",
- "accessibility.largerClickArea": ".topic-list-item > .main-link { cursor: pointer; }",
- "accessibility.showPostsFloor": `.post-stream > .topic-post > article[id^='post_']::after {
- content: attr(id) '#'; color: var(--primary-med-or-secondary-med);
- position: absolute; right: 0; top: calc(0.8em + 1px);
- text-indent: -2.4em; overflow: hidden; /* Dirty trick to hide leading "post_" */
- }`,
- };
- for (const prop in dynamicStyles) {
- cssHelper(prop, config.get(prop));
- }
- // Accessibility
- // Larger click area
- let largerClickAreaEnabled = false;
- /**
- * Handles the click event when larger click area is enabled.
- * @param {MouseEvent} e
- */
- function largerClickAreaHandler(e) {
- if (e.defaultPrevented || !e.isTrusted) return;
- e.preventDefault();
- const mainLink = e.target.closest(".topic-list-item > .main-link");
- if (mainLink) {
- const title = mainLink.querySelector(".title.raw-link.raw-topic-link");
- title?.click();
- }
- }
- /**
- * Enables or disables the larger click area feature.
- * @param {boolean} enable
- */
- function largerClickArea(enable) {
- if (enable && !largerClickAreaEnabled) {
- document.body.addEventListener("click", largerClickAreaHandler);
- largerClickAreaEnabled = true;
- } else if (!enable && largerClickAreaEnabled) {
- document.body.removeEventListener("click", largerClickAreaHandler);
- largerClickAreaEnabled = false;
- }
- }
- // Callbacks
- const callbacks = {
- "accessibility.largerClickArea": largerClickArea,
- };
- for (const [prop, callback] of Object.entries(callbacks)) {
- callback(config.get(prop));
- }
- config.addEventListener("set", e => {
- if (e.detail.prop in dynamicStyles) {
- cssHelper(e.detail.prop, e.detail.after);
- }
- if (e.detail.prop in callbacks) {
- callbacks[e.detail.prop](e.detail.after);
- }
- });
- // https://linux.do/emojis.json
- })();