腾讯课堂签到提醒

腾讯课堂签到时弹出通知,可配置自动签到

  1. // ==UserScript==
  2. // @name 腾讯课堂签到提醒
  3. // @namespace http://tampermonkey.net/
  4. // @version 2.1
  5. // @description 腾讯课堂签到时弹出通知,可配置自动签到
  6. // @author askar882
  7. // @match https://ke.qq.com/webcourse/*
  8. // @icon 
  9. // @grant none
  10. // @run-at document-idle
  11. // ==/UserScript==
  12.  
  13. /* jshint esversion: 6, browser: true */
  14.  
  15. (function() {
  16. 'use strict';
  17.  
  18. // 启用自动签到
  19. const AUTO_SIGN_ENABLED = false;
  20.  
  21. // 日志
  22. // const log = (...msg) => console.info(`%c${new Date().toISOString()} 腾讯课堂签到 `, 'color: blue;', ...msg);
  23.  
  24. // 使用Notification API弹出通知
  25. const notify = (title, body, { tag = "", requireInteraction = true, callback = null } = {}) => {
  26. const createNotification = () => {
  27. const notification = new Notification(title, { body, tag, requireInteraction });
  28. notification.addEventListener('click', () => {
  29. window.focus();
  30. notification.close();
  31. });
  32. if (callback) {
  33. notification.addEventListener('click', callback);
  34. }
  35. };
  36. if(Notification.permission === 'granted' && title) {
  37. createNotification();
  38. } else {
  39. Notification.requestPermission().then(permission => {
  40. if(permission === 'granted' && title) {
  41. createNotification();
  42. }
  43. });
  44. }
  45. };
  46. // Unix时间戳
  47. const getTime = () => Math.floor(new Date().getTime() / 1000);
  48. // 签到弹窗父元素
  49. const wrapper = document.getElementById('react-body');
  50. // 签到按钮
  51. const signButton = () => document.querySelector('#react-body > div.sign-dialog > div.im-dialog-wrap > div > div.btn-group > span');
  52. // 自动签到
  53. const autoSign = () => {
  54. if (signButton()) {
  55. signButton().click();
  56. }
  57. };
  58. // 最近一次签到时间,用于对通知进行节流
  59. let lastSignTime = getTime();
  60. // MutationObserver侦听器
  61. const wrapperMutation = () => {
  62. // 判断签到按钮是否存在
  63. if(signButton() && (getTime() - lastSignTime > 30)) {
  64. // log('签到');
  65. if (AUTO_SIGN_ENABLED) {
  66. autoSign();
  67. notify('腾讯课堂', '已完成自动签到', { callback: autoSign });
  68. } else {
  69. notify('腾讯课堂', '签到');
  70. }
  71. lastSignTime = getTime();
  72. }
  73. };
  74. // 按需申请通知权限
  75. if (Notification.permission !== 'granted') {
  76. notify(null, null);
  77. }
  78. const wrapperObserver = new MutationObserver(wrapperMutation);
  79. // 观察DOM树的父元素所有子孙节点的新增和删除
  80. wrapperObserver.observe(wrapper, {attributes: false, childList: true, subtree: true});
  81. })();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址