leetcode-hide-locked

hide locked problems in LeetCode

目前為 2016-09-24 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

/* eslint-env greasemonkey, browser */
// ==UserScript==
// @name         leetcode-hide-locked
// @namespace    weibo.com/flowmemo
// @version      0.1.4
// @description  hide locked problems in LeetCode
// @author       flowmemo
// @match        https://leetcode.com/problemset/*
// @grant        none
// @license      MIT
// @supportURL   https://github.com/flowmemo/leetcode-hide-locked
// ==/UserScript==

;(function () {
  'use strict'
  function removeLocked () {
    const all = document.querySelectorAll('tbody.reactable-data tr')
    Array.prototype.forEach.call(all, tr => { tr.style.display = '' })
    const locked = document.querySelectorAll('tbody.reactable-data .fa-lock')
    Array.prototype.forEach.call(locked, item => {
      const tr = item.parentElement.parentElement.parentElement
      if (tr.tagName === 'TR') tr.style.display = 'none'
    })
  }
  const problemList = document.querySelector('div[data-reactroot]')
  const observer = new MutationObserver(removeLocked)
  observer.observe(problemList, { childList: true, subtree: true })
  removeLocked()
})()