new luogu

Luogu Expansion

目前為 2024-08-05 提交的版本,檢視 最新版本

  1. // ==UserScript==
  2. // @name new luogu
  3. // @namespace http://tampermonkey.net/
  4. // @version 1.4.1
  5. // @description Luogu Expansion
  6. // @description:zh 洛谷扩展
  7. // @author volatile
  8. // @match https://www.luogu.com.cn/*
  9. // @icon https://www.google.com/s2/favicons?sz=64&domain=luogu.com.cn
  10. // @grant GM_addStyle
  11. // @grant GM_getValue
  12. // @grant GM_setValue
  13. // @grant GM_deleteValue
  14. // @grant GM_listValues
  15. // @grant GM_setClipboard
  16. // @grant GM_xmlhttpRequest
  17. // @grant GM_getResourceText
  18. // @grant unsafeWindow
  19. // @connect baidu.com
  20. // @license MIT
  21. // ==/UserScript==
  22.  
  23. (function() {
  24. 'use strict';
  25. //进入插件
  26. console.log("This is new luogu");
  27. console.log("\n _____ _____ _____ _____ _____ \n /\\ \\ /\\ \\ /\\ \\ /\\ \\ /\\ \\ \n /::\\____\\ /::\\ \\ /::\\____\\ /::\\____\\ /::\\ \\ \n /::::| | /::::\\ \\ /:::/ / /:::/ / /::::\\ \\ \n /:::::| | /::::::\\ \\ /:::/ _/___ /:::/ / /::::::\\ \\ \n /::::::| | /:::/\\:::\\ \\ /:::/ /\\ \\ /:::/ / /:::/\\:::\\ \\ \n /:::/|::| | /:::/__\\:::\\ \\ /:::/ /::\\____\\ /:::/ / /:::/ \\:::\\ \\ \n /:::/ |::| | /::::\\ \\:::\\ \\ /:::/ /:::/ / /:::/ / /:::/ \\:::\\ \\ \n /:::/ |::| | _____ /::::::\\ \\:::\\ \\ /:::/ /:::/ _/___ /:::/ / /:::/ / \\:::\\ \\ \n /:::/ |::| |/\\ \\ /:::/\\:::\\ \\:::\\ \\ /:::/___/:::/ /\\ \\ /:::/ / /:::/ / \\:::\\ ___\\ \n/:: / |::| /::\\____\\/:::/__\\:::\\ \\:::\\____\\|:::| /:::/ /::\\____\\/:::/____/ /:::/____/ ___\\:::| |\n\\::/ /|::| /:::/ /\\:::\\ \\:::\\ \\::/ /|:::|__/:::/ /:::/ /\\:::\\ \\ \\:::\\ \\ /\\ /:::|____|\n \\/____/ |::| /:::/ / \\:::\\ \\:::\\ \\/____/ \\:::\\/:::/ /:::/ / \\:::\\ \\ \\:::\\ /::\\ \\::/ / \n |::|/:::/ / \\:::\\ \\:::\\ \\ \\::::::/ /:::/ / \\:::\\ \\ \\:::\\ \\:::\\ \\/____/ \n |::::::/ / \\:::\\ \\:::\\____\\ \\::::/___/:::/ / \\:::\\ \\ \\:::\\ \\:::\\____\\ \n |:::::/ / \\:::\\ \\::/ / \\:::\\__/:::/ / \\:::\\ \\ \\:::\\ /:::/ / \n |::::/ / \\:::\\ \\/____/ \\::::::::/ / \\:::\\ \\ \\:::\\/:::/ / \n /:::/ / \\:::\\ \\ \\::::::/ / \\:::\\ \\ \\::::::/ / \n /:::/ / \\:::\\____\\ \\::::/ / \\:::\\____\\ \\::::/ / \n \\::/ / \\::/ / \\::/____/ \\::/ / \\::/____/ \n \\/____/ \\/____/ ~~ \\/____/ \n ");
  28.  
  29. var css = ".newlgmenu{width: 100vw; height: 80vh; display: none; align-items: center; justify-content: center; font-size: 16px; } .NEWLG-menu{width: 600px; height: 550px; display: flex; flex-direction: column; padding: 40px; position: relative; z-index: 100; background: inherit; border-radius: 18px; overflow: hidden; } .NEWLG-menu::before{ content: \"\"; width: calc\(100% + 20px\); height: calc\(100% + 20px\); position: absolute; top: -10px; left: -10px; overflow:hidden; background: inherit; box-shadow: inset 0 0 0 200px rgba\(255, 255, 255, 0.75\); filter: blur\(5px\); z-index: -1; } .NEWLG-menu input { margin: 6px 0; height: 36px; border: none; background-color: rgba\(255, 255, 255, 0.75\); border-radius: 4px; padding: 0 14px; color: #3d5245; } .NEWLG-menu button { border: none; background: transparent; } .search-container { width: 10%; height: 50px; display: none; z-index: 114514; position: fixed; top: 20px; left: 500px; }.search-box {padding: 10px;border: 1px solid #ddd;border-radius: 4px;font-size: 16px;transition: border-color 0.3s;}.search-box:focus {border-color: #4A90E2;box-shadow: 0 0 8px rgba(74, 144, 226, 0.5);} #mask { position: fixed; left: 0; top: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); z-index: 1000; }";
  30. var style = document.createElement("style");
  31. style.innerHTML = css;
  32. document.head.appendChild(style);
  33.  
  34. let nowurl = window.location.href;
  35. console.log(nowurl);
  36.  
  37. let nowcolor1;
  38. let nowcolor="";
  39. if(nowurl == 'https://www.luogu.com.cn/'){
  40. nowcolor1 = document.querySelector('#app-old > div.lg-index-content.am-center > div:nth-child(1) > div > div > div > div.am-u-md-4.lg-punch.am-text-center > h2 > a').className;
  41. for(let i=0;i<nowcolor1.length;i++){
  42. if(nowcolor1[i]==' ') break;
  43. nowcolor = nowcolor + nowcolor1[i];
  44. }
  45. }
  46. console.log(nowcolor);
  47.  
  48.  
  49. function getcookie(name){
  50. const cookiestring = document.cookie;
  51. const cookies = cookiestring.split('; ');
  52. for(const cookie of cookies){
  53. const [cookiename, cookievalue] = cookie.split('=');
  54. if(cookiename === name) return cookievalue;
  55. }
  56. if(name == 'color'){
  57. const time = new Date();
  58. time.setDate(time.getDate() + 365);
  59. document.cookie = "color=" + nowcolor + ";expires=" + time.toUTCString();
  60. return nowcolor;
  61. }
  62. else if(name == 'hanger'){
  63. const time = new Date();
  64. time.setDate(time.getDate() + 365);
  65. document.cookie = "hanger=null" + ";expires=" + time.toUTCString();
  66. return "null";
  67. }
  68. else if(name == 'tag'){
  69. const time = new Date();
  70. time.setDate(time.getDate() + 365);
  71. document.cookie = "tag=null" + ";expires=" + time.toUTCString();
  72. return "null";
  73. }
  74. else if(name == 'version'){
  75. const time = new Date();
  76. time.setDate(time.getDate() + 119810);
  77. document.cookie = "version=1.3.1" + ";expires=" + time.toUTCString();
  78. return "1.3.1";
  79. }
  80. }
  81.  
  82. function colorschange(changecolor){
  83. if(changecolor == 'lg-fg-gray') return 'rgb\(191, 191, 191\)';
  84. else if(changecolor == 'lg-fg-blue') return 'rgb\(14, 144, 210\)';
  85. else if(changecolor == 'lg-fg-green') return 'rgb\(94, 185, 94\)';
  86. else if(changecolor == 'lg-fg-orange') return 'rgb\(230, 126 34\)';
  87. else if(changecolor == 'lg-fg-red') return 'rgb\(231, 76, 60\)';
  88. else if(changecolor == 'lg-fg-purple') return 'rgb\(142, 68, 173\)';
  89. }
  90.  
  91. if(getcookie('version') != '1.4.1'){
  92. const time = new Date();
  93. time.setDate(time.getDate() + 1919810);
  94. document.cookie = "version=1.4.1" + ";expires=" + time.toUTCString();
  95. //alert('new luogu 1.4!');
  96. //alert('更新:阉割了搜索功能(?)修复了部分bug');
  97. }
  98.  
  99. let changecolor = getcookie('color');
  100.  
  101. let tagchange = getcookie('tag');
  102. let tag = document.createElement("span");
  103. let tagcolor;
  104. if(changecolor != 'lg-fg-blue' && changecolor != 'lg-fg-orange'){
  105. tagcolor = changecolor.replace('fg','bg');
  106. tag.className = 'am-badge am-radius ' + tagcolor;
  107. }
  108. else if(changecolor == 'lg-fg-blue'){
  109. tagcolor = 'color-none';
  110. tag.className = 'am-badge am-radius ' + tagcolor;
  111. tag.style.background = 'rgb(52, 152, 219)';
  112. }
  113. else if(changecolor == 'lg-fg-orange'){
  114. tagcolor = 'color-none';
  115. tag.className = 'am-badge am-radius ' + tagcolor;
  116. tag.style.background = 'rgb(243, 156, 17)';
  117. }
  118. tag.textContent = tagchange;
  119.  
  120. //首页
  121. if(nowurl == 'https://www.luogu.com.cn/'){
  122. //日历
  123. const today=new Date();
  124. const year=today.getFullYear();
  125. const month=String(today.getMonth()+1);
  126. const day=String(today.getDate());
  127. console.log(year);
  128. console.log(month);
  129. console.log(day);
  130. let date_html='<h2>今天是 '+year+'-'+month+'-'+day+'</h2>';
  131. if(month==1&&day==1){
  132. date_html+='<h2>今天是元旦,新的一年,新的开始</h2>';
  133. }
  134. else if(month==2&&day==29){
  135. date_html+='<h2>今年是闰年</h2>';
  136. }
  137. else if(month==4&&day==1){
  138. date_html+='<h2>今天是愚人节</h2>';
  139. }
  140. else if(month==5&&day==1){
  141. date_html+='<h2>今天是劳动节</h2>';
  142. }
  143. else if(month==6&&day==1){
  144. date_html+='<h2>今天是儿童节</h2>';
  145. }
  146. else if(month==9&&day==10){
  147. date_html+='<h2>今天是教师节</h2>';
  148. }
  149. else if(month==10&&day==1){
  150. date_html+='<h2>今天是国庆节,七天小长假,启动!</h2>'
  151. }
  152. else if(month==12&&day==31){
  153. date_html+='<h2>明年见</h2>';
  154. }
  155. else{
  156. date_html+='<h2>欢迎!</h2>';
  157. }
  158. let date = document.createElement('div');
  159. date.className = 'lg-article';
  160. date.innerHTML = date_html;
  161. document.querySelector('div.lg-right > div:nth-child(1)').insertAdjacentElement('beforebegin', date);
  162.  
  163. //更改用户名颜色
  164. let color = document.querySelector('#app-old > div.lg-index-content.am-center > div:nth-child(1) > div > div > div > div.am-u-md-4.lg-punch.am-text-center > h2 > a');
  165. console.log(color);
  166. if(changecolor != 'null') color.className=changecolor;
  167.  
  168. function removeDivWithText(text) {
  169. document.querySelectorAll('div').forEach(div => {
  170. if(div.textContent === text) div.remove();
  171. });
  172. }
  173.  
  174. function findElement(element, text, cclass){
  175. document.querySelectorAll(element).forEach(E => {
  176. if(E.textContent === text) E.className = cclass;
  177. });
  178. }
  179.  
  180. removeDivWithText('暂无推荐');
  181. removeDivWithText('洛谷根据您近期的做题情况,使用机器学习自动为您推荐符合您目前程度的题目。本列表每日更新一次。');
  182.  
  183. GM_xmlhttpRequest({
  184. method: "GET",
  185. url: 'https://top.baidu.com/board?tab=realtime',
  186. onload: function(response){
  187. let rs = new DOMParser();
  188. let doc = rs.parseFromString(response.responseText, "text/html");
  189. for(let i=1;i<=5;i++){
  190. let th = i.toString();
  191. let selector = '#sanRoot > main > div.container.right-container_2EFJr > div > div:nth-child(2) > div:nth-child(' + th + ') > div.content_1YWBm > a > div.c-single-text-ellipsis';
  192. let _rs = doc.querySelector(selector);
  193. console.log(_rs.textContent);
  194. let selector2 = '#sanRoot > main > div.container.right-container_2EFJr > div > div:nth-child(2) > div:nth-child(' + th + ') > div.content_1YWBm > a';
  195. let rslink = doc.querySelector(selector2);
  196. console.log(rslink);
  197. let link = document.createElement("a");
  198. link.href = rslink.href;
  199. link.textContent = _rs.textContent;
  200. let RS = document.createElement("p");
  201. RS.appendChild(link);
  202. findElement('h2','智能推荐','zntj');
  203. document.getElementsByClassName('zntj')[0].parentNode.append(RS);
  204. }
  205. }
  206. });
  207. }
  208.  
  209. window.onload = function(){
  210. let _hanger = getcookie('hanger');
  211. let __hanger = document.createElementNS('http://www.w3.org/2000/svg','svg');
  212. __hanger.setAttribute('width','16');
  213. __hanger.setAttribute('height','16');
  214. __hanger.setAttribute('viewBox','0 0 16 16');
  215. __hanger.setAttribute('style','margin-bottom: -3px;');
  216.  
  217. if(_hanger == 'green') __hanger.setAttribute('fill','#5eb95e');
  218. else if(_hanger == 'blue') __hanger.setAttribute('fill','#3498db');
  219. else if(_hanger == 'golden') __hanger.setAttribute('fill','#f1c40f');
  220.  
  221. let ___hanger = document.createElementNS('http://www.w3.org/2000/svg','path');
  222. ___hanger.setAttribute('d','M16 8C16 6.84375 15.25 5.84375 14.1875 5.4375C14.6562 4.4375 14.4688 3.1875 13.6562 2.34375C12.8125 1.53125 11.5625 1.34375 10.5625 1.8125C10.1562 0.75 9.15625 0 8 0C6.8125 0 5.8125 0.75 5.40625 1.8125C4.40625 1.34375 3.15625 1.53125 2.34375 2.34375C1.5 3.1875 1.3125 4.4375 1.78125 5.4375C0.71875 5.84375 0 6.84375 0 8C0 9.1875 0.71875 10.1875 1.78125 10.5938C1.3125 11.5938 1.5 12.8438 2.34375 13.6562C3.15625 14.5 4.40625 14.6875 5.40625 14.2188C5.8125 15.2812 6.8125 16 8 16C9.15625 16 10.1562 15.2812 10.5625 14.2188C11.5938 14.6875 12.8125 14.5 13.6562 13.6562C14.4688 12.8438 14.6562 11.5938 14.1875 10.5938C15.25 10.1875 16 9.1875 16 8ZM11.4688 6.625L7.375 10.6875C7.21875 10.8438 7 10.8125 6.875 10.6875L4.5 8.3125C4.375 8.1875 4.375 7.96875 4.5 7.8125L5.3125 7C5.46875 6.875 5.6875 6.875 5.8125 7.03125L7.125 8.34375L10.1562 5.34375C10.3125 5.1875 10.5312 5.1875 10.6562 5.34375L11.4688 6.15625C11.5938 6.28125 11.5938 6.5 11.4688 6.625Z');
  223. __hanger.appendChild(___hanger);
  224. let _hanger_ = document.createElement("a");
  225. _hanger_.href = 'https://www.luogu.com/discuss/142324';
  226. _hanger_.appendChild(__hanger);
  227.  
  228. let button = document.createElement("div");
  229. button.innerHTML = '<button style=\"background-color: rgb\(94,114,228\);border-radius: 7px;color: white;border: none;padding: 7px 12px;text-align: center;text-decoration: none;display: inline-block;font-size: 16px;margin: 4px 2px;cursor: pointer;border: none;box-shadow: 2px 3px 7px #000;\">NEWLG</button>';
  230. if(nowurl == 'https://www.luogu.com.cn/' || nowurl == 'https://www.luogu.com.cn/chat' || nowurl.includes('https://www.luogu.com.cn/user/notification') || (nowurl.includes('https://www.luogu.com.cn/user/') && !nowurl.includes('https://www.luogu.com.cn/user/setting'))) document.querySelector('#app > div.main-container > div.wrapper.wrapped.lfe-body.header-layout.tiny > div.container > nav').insertAdjacentElement('beforebegin', button);
  231. let menu = document.createElement("div");
  232. menu.innerHTML = '<div class=\"newlgmenu\"><from class=\"NEWLG-menu\"><h2>v1.3.0</h2><h3>用户名颜色</h3><input type="text" placeholder="更改名字颜色为(如“紫名”“复原”)" id="nlcolor"><button>提交</button><h3>勾子<h3><button><svg xmlns="http://www.w3.org/2000/svg" width="50" height="50" viewBox="0 0 16 16" fill="#5eb95e" style="margin-bottom: -3px;"><path d="M16 8C16 6.84375 15.25 5.84375 14.1875 5.4375C14.6562 4.4375 14.4688 3.1875 13.6562 2.34375C12.8125 1.53125 11.5625 1.34375 10.5625 1.8125C10.1562 0.75 9.15625 0 8 0C6.8125 0 5.8125 0.75 5.40625 1.8125C4.40625 1.34375 3.15625 1.53125 2.34375 2.34375C1.5 3.1875 1.3125 4.4375 1.78125 5.4375C0.71875 5.84375 0 6.84375 0 8C0 9.1875 0.71875 10.1875 1.78125 10.5938C1.3125 11.5938 1.5 12.8438 2.34375 13.6562C3.15625 14.5 4.40625 14.6875 5.40625 14.2188C5.8125 15.2812 6.8125 16 8 16C9.15625 16 10.1562 15.2812 10.5625 14.2188C11.5938 14.6875 12.8125 14.5 13.6562 13.6562C14.4688 12.8438 14.6562 11.5938 14.1875 10.5938C15.25 10.1875 16 9.1875 16 8ZM11.4688 6.625L7.375 10.6875C7.21875 10.8438 7 10.8125 6.875 10.6875L4.5 8.3125C4.375 8.1875 4.375 7.96875 4.5 7.8125L5.3125 7C5.46875 6.875 5.6875 6.875 5.8125 7.03125L7.125 8.34375L10.1562 5.34375C10.3125 5.1875 10.5312 5.1875 10.6562 5.34375L11.4688 6.15625C11.5938 6.28125 11.5938 6.5 11.4688 6.625Z"></path></svg></button><button><svg xmlns="http://www.w3.org/2000/svg" width="50" height="50" viewBox="0 0 16 16" fill="#3498db" style="margin-bottom: -3px;"><path d="M16 8C16 6.84375 15.25 5.84375 14.1875 5.4375C14.6562 4.4375 14.4688 3.1875 13.6562 2.34375C12.8125 1.53125 11.5625 1.34375 10.5625 1.8125C10.1562 0.75 9.15625 0 8 0C6.8125 0 5.8125 0.75 5.40625 1.8125C4.40625 1.34375 3.15625 1.53125 2.34375 2.34375C1.5 3.1875 1.3125 4.4375 1.78125 5.4375C0.71875 5.84375 0 6.84375 0 8C0 9.1875 0.71875 10.1875 1.78125 10.5938C1.3125 11.5938 1.5 12.8438 2.34375 13.6562C3.15625 14.5 4.40625 14.6875 5.40625 14.2188C5.8125 15.2812 6.8125 16 8 16C9.15625 16 10.1562 15.2812 10.5625 14.2188C11.5938 14.6875 12.8125 14.5 13.6562 13.6562C14.4688 12.8438 14.6562 11.5938 14.1875 10.5938C15.25 10.1875 16 9.1875 16 8ZM11.4688 6.625L7.375 10.6875C7.21875 10.8438 7 10.8125 6.875 10.6875L4.5 8.3125C4.375 8.1875 4.375 7.96875 4.5 7.8125L5.3125 7C5.46875 6.875 5.6875 6.875 5.8125 7.03125L7.125 8.34375L10.1562 5.34375C10.3125 5.1875 10.5312 5.1875 10.6562 5.34375L11.4688 6.15625C11.5938 6.28125 11.5938 6.5 11.4688 6.625Z"></path></svg></button><button><svg xmlns="http://www.w3.org/2000/svg" width="50" height="50" viewBox="0 0 16 16" fill="#f1c40f" style="margin-bottom: -3px;"><path d="M16 8C16 6.84375 15.25 5.84375 14.1875 5.4375C14.6562 4.4375 14.4688 3.1875 13.6562 2.34375C12.8125 1.53125 11.5625 1.34375 10.5625 1.8125C10.1562 0.75 9.15625 0 8 0C6.8125 0 5.8125 0.75 5.40625 1.8125C4.40625 1.34375 3.15625 1.53125 2.34375 2.34375C1.5 3.1875 1.3125 4.4375 1.78125 5.4375C0.71875 5.84375 0 6.84375 0 8C0 9.1875 0.71875 10.1875 1.78125 10.5938C1.3125 11.5938 1.5 12.8438 2.34375 13.6562C3.15625 14.5 4.40625 14.6875 5.40625 14.2188C5.8125 15.2812 6.8125 16 8 16C9.15625 16 10.1562 15.2812 10.5625 14.2188C11.5938 14.6875 12.8125 14.5 13.6562 13.6562C14.4688 12.8438 14.6562 11.5938 14.1875 10.5938C15.25 10.1875 16 9.1875 16 8ZM11.4688 6.625L7.375 10.6875C7.21875 10.8438 7 10.8125 6.875 10.6875L4.5 8.3125C4.375 8.1875 4.375 7.96875 4.5 7.8125L5.3125 7C5.46875 6.875 5.6875 6.875 5.8125 7.03125L7.125 8.34375L10.1562 5.34375C10.3125 5.1875 10.5312 5.1875 10.6562 5.34375L11.4688 6.15625C11.5938 6.28125 11.5938 6.5 11.4688 6.625Z"></path></svg></button><button><svg xmlns="http://www.w3.org/2000/svg" width="50" height="50" viewBox="0 0 50 50" overflow="visible" stroke="red" stroke-width="10" stroke-linecap="round"><line x2="50" y2="50" fill="red"/><line x1="50" y2="50" fill="red"/></svg></button><h2>Tag</h2><input type="text" id="nltag" placeholder="无输入以取消,长度不超过10"><button>提交</button></from></div>';
  233. document.querySelector("#app > div.main-container > div.wrapper.wrapped.lfe-body.header-layout.tiny > div.container").parentNode.append(menu);
  234. const tb = document.querySelector('#app > div.main-container > div.wrapper.wrapped.lfe-body.header-layout.tiny > div.container > div:nth-child(3) > button');
  235. let menudisplay = document.querySelector('#app > div.main-container > div.wrapper.wrapped.lfe-body.header-layout.tiny > div:nth-child(3) > div');
  236.  
  237. function reloadmenu(){
  238. location.reload();
  239. menudisplay.style.display = 'flex';
  240. document.body.style.overflow = 'hidden';
  241. tb.textContent = "EXIT";
  242. }
  243.  
  244. tb.addEventListener('click', function(){
  245. if(menudisplay.style.display == 'none'){
  246. menudisplay.style.display = 'flex';
  247. document.body.style.overflow = 'hidden';
  248. tb.textContent = "EXIT";
  249. }
  250. else{
  251. menudisplay.style.display = 'none';
  252. document.body.style.overflow = 'visible';
  253. tb.textContent = "NEWLG";
  254. }
  255.  
  256. const submitcolor = document.querySelector('#app > div.main-container > div.wrapper.wrapped.lfe-body.header-layout.tiny > div:nth-child(3) > div > from > button');
  257. const greenhanger = document.querySelector('#app > div.main-container > div.wrapper.wrapped.lfe-body.header-layout.tiny > div:nth-child(3) > div > from > h3:nth-child(6) > button:nth-child(1)');
  258. const bluehanger = document.querySelector('#app > div.main-container > div.wrapper.wrapped.lfe-body.header-layout.tiny > div:nth-child(3) > div > from > h3:nth-child(6) > button:nth-child(2)');
  259. const goldenhanger = document.querySelector('#app > div.main-container > div.wrapper.wrapped.lfe-body.header-layout.tiny > div:nth-child(3) > div > from > h3:nth-child(6) > button:nth-child(3)');
  260. const nullhanger = document.querySelector('#app > div.main-container > div.wrapper.wrapped.lfe-body.header-layout.tiny > div:nth-child(3) > div > from > h3:nth-child(6) > button:nth-child(4)');
  261.  
  262. submitcolor.addEventListener('click', function(){
  263. let colorchange = document.getElementById('nlcolor').value;
  264. console.log(colorchange);
  265. if(colorchange=='灰名'){
  266. const time = new Date();
  267. time.setDate(time.getDate() + 365);
  268. document.cookie = "color=lg-fg-gray" + ";expires=" + time.toUTCString();
  269. reloadmenu();
  270. }
  271. else if(colorchange=='蓝名'){
  272. const time = new Date();
  273. time.setDate(time.getDate() + 365);
  274. document.cookie = "color=lg-fg-blue" + ";expires=" + time.toUTCString();
  275. reloadmenu();
  276. }
  277. else if(colorchange=='绿名'){
  278. const time = new Date();
  279. time.setDate(time.getDate() + 365);
  280. document.cookie = "color=lg-fg-green" + ";expires=" + time.toUTCString();
  281. reloadmenu();
  282. }
  283. else if(colorchange=='橙名'){
  284. const time = new Date();
  285. time.setDate(time.getDate() + 365);
  286. document.cookie = "color=lg-fg-orange" + ";expires=" + time.toUTCString();
  287. reloadmenu();
  288. }
  289. else if(colorchange=='红名'){
  290. const time = new Date();
  291. time.setDate(time.getDate() + 365);
  292. document.cookie = "color=lg-fg-red" + ";expires=" + time.toUTCString();
  293. reloadmenu();
  294. }
  295. else if(colorchange=='紫名'){
  296. const time = new Date();
  297. time.setDate(time.getDate() + 365);
  298. document.cookie = "color=lg-fg-purple" + ";expires=" + time.toUTCString();
  299. reloadmenu();
  300. }
  301. else if(colorchange=='复原'){
  302. const time = new Date();
  303. time.setDate(time.getDate() + 365);
  304. document.cookie = "color=" + nowcolor + ";expires=" + time.toUTCString();
  305. reloadmenu();
  306. }
  307. });
  308. greenhanger.addEventListener('click', function(){
  309. const time = new Date();
  310. time.setDate(time.getDate() + 365);
  311. document.cookie = "hanger=green" + ";expires=" + time.toUTCString();
  312. reloadmenu();
  313. });
  314. bluehanger.addEventListener('click', function(){
  315. const time = new Date();
  316. time.setDate(time.getDate() + 365);
  317. document.cookie = "hanger=blue" + ";expires=" + time.toUTCString();
  318. reloadmenu();
  319. });
  320. goldenhanger.addEventListener('click', function(){
  321. const time = new Date();
  322. time.setDate(time.getDate() + 365);
  323. document.cookie = "hanger=golden" + ";expires=" + time.toUTCString();
  324. reloadmenu();
  325. });
  326. nullhanger.addEventListener('click',function(){
  327. const time = new Date();
  328. time.setDate(time.getDate() + 365);
  329. document.cookie = "hanger=null" + ";expires=" + time.toUTCString();
  330. reloadmenu();
  331. });
  332.  
  333. const submittag = document.querySelector('#app > div.main-container > div.wrapper.wrapped.lfe-body.header-layout.tiny > div:nth-child(3) > div > from > button:nth-child(9)');
  334. submittag.addEventListener('click', function(){
  335. let tagchange = document.getElementById('nltag').value;
  336. const time = new Date();
  337. time.setDate(time.getDate() + 365);
  338. document.cookie = "tag=" + tagchange + ";expires=" + time.toUTCString();
  339. reloadmenu();
  340. });
  341. });
  342. if(nowurl == 'https://www.luogu.com.cn/'){
  343. if(getcookie('hanger')!='null'){
  344. document.querySelector('#app-old > div.lg-index-content.am-center > div:nth-child(1) > div > div > div > div.am-u-md-4.lg-punch.am-text-center > h2 > a').innerHTML += '&nbsp;';
  345. document.querySelector('#app-old > div.lg-index-content.am-center > div:nth-child(1) > div > div > div > div.am-u-md-4.lg-punch.am-text-center > h2 > a').appendChild(_hanger_);
  346. }
  347. if(getcookie('tag')!='null'){
  348. document.querySelector('#app-old > div.lg-index-content.am-center > div:nth-child(1) > div > div > div > div.am-u-md-4.lg-punch.am-text-center > h2 > a').innerHTML += '&nbsp;';
  349. document.querySelector('#app-old > div.lg-index-content.am-center > div:nth-child(1) > div > div > div > div.am-u-md-4.lg-punch.am-text-center > h2 > a').appendChild(tag);
  350. }
  351. }
  352. else if(nowurl.includes('https://www.luogu.com.cn/user/')&&!nowurl.includes('https://www.luogu.com.cn/user/setting')){
  353. if(document.querySelector('#app > div.main-container > main > div > div.full-container > section.main > div > div:nth-child(2)').className == 'introduction marked') document.querySelector('#app > div.main-container > main > div > div.full-container > section.main > div > div:nth-child(2)').removeAttribute('style');
  354. else document.querySelector('#app > div.main-container > main > div > div.full-container > section.main > div > div:nth-child(2)').remove();
  355. let jieshao = document.querySelector('#app > div.main-container > main > div > div.full-container > section.main > div > div.introduction.marked');
  356. if(jieshao.style.display == 'none') jieshao.removeAttribute('style');
  357. }
  358. };
  359. })();