V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
Vegetable
V2EX  ›  问与答

开发个插件显示 [今日已在 V2EX 浪费 180 分钟] 怎么样?

  •  
  •   Vegetable · 2020-07-03 12:56:21 +08:00 · 870 次点击
    这是一个创建于 1598 天前的主题,其中的信息可能已经有所发展或是发生改变。

    一天天的太划了,活跃度那个条已经溢出去了

    第 1 条附言  ·  2020-07-03 14:28:56 +08:00

    嗯...不知道有没有bug

    visibleState为visible的页面,每3秒向localstorage插入一次truncate之后的时间,再根据标记个数记录页面活跃的时间。
    显示到活跃度下边,与进度条颜色相同。

    // ==UserScript==
    // @name         V2EX Timer
    // @namespace    http://tampermonkey.net/
    // @version      0.1
    // @description  该干活了亲
    // @author       Anonymous
    // @match        https://*.v2ex.com/*
    // @grant        none
    // ==/UserScript==
    
    const SET_CACHE_KEY = 'V2EX_WASTE_SET';
    const DATE_CACHE_KEY = 'V2EX_WASTE_DATE';
    function tick() {
        if (document.visibilityState !== 'visible') {
            //invisible
            return
        }
        const now = new Date()
        const cache_date = localStorage.getItem(DATE_CACHE_KEY)
        if (cache_date != now.toLocaleDateString()) {
            //today is a good day
            localStorage.setItem(DATE_CACHE_KEY, now.toLocaleDateString())
            localStorage.setItem(SET_CACHE_KEY, '[]')
        }
        const set = new Set(JSON.parse(localStorage.getItem(SET_CACHE_KEY)))
        const flag = now.getTime() - now.getTime() % 6000 // record every 6 seconds
        set.add(flag)
        localStorage.setItem(SET_CACHE_KEY, JSON.stringify(Array.from(set)))
    }
    
    function render_node(minutes) {
        const origin_bar = document.getElementById('member-activity')
        const div = document.createElement('div')
        const span = document.createElement('span')
        span.innerHTML = `今日已在V2EX浪费${minutes}分钟`
        span.style.color = window.getComputedStyle(origin_bar.firstElementChild.firstElementChild).backgroundColor
        span.style.fontWeight = 700
        div.append(span)
        origin_bar.append(div)
    
    }
    
    
    (function () {
        'use strict';
        tick()
        setInterval(tick, 3000)
        const len = JSON.parse(localStorage.getItem(SET_CACHE_KEY)).length
        render_node(len / 10)
    })();
    
    3 条回复    2020-07-03 13:13:24 +08:00
    ipadpro4k
        1
    ipadpro4k  
       2020-07-03 13:07:24 +08:00 via iPhone
    这和香烟包装上写个吸烟有害健康有啥区别
    Procumbens
        2
    Procumbens  
       2020-07-03 13:11:20 +08:00   ❤️ 1
    逛 V 站的时间 能叫浪费么🐶
    d5
        3
    d5  
       2020-07-03 13:13:24 +08:00
    学习老哥们的生活、生产经验,以后少踩坑,不觉得是浪费时间,超值 哈哈哈
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3670 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 19ms · UTC 04:23 · PVG 12:23 · LAX 20:23 · JFK 23:23
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.