When2Meet User Filter with Styling

Source: https://gist.github.com/Ulyssys/160e12ed2f14c0dadf0ee769a474d19b

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name        When2Meet User Filter with Styling
// @namespace   Violentmonkey Scripts
// @match       https://www.when2meet.com/*
// @grant       none
// @version     1.0
// @author      ulyssys
// @description Source: https://gist.github.com/Ulyssys/160e12ed2f14c0dadf0ee769a474d19b
// @grant GM_addStyle
// ==/UserScript==

// paste this into your browser console when looking at when2meet results
if (!window.OrigAvailableAtSlot) window.OrigAvailableAtSlot = AvailableAtSlot;
if (!window.OrigAvailableIDs) window.OrigAvailableIDs = AvailableIDs;
let nameFilter;
if ((nameFilter = document.getElementById("NameFilter"))) nameFilter.remove();
nameFilter = document.createElement("ul");
nameFilter.id = "NameFilter";
document.getElementById("LeftPanel").appendChild(nameFilter);
const idOn = (id) => document.getElementById(id).checked;
for (let i = 0; i < PeopleNames.length; i++) {
  const li = document.createElement("li");
  li.innerHTML =
    `<input type="checkbox" id="${PeopleIDs[i]}" checked>` +
    `&nbsp;<label for="${PeopleIDs[i]}">${PeopleNames[i]}</label>`;
  nameFilter.appendChild(li);
  li.addEventListener("change", () => {
    AvailableIDs = OrigAvailableIDs.filter(idOn);
    AvailableAtSlot = OrigAvailableAtSlot.map((avail) => avail.filter(idOn));
    ReColorGroup();
  });
}

GM_addStyle (`
.HalfPanel ul li {
    text-align: left !important;
}
`)