Discourse Pro

增强 Discourse 论坛。

目前为 2024-12-15 提交的版本。查看 最新版本

  1. /******/ (() => { // webpackBootstrap
  2. /******/ "use strict";
  3. /******/ var __webpack_modules__ = ({
  4.  
  5. /***/ "./utils/src/CommonOptions.ts":
  6. /*!************************************!*\
  7. !*** ./utils/src/CommonOptions.ts ***!
  8. \************************************/
  9. /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
  10.  
  11. __webpack_require__.r(__webpack_exports__);
  12. /* harmony export */ __webpack_require__.d(__webpack_exports__, {
  13. /* harmony export */ "default": () => (/* binding */ CommonOptions)
  14. /* harmony export */ });
  15. /* harmony import */ var _utils_gm_Store__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @utils/gm/Store */ "./utils/src/gm/Store.ts");
  16. /* harmony import */ var _utils_gm_MenuCmd__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @utils/gm/MenuCmd */ "./utils/src/gm/MenuCmd.ts");
  17. function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
  18. function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e) { throw _e; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e2) { didErr = true; err = _e2; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
  19. function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
  20. function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
  21. function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
  22. function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
  23. function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
  24. function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
  25. function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
  26.  
  27.  
  28.  
  29. /**
  30. * 选项菜单
  31. */
  32. var CommonOptions = /*#__PURE__*/function () {
  33. function CommonOptions() {
  34. _classCallCheck(this, CommonOptions);
  35. }
  36. return _createClass(CommonOptions, null, [{
  37. key: "registerBoolOption",
  38. value:
  39. // /**
  40. // * 选项 Key
  41. // */
  42. // protected static Keys = {
  43. // // xxx: 'xxx'
  44. // }
  45. //
  46. // /**
  47. // * 选项
  48. // * @private
  49. // */
  50. // protected static options = [
  51. // // {label: '', name: this.Keys.xxx, version: 1, value: false, menuCmdId: null},
  52. // ];
  53.  
  54. /**
  55. * 注册 bool 类型的选项
  56. * @param option 选项
  57. */
  58. function registerBoolOption(option) {
  59. var _this = this;
  60. var val = option.value,
  61. valIsBool = typeof val === 'boolean';
  62. if (!valIsBool) {
  63. return;
  64. }
  65. // 注册选项
  66. var currentMenuCmdId = _utils_gm_MenuCmd__WEBPACK_IMPORTED_MODULE_1__["default"].register((val ? '☑️ ' : '🔲 ') + option.label, function () {
  67. // 点击值取反
  68. option.value = !option.value;
  69. _utils_gm_Store__WEBPACK_IMPORTED_MODULE_0__["default"].set(option.name, JSON.stringify(option));
  70.  
  71. // 取消注册
  72. _utils_gm_MenuCmd__WEBPACK_IMPORTED_MODULE_1__["default"].unregister(currentMenuCmdId);
  73. // 重新注册
  74. _this.registerBoolOption(option);
  75. // 刷新页面
  76. window.location.reload();
  77. });
  78.  
  79. // 保存选项 ID
  80. option.menuCmdId = currentMenuCmdId;
  81. _utils_gm_Store__WEBPACK_IMPORTED_MODULE_0__["default"].set(option.name, JSON.stringify(option));
  82. }
  83.  
  84. /**
  85. * 注册所有选项
  86. * @param url 设置页面 URL
  87. * @param options
  88. */
  89. }, {
  90. key: "registerAll",
  91. value: function registerAll(url, options) {
  92. _utils_gm_MenuCmd__WEBPACK_IMPORTED_MODULE_1__["default"].register('更多设置', function () {
  93. window.open(url, '_blank');
  94. });
  95. var _iterator = _createForOfIteratorHelper(options),
  96. _step;
  97. try {
  98. for (_iterator.s(); !(_step = _iterator.n()).done;) {
  99. var option = _step.value;
  100. // TODO 【调试】不保留选项的值,每次都从 Store 中获取
  101. // Store.set(option.name, null);
  102.  
  103. var storeOption = _utils_gm_Store__WEBPACK_IMPORTED_MODULE_0__["default"].get(option.name) ? JSON.parse(_utils_gm_Store__WEBPACK_IMPORTED_MODULE_0__["default"].get(option.name)) : null;
  104. // 如果选项不存在 || 版本不一致 时重置选项
  105. if (storeOption === null || !storeOption['version'] || storeOption['version'] < option.version) {
  106. _utils_gm_Store__WEBPACK_IMPORTED_MODULE_0__["default"].set(option.name, JSON.stringify(option));
  107. storeOption = option;
  108. }
  109. this.registerBoolOption(storeOption);
  110. }
  111. } catch (err) {
  112. _iterator.e(err);
  113. } finally {
  114. _iterator.f();
  115. }
  116. }
  117.  
  118. /**
  119. * 在页面中加载选项
  120. */
  121. }, {
  122. key: "loadInGreasyfork",
  123. value: function loadInGreasyfork(scriptId, loadOptionContentFn) {
  124. if (location.host !== 'greasyfork.org' || location.href.indexOf('/scripts/' + scriptId) == -1) {
  125. return;
  126. }
  127. var selector = {
  128. scriptLinks: '#script-links',
  129. scriptOptions: '#script-options',
  130. scriptContent: '#script-content'
  131. };
  132. var $body = $(document.body),
  133. $scriptLinks = $(selector.scriptLinks),
  134. $scriptContent = $(selector.scriptContent);
  135.  
  136. // 添加脚本设置的选项卡
  137. $scriptLinks.children('li:eq(0)').after("<li><a href=\"javascript:;\" id=\"script-options\">\u811A\u672C\u8BBE\u7F6E</a></li>");
  138. // 脚本设置选项点击事件
  139. $body.on('click', selector.scriptOptions, function () {
  140. // 移除已选中选项的样式
  141. var $currentLi = $scriptLinks.children('li.current');
  142. $currentLi.html("<a href=\"".concat(location.href, "\">").concat($currentLi.text(), "</a>"));
  143. $currentLi.removeClass('current');
  144.  
  145. // 添加选中选项的样式
  146. var $scriptOptions = $(selector.scriptOptions);
  147. $scriptOptions.parent().addClass('current');
  148. loadOptionContentFn($scriptContent);
  149. });
  150. }
  151. }]);
  152. }();
  153.  
  154.  
  155. /***/ }),
  156.  
  157. /***/ "./utils/src/gm/MenuCmd.ts":
  158. /*!*********************************!*\
  159. !*** ./utils/src/gm/MenuCmd.ts ***!
  160. \*********************************/
  161. /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
  162.  
  163. __webpack_require__.r(__webpack_exports__);
  164. /* harmony export */ __webpack_require__.d(__webpack_exports__, {
  165. /* harmony export */ "default": () => (/* binding */ MenuCmd)
  166. /* harmony export */ });
  167. function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
  168. function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
  169. function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
  170. function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
  171. function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
  172. function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
  173. /**
  174. * 选项菜单
  175. */
  176. var MenuCmd = /*#__PURE__*/function () {
  177. function MenuCmd() {
  178. _classCallCheck(this, MenuCmd);
  179. }
  180. return _createClass(MenuCmd, null, [{
  181. key: "register",
  182. value:
  183. /**
  184. * 注册
  185. * @param name 名称
  186. * @param fn 点击菜单时执行的函数
  187. */
  188. function register(name, fn) {
  189. return GM_registerMenuCommand(name, fn);
  190. }
  191.  
  192. /**
  193. * 注销
  194. * @param menuCmdId 注册时返回的 ID
  195. */
  196. }, {
  197. key: "unregister",
  198. value: function unregister(menuCmdId) {
  199. GM_unregisterMenuCommand(menuCmdId);
  200. }
  201. }]);
  202. }();
  203.  
  204.  
  205. /***/ }),
  206.  
  207. /***/ "./utils/src/gm/Store.ts":
  208. /*!*******************************!*\
  209. !*** ./utils/src/gm/Store.ts ***!
  210. \*******************************/
  211. /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
  212.  
  213. __webpack_require__.r(__webpack_exports__);
  214. /* harmony export */ __webpack_require__.d(__webpack_exports__, {
  215. /* harmony export */ "default": () => (/* binding */ Store)
  216. /* harmony export */ });
  217. function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
  218. function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
  219. function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
  220. function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
  221. function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
  222. function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
  223. /**
  224. * 存储
  225. */
  226. var Store = /*#__PURE__*/function () {
  227. function Store() {
  228. _classCallCheck(this, Store);
  229. }
  230. return _createClass(Store, null, [{
  231. key: "get",
  232. value:
  233. /**
  234. * 获取
  235. * @param key 键
  236. */
  237. function get(key) {
  238. return GM_getValue(key);
  239. }
  240.  
  241. /**
  242. * 设置
  243. * @param key 键
  244. * @param value 值
  245. */
  246. }, {
  247. key: "set",
  248. value: function set(key, value) {
  249. GM_setValue(key, value);
  250. }
  251. }]);
  252. }();
  253.  
  254.  
  255. /***/ })
  256.  
  257. /******/ });
  258. /************************************************************************/
  259. /******/ // The module cache
  260. /******/ var __webpack_module_cache__ = {};
  261. /******/
  262. /******/ // The require function
  263. /******/ function __webpack_require__(moduleId) {
  264. /******/ // Check if module is in cache
  265. /******/ var cachedModule = __webpack_module_cache__[moduleId];
  266. /******/ if (cachedModule !== undefined) {
  267. /******/ return cachedModule.exports;
  268. /******/ }
  269. /******/ // Create a new module (and put it into the cache)
  270. /******/ var module = __webpack_module_cache__[moduleId] = {
  271. /******/ // no module.id needed
  272. /******/ // no module.loaded needed
  273. /******/ exports: {}
  274. /******/ };
  275. /******/
  276. /******/ // Execute the module function
  277. /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
  278. /******/
  279. /******/ // Return the exports of the module
  280. /******/ return module.exports;
  281. /******/ }
  282. /******/
  283. /************************************************************************/
  284. /******/ /* webpack/runtime/define property getters */
  285. /******/ (() => {
  286. /******/ // define getter functions for harmony exports
  287. /******/ __webpack_require__.d = (exports, definition) => {
  288. /******/ for(var key in definition) {
  289. /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
  290. /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
  291. /******/ }
  292. /******/ }
  293. /******/ };
  294. /******/ })();
  295. /******/
  296. /******/ /* webpack/runtime/hasOwnProperty shorthand */
  297. /******/ (() => {
  298. /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
  299. /******/ })();
  300. /******/
  301. /******/ /* webpack/runtime/make namespace object */
  302. /******/ (() => {
  303. /******/ // define __esModule on exports
  304. /******/ __webpack_require__.r = (exports) => {
  305. /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
  306. /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
  307. /******/ }
  308. /******/ Object.defineProperty(exports, '__esModule', { value: true });
  309. /******/ };
  310. /******/ })();
  311. /******/
  312. /************************************************************************/
  313. var __webpack_exports__ = {};
  314. // This entry need to be wrapped in an IIFE because it need to be isolated against other entry modules.
  315. (() => {
  316. var __webpack_exports__ = {};
  317. /*!**************************************!*\
  318. !*** ./discourse-pro/src/Options.ts ***!
  319. \**************************************/
  320. __webpack_require__.r(__webpack_exports__);
  321. /* harmony export */ __webpack_require__.d(__webpack_exports__, {
  322. /* harmony export */ "default": () => (/* binding */ Options)
  323. /* harmony export */ });
  324. /* harmony import */ var _utils_CommonOptions__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @utils/CommonOptions */ "./utils/src/CommonOptions.ts");
  325. /* harmony import */ var _utils_gm_Store__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! @utils/gm/Store */ "./utils/src/gm/Store.ts");
  326. var _Options;
  327. function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
  328. function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
  329. function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
  330. function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
  331. function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
  332. function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
  333. function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
  334. function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
  335. function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
  336.  
  337.  
  338. var Options = /*#__PURE__*/function () {
  339. function Options() {
  340. _classCallCheck(this, Options);
  341. }
  342. return _createClass(Options, null, [{
  343. key: "registerAll",
  344. value:
  345. /**
  346. * 注册所有选项
  347. */
  348. function registerAll() {
  349. _utils_CommonOptions__WEBPACK_IMPORTED_MODULE_0__["default"].registerAll('https://www.v2ex.com/settings', this.options);
  350. }
  351.  
  352. /**
  353. * 在页面中加载选项
  354. */
  355. }, {
  356. key: "loadInV2ex",
  357. value: function loadInV2ex() {
  358. var _this = this;
  359. if (location.href.indexOf('v2ex.com/settings') == -1) {
  360. return;
  361. }
  362. var selector = {
  363. menuTab: 'a.tab',
  364. currentMenuTab: 'a.tab_current',
  365. scriptOptions: '#script-options',
  366. scriptContent: '#Main .box',
  367. v2exTokenInput: 'input[name="v2exToken"]',
  368. saveOptionsBtn: '#save-options'
  369. },
  370. $body = $(document.body),
  371. $menuTab = $(selector.menuTab);
  372.  
  373. // 添加脚本设置的选项卡
  374. $menuTab.parent().append("<a id=\"script-options\" class=\"tab\" href=\"javascript:void(0);\">\u811A\u672C\u8BBE\u7F6E</a>");
  375. // 脚本设置选项点击事件
  376. $body.on('click', selector.scriptOptions, function () {
  377. // 移除已选中选项的样式
  378. var $currentMenuTab = $(selector.currentMenuTab);
  379. $currentMenuTab.removeClass('tab_current');
  380. $currentMenuTab.addClass('tab');
  381.  
  382. // 添加选中选项的样式
  383. var $scriptOptions = $(selector.scriptOptions);
  384. $scriptOptions.removeClass('tab');
  385. $scriptOptions.addClass('tab_current');
  386.  
  387. // 添加脚本设置的内容
  388. $(selector.scriptContent + ' div:gt(1)').remove();
  389. $(selector.scriptContent).append("\n <form>\n <div class=\"inner\">\n <div class=\"topic_content markdown_body\">\n <!--<p><a href=\"https://www.v2ex.com/settings/tokens\" target=\"_blank\">\u83B7\u53D6 V2EX Token</a></p> -->\n </div>\n <div class=\"sep20\"></div>\n <div class=\"social-settings-form\">\n <div>\n <div><a href=\"https://www.v2ex.com/settings/tokens\" target=\"_blank\">V2EX Token</a>\uFF1A</div>\n <input type=\"password\" class=\"sl\" name=\"v2exToken\" value=\"".concat(JSON.parse(_utils_gm_Store__WEBPACK_IMPORTED_MODULE_1__["default"].get(_this.Keys.v2exToken)).value, "\">\n </div>\n </div>\n </div>\n <div class=\"cell_ops\">\n <input id=\"save-options\" type=\"submit\" class=\"super normal button\" value=\"Save\">\n </div>\n </form>\n "));
  390. $body.on('click', selector.saveOptionsBtn, function () {
  391. var token = $(selector.v2exTokenInput).val();
  392. _utils_gm_Store__WEBPACK_IMPORTED_MODULE_1__["default"].set(_this.Keys.v2exToken, JSON.stringify(_objectSpread(_objectSpread({}, JSON.parse(_utils_gm_Store__WEBPACK_IMPORTED_MODULE_1__["default"].get(_this.Keys.v2exToken))), {
  393. value: token
  394. })));
  395. layer.msg('保存成功');
  396. return false;
  397. });
  398. });
  399. }
  400. }]);
  401. }();
  402. _Options = Options;
  403. /**
  404. * 选项 Key
  405. */
  406. _defineProperty(Options, "Keys", {
  407. v2exToken: 'v2exToken'
  408. });
  409. /**
  410. * 选项
  411. * @private
  412. */
  413. _defineProperty(Options, "options", [{
  414. label: 'V2EX Token',
  415. name: _Options.Keys.v2exToken,
  416. version: 1,
  417. value: '',
  418. menuCmdId: null
  419. }]);
  420.  
  421. })();
  422.  
  423. // This entry need to be wrapped in an IIFE because it need to be isolated against other entry modules.
  424. (() => {
  425. /*!***********************************!*\
  426. !*** ./discourse-pro/src/main.ts ***!
  427. \***********************************/
  428. __webpack_require__.r(__webpack_exports__);
  429. /* harmony import */ var _utils_gm_Store__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! @utils/gm/Store */ "./utils/src/gm/Store.ts");
  430. // ==UserScript==
  431. // @name Discourse Pro
  432. // @namespace http://tampermonkey.net/
  433. // @version 0.0.1
  434. // @description 增强 Discourse 论坛。
  435. // @author duanluan
  436. // @copyright 2024, duanluan (https://github.com/duanluan)
  437. // @license Apache-2.0; https://www.apache.org/licenses/LICENSE-2.0.txt
  438. // @homepage https://greasyfork.org/zh-CN/scripts/520817
  439. // @supportURL https://github.com/duanluan/tampermonkey-scripts/issues
  440. // @match *://linux.do/*
  441. // @match *://meta.appinn.net/*
  442. // @require https://cdn.jsdelivr.net/npm/jquery@3.7.1/dist/jquery.slim.min.js
  443. // @resource css https://cdn.jsdelivr.net/npm/layer-src@3.5.1/src/theme/default/layer.min.css
  444. // @require https://cdn.jsdelivr.net/npm/layer-src@3.5.1/src/layer.min.js
  445. // @grant GM_addStyle
  446. // @grant GM_getResourceText
  447. // @grant GM_getValue
  448. // @grant GM_setValue
  449. // ==/UserScript==
  450.  
  451. // ==OpenUserJS==
  452. // @author duanluan
  453. // @updateURL https://raw.kkgithub.com/duanluan/tampermonkey-scripts/main/discourse-pro/dist/discourse-pro.user.js
  454. // ==/OpenUserJS==
  455.  
  456.  
  457. var host = location.host;
  458. var selector = {
  459. // 侧边栏和主内容的父容器
  460. mainOutletWrapper: '#main-outlet-wrapper',
  461. // 侧边栏
  462. sidebarWrapper: '.sidebar-wrapper',
  463. // 主内容
  464. mainOutlet: '#main-outlet'
  465. };
  466. var storeKeys = {
  467. // 侧边栏宽度
  468. sidebarWidth: 'sidebarWidth_'
  469. };
  470.  
  471. /**
  472. * 加载侧边栏和内容之前的拖拽条
  473. */
  474. var loadDragBar = function loadDragBar() {
  475. var $mainOutletWrapper = $(selector.mainOutletWrapper),
  476. $sidebarWrapper = $(selector.sidebarWrapper);
  477.  
  478. // 在侧边栏内部追加一个拖拽条
  479. $sidebarWrapper.append("\n <div class=\"drag-bar\" style=\"width: 4px; cursor: ew-resize\"></div>\n ");
  480. // 读取存储的侧边栏宽度
  481. var storeSidebarWidth = _utils_gm_Store__WEBPACK_IMPORTED_MODULE_0__["default"].get(storeKeys.sidebarWidth + host);
  482. if (storeSidebarWidth) {
  483. $mainOutletWrapper.css('grid-template-columns', "".concat(storeSidebarWidth, "px minmax(0, 1fr)"));
  484. }
  485.  
  486. // 拖拽条
  487. var $dragBar = $sidebarWrapper.find('.drag-bar');
  488. // 是否正在拖拽
  489. var isDragging = false;
  490. // 鼠标按下时的 clientX
  491. var startClientX = 0;
  492. // 鼠标按下时的侧边栏宽度
  493. var startSidebarWidth = 0;
  494. // 侧边栏宽度范围
  495. var minSidebarWidth = 180,
  496. maxSidebarWidth = 500;
  497. var newSidebarWidth = 0;
  498.  
  499. // 鼠标按下事件
  500. $dragBar.on('mousedown', function (e) {
  501. startClientX = e.clientX;
  502. startSidebarWidth = $sidebarWrapper.width();
  503. isDragging = true;
  504. // 改变鼠标样式
  505. document.body.style.cursor = 'ew-resize';
  506. // 设置拖拽条背景色
  507. $dragBar.css('background-color', '#e6e6e6');
  508. // 防止文本被选中
  509. e.preventDefault();
  510. });
  511.  
  512. // 鼠标移动事件
  513. $(document).on('mousemove', function (e) {
  514. if (!isDragging) return;
  515.  
  516. // 计算新的宽度
  517. var deltaX = e.clientX - startClientX;
  518. newSidebarWidth = startSidebarWidth + deltaX;
  519. if (newSidebarWidth >= minSidebarWidth && newSidebarWidth <= maxSidebarWidth) {
  520. $mainOutletWrapper.css('grid-template-columns', "".concat(newSidebarWidth, "px minmax(0, 1fr)"));
  521. }
  522. });
  523.  
  524. // 鼠标松开事件
  525. $(document).on('mouseup', function () {
  526. if (!isDragging) return;
  527. isDragging = false;
  528. // 恢复鼠标样式
  529. document.body.style.cursor = 'default';
  530. // 恢复拖拽条背景色
  531. $dragBar.css('background-color', 'transparent');
  532. // 记忆侧边栏宽度
  533. _utils_gm_Store__WEBPACK_IMPORTED_MODULE_0__["default"].set(storeKeys.sidebarWidth + host, newSidebarWidth);
  534. });
  535. };
  536. (function (_$) {
  537. 'use strict';
  538.  
  539. // 判断是否为 Discourse
  540. var generator = (_$ = $('meta[name="generator"]')) === null || _$ === void 0 ? void 0 : _$.attr('content');
  541. if (!generator || generator.indexOf('Discourse') == -1) return;
  542.  
  543. // 加载 CSS
  544. GM_addStyle(GM_getResourceText('css'));
  545. // layer 图标未知原因失效,手动添加样式
  546. $(document.head).append("<style>\n .layui-layer-ico{background:url('https://cdn.jsdelivr.net/npm/layer-src@3.5.1/dist/theme/default/icon.png') no-repeat}\n .layui-layer-ico1{background-position:-30px 0}\n .layui-layer-ico2{background-position:-60px 0}\n .layui-layer-ico3{background-position:-90px 0}\n .layui-layer-ico4{background-position:-120px 0}\n .layui-layer-ico5{background-position:-150px 0}\n .layui-layer-ico6{background-position:-180px 0}\n </style>");
  547. loadDragBar();
  548. })();
  549. })();
  550.  
  551. /******/ })()
  552. ;
  553. //# sourceMappingURL=discourse-pro.user.js.map