๐Ÿ˜ดๆ้ซ˜ๆฑ‰ๅŒ–็ฒพๅ‡†ๅบฆ๏ผŒๅผบ่ฐƒ็‰ˆๆƒๅฃฐๆ˜Ž

This commit is contained in:
2024-07-26 01:23:01 +08:00
parent da08f8d085
commit 3ede8f710d
23 changed files with 657 additions and 183 deletions

View File

@ -29,6 +29,7 @@
- ๆ„Ÿ่ฐข[NoneBot2](https://nonebot.dev)ๆไพ›็š„ๆก†ๆžถๆ”ฏๆŒ
- ๆ„Ÿ่ฐข[nonebot-plugin-htmlrender](https://github.com/kexue-z/nonebot-plugin-htmlrender)ๆไพ›็š„ๆธฒๆŸ“ๅŠŸ่ƒฝ
- ่ฎจๅŽŒไธŠ่ฟฐ้กน็›ฎๆไพ›็š„**ๅŸบไบŽ Chromium ๆต่งˆๅ™จ**็š„ HTML ๆธฒๆŸ“ๅŠŸ่ƒฝ๏ผŒๅฐฑๅŠŸ่ƒฝๆœฌ่บซ่€Œ่จ€ๅพˆๅฅฝ๏ผŒไฝ†ๆˆ‘่ฎจๅŽŒไธ€ๅฃฐไธๅ“ๅœจๆˆ‘็”ต่„‘้‡Œ่ฃ…ๆต่งˆๅ™จ่ฟ™ไธช่กŒไธบ๏ผŒ่™ฝ็„ถ่ฟ™ๅนถไธๅฆจ็ขๆˆ‘ๆ„Ÿ่ฐขไน‹ โ€”โ€”้‡‘็พฟ
- ๆ„Ÿ่ฐข[nonebot-plugin-alconna](https://github.com/ArcletProject/nonebot-plugin-alconna)ๆไพ›็š„ๅ‘ฝไปค่งฃๆžๅŠŸ่ƒฝ
- ๅๅˆ†ๆ„Ÿ่ฐข[็ฅž็พฝ SnowyKami](https://github.com/snowykami)ๆไพ›็š„ๆŠ€ๆœฏๆŒ‡ๅฏผๅ’ŒๆœๅŠกๅ™จ่ต„ๆบ
- ็‰นๅˆซๆ„Ÿ่ฐข[ไบ‘่ฃณๅทฅไฝœๅฎค](https://doc.ysmcc.cn/doc/1/)ๆไพ›็š„ๆœๅŠกๅ™จๆŒ‚่ฝฝ
@ -39,8 +40,8 @@
ๆœฌ็‰นๅฎš็‰ˆๆœฌ็š„ ่ฝป้›ชๆœบๅ™จไบบ ไปฅ ๆฑ‰็މๅพ‹่ฎธๅฏๅ่ฎฎ ๆŽˆๆƒๅผ€ๆบ\
ๅ…ผๅฎนๅนถ็ปงๆ‰ฟ่‡ช LSO license (LiteyukiStudio Opensource license)
็‰ˆๆƒๆ‰€ๆœ‰ ยฉ 2024 SnowyKami & EillesWan
็‰ˆๆƒๆ‰€ๆœ‰ ยฉ 2024 ็ฅž็พฝ SnowyKami & ้‡‘็พฟ Eilles\
ไฟ็•™ๆ‰€ๆœ‰ๆƒๅˆฉ
่ฝป้›ชๆœบๅ™จไบบ็ฟไนๅฎšๅˆถ็‰ˆ(LiteyukiBot-TriMO)ๆ นๆฎ ็ฌฌไธ€็‰ˆ ๆฑ‰้’ฐๅพ‹่ฎธๅฏๅ่ฎฎ๏ผˆโ€œๆœฌๅ่ฎฎโ€๏ผ‰ๆŽˆๆƒใ€‚\
ไปปไฝ•ไบบ็š†ๅฏไปŽไปฅไธ‹ๅœฐๅ€่Žทๅพ—ๆœฌๅ่ฎฎๅ‰ฏๆœฌ๏ผš[ๆฑ‰้’ฐๅพ‹่ฎธๅฏๅ่ฎฎ ็ฌฌไธ€็‰ˆ](https://gitee.com/EillesWan/YulvLicenses/raw/master/%E6%B1%89%E9%92%B0%E5%BE%8B%E8%AE%B8%E5%8F%AF%E5%8D%8F%E8%AE%AE/%E6%B1%89%E9%92%B0%E5%BE%8B%E8%AE%B8%E5%8F%AF%E5%8D%8F%E8%AE%AE.MD)ใ€‚\

View File

@ -34,20 +34,6 @@ class LiteyukiBot:
self.lifespan: Lifespan = Lifespan()
self.init(**self.config) # ๅˆๅง‹ๅŒ–
print("\033[34m" + r"""
โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–ˆโ–ˆ โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–ˆโ–ˆ โ–ˆโ–ˆ โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–ˆโ–ˆ
โ–› โ–ˆโ–ˆ โ–ˆโ–ˆ โ–› โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ
โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–… โ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ
โ–ˆโ–ˆ โ–ˆโ–ˆ โ–…โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–› โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ
โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–… โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆ โ–ˆ โ–œโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–› โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ
""" + "\033[0m")
def run(self, *args, **kwargs):
if _MAIN_PROCESS:

View File

@ -1,6 +1,9 @@
# -*- coding: utf-8 -*-
"""
Copyright (C) 2020-2024 LiteyukiStudio. All Rights Reserved
Copyright (C) 2020-2024 LiteyukiStudio. All rights reserved
็‰ˆๆƒๆ‰€ๆœ‰ ยฉ 2020-2024 ็ฅž็พฝSnowyKami & ้‡‘็พฟEilles with LiteyukiStudio & TriM Org.
ไฟ็•™ๆ‰€ๆœ‰ๆƒๅˆฉ
@Time : 2024/7/23 ไธ‹ๅˆ8:24
@Author : snowykami

View File

@ -1,6 +1,9 @@
# -*- coding: utf-8 -*-
"""
Copyright (C) 2020-2024 LiteyukiStudio. All Rights Reserved
Copyright (C) 2020-2024 LiteyukiStudio. All rights reserved
็‰ˆๆƒๆ‰€ๆœ‰ ยฉ 2020-2024 ็ฅž็พฝSnowyKami & ้‡‘็พฟEilles with LiteyukiStudio & TriM Org.
ไฟ็•™ๆ‰€ๆœ‰ๆƒๅˆฉ
@Time : 2024/7/23 ไธ‹ๅˆ11:59
@Author : snowykami

View File

@ -1,6 +1,9 @@
# -*- coding: utf-8 -*-
"""
Copyright (C) 2020-2024 LiteyukiStudio. All Rights Reserved
Copyright (C) 2020-2024 LiteyukiStudio. All rights reserved
็‰ˆๆƒๆ‰€ๆœ‰ ยฉ 2020-2024 ็ฅž็พฝSnowyKami & ้‡‘็พฟEilles with LiteyukiStudio & TriM Org.
ไฟ็•™ๆ‰€ๆœ‰ๆƒๅˆฉ
@Time : 2024/7/23 ไธ‹ๅˆ11:59
@Author : snowykami

View File

@ -1,6 +1,9 @@
# -*- coding: utf-8 -*-
"""
Copyright (C) 2020-2024 LiteyukiStudio. All Rights Reserved
Copyright (C) 2020-2024 LiteyukiStudio. All rights reserved
็‰ˆๆƒๆ‰€ๆœ‰ ยฉ 2020-2024 ็ฅž็พฝSnowyKami & ้‡‘็พฟEilles with LiteyukiStudio & TriM Org.
ไฟ็•™ๆ‰€ๆœ‰ๆƒๅˆฉ
@Time : 2024/7/24 ไธŠๅˆ12:02
@Author : snowykami

View File

@ -1,6 +1,9 @@
# -*- coding: utf-8 -*-
"""
Copyright (C) 2020-2024 LiteyukiStudio. All Rights Reserved
Copyright (C) 2020-2024 LiteyukiStudio. All rights reserved
็‰ˆๆƒๆ‰€ๆœ‰ ยฉ 2020-2024 ็ฅž็พฝSnowyKami & ้‡‘็พฟEilles with LiteyukiStudio & TriM Org.
ไฟ็•™ๆ‰€ๆœ‰ๆƒๅˆฉ
@Time : 2024/7/23 ไธ‹ๅˆ11:21
@Author : snowykami

View File

@ -18,6 +18,28 @@ __plugin_meta__ = PluginMetadata(
from ..utils.base.language import Language, get_default_lang_code
print(
"\033[34m"
+ r"""
โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–ˆโ–ˆ โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–ˆโ–ˆ โ–ˆโ–ˆ โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–ˆโ„ข
โ–› โ–ˆโ–ˆ โ–ˆโ–ˆ โ–› โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ
โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–… โ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ
โ–ˆโ–ˆ โ–ˆโ–ˆ โ–…โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–› โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ
โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–… โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–…โ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆ โ–ˆ โ–œโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–› โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ โ–ˆโ–ˆ
โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆ โ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆโ–ˆ
ๅ•†ๆ ‡ๆ ‡่ฎฐ ยฉ 2024 ้‡‘็พฟEilles
็‰ˆๆƒๆ‰€ๆœ‰ ยฉ 2020-2024 ็ฅž็พฝSnowyKami & ้‡‘็พฟEilles\\
with LiteyukiStudio & TriM Org.
ไฟ็•™ๆ‰€ๆœ‰ๆƒๅˆฉ
"""
+ "\033[0m"
)
sys_lang = Language(get_default_lang_code())
nonebot.logger.info(

View File

@ -17,11 +17,7 @@ async def count_msg_by_bot_id(bot_id: str) -> int:
condition = " AND bot_id = ?"
condition_args = [bot_id]
msg_rows = msg_db.where_all(
MessageEventModel(),
condition,
*condition_args
)
msg_rows = msg_db.where_all(MessageEventModel(), condition, *condition_args)
return len(msg_rows)
@ -32,7 +28,7 @@ async def get_stat_msg_image(
group_id: str = None,
bot_id: str = None,
user_id: str = None,
ulang: Language = Language()
ulang: Language = Language(),
) -> bytes:
"""
่Žทๅ–็ปŸ่ฎกๆถˆๆฏ
@ -48,7 +44,7 @@ async def get_stat_msg_image(
tuple: [int,], [int,] ไธคไธชๅˆ—่กจ๏ผŒๅˆ†ๅˆซไธบๅ‘จๆœŸไธญๅฟƒๆ—ถ้—ดๆˆณๅ’Œๆถˆๆฏๆ•ฐ้‡
"""
now = int(time.time())
start_time = (now - duration)
start_time = now - duration
condition = "time > ?"
condition_args = [start_time]
@ -64,11 +60,7 @@ async def get_stat_msg_image(
condition += " AND user_id = ?"
condition_args.append(user_id)
msg_rows = msg_db.where_all(
MessageEventModel(),
condition,
*condition_args
)
msg_rows = msg_db.where_all(MessageEventModel(), condition, *condition_args)
timestamps = []
msg_count = []
msg_rows.sort(key=lambda x: x.time)
@ -88,12 +80,16 @@ async def get_stat_msg_image(
templates = {
"data": [
{
"name" : ulang.get("stat.message")
+ f" Period {convert_seconds_to_time(period)}" + f" Duration {convert_seconds_to_time(duration)}"
+ (f" Group {group_id}" if group_id else "") + (f" Bot {bot_id}" if bot_id else "") + (
f" User {user_id}" if user_id else ""),
"name": "ไปฅ{}ไธบๅˆ†ๅ‰ฒ๏ผŒๅœจ{}่Œƒๅ›ดๅ†…็š„ {}".format(
convert_seconds_to_time(period),
convert_seconds_to_time(duration),
ulang.get("stat.message"),
)
+ (f" ็พค่Š๏ผš{group_id}" if group_id else "")
+ (f" ๆœบๅ™จ๏ผš{bot_id}" if bot_id else "")
+ (f" ็”จๆˆท๏ผš{user_id}" if user_id else ""),
"times": timestamps,
"counts": msg_count
"counts": msg_count,
}
]
}
@ -129,11 +125,7 @@ async def get_stat_rank_image(
condition += " AND time > ?"
condition_args.append(v)
msg_rows = msg_db.where_all(
MessageEventModel(),
condition,
*condition_args
)
msg_rows = msg_db.where_all(MessageEventModel(), condition, *condition_args)
"""
{
@ -153,20 +145,24 @@ async def get_stat_rank_image(
{
"name": _[0],
"count": _[1],
"icon" : await (get_group_icon(platform="qq", group_id=_[0]) if rank_type == "group" else get_user_icon(
platform="qq", user_id=_[0]
))
"icon": await (
get_group_icon(platform="qq", group_id=_[0])
if rank_type == "group"
else get_user_icon(platform="qq", user_id=_[0])
),
}
for _ in sorted_data[0 : min(len(sorted_data), limit["rank"])]
]
templates = {
"data":
{
"name" : ulang.get("stat.rank") + f" Type {rank_type}" + f" Limit {limit}",
"ranking": ranking
"data": {
"name": ulang.get("stat.rank")
+ f" ็ฑปๅˆซ๏ผš{rank_type}"
+ f" ๅˆถ็บฆ๏ผš{limit}",
"ranking": ranking,
}
}
}
return await template2image(get_path("templates/stat_rank.html"), templates, debug=True)
return await template2image(
get_path("templates/stat_rank.html"), templates, debug=True
)

View File

@ -15,7 +15,7 @@ from nonebot_plugin_alconna import (
Subcommand,
Arparma,
Option,
MultiVar
MultiVar,
)
stat_msg = on_alconna(
@ -40,17 +40,11 @@ stat_msg = on_alconna(
help_text="ๆ˜ฏๅฆๆŒ‡ๅฎšๆœบๅ™จไบบ",
),
Option(
"-g|--group",
Args["group_id", str, "current"],
help_text="ๆŒ‡ๅฎš็พค็ป„"
),
Option(
"-u|--user",
Args["user_id", str, "current"],
help_text="ๆŒ‡ๅฎš็”จๆˆท"
"-g|--group", Args["group_id", str, "current"], help_text="ๆŒ‡ๅฎš็พค็ป„"
),
Option("-u|--user", Args["user_id", str, "current"], help_text="ๆŒ‡ๅฎš็”จๆˆท"),
alias={"msg", "m"},
help_text="ๆŸฅ็œ‹็ปŸ่ฎกๆฌกๆ•ฐๅ†…็š„ๆถˆๆฏ"
help_text="ๆŸฅ็œ‹็ปŸ่ฎกๆฌกๆ•ฐๅ†…็š„ๆถˆๆฏ",
),
Subcommand(
"rank",
@ -78,9 +72,9 @@ stat_msg = on_alconna(
help_text="ๆŒ‡ๅฎšๆŽ’ๅ",
),
alias={"r"},
)
),
aliases={"stat"}
),
aliases={"stat"},
)
@ -88,10 +82,14 @@ stat_msg = on_alconna(
async def _(result: Arparma, event: T_MessageEvent, bot: Bot):
ulang = Language(event_utils.get_user_id(event))
try:
duration = convert_time_to_seconds(result.other_args.get("duration", "2d")) # ็ง’ๆ•ฐ
duration = convert_time_to_seconds(
result.other_args.get("duration", "2d")
) # ็ง’ๆ•ฐ
period = convert_time_to_seconds(result.other_args.get("period", "1m"))
except BaseException as e:
await stat_msg.send(ulang.get("liteyuki.invalid_command", TEXT=str(e.__str__())))
await stat_msg.send(
ulang.get("liteyuki.invalid_command", TEXT=str(e.__str__()))
)
return
group_id = result.other_args.get("group_id")
@ -110,7 +108,14 @@ async def _(result: Arparma, event: T_MessageEvent, bot: Bot):
if user_id in ["current", "c"]:
user_id = str(event_utils.get_user_id(event))
img = await get_stat_msg_image(duration=duration, period=period, group_id=group_id, bot_id=bot_id, user_id=user_id, ulang=ulang)
img = await get_stat_msg_image(
duration=duration,
period=period,
group_id=group_id,
bot_id=bot_id,
user_id=user_id,
ulang=ulang,
)
await stat_msg.send(UniMessage.image(raw=img))

View File

@ -1,7 +1,7 @@
from nonebot.plugin import PluginMetadata
from .status import *
__author__ = "snowykami & ้‡‘็พฟEilles"
__author__ = "็ฅž็พฝSnowyKami & ้‡‘็พฟEilles"
__plugin_meta__ = PluginMetadata(
name="็Šถๆ€ๆŸฅ็œ‹ๅ™จ",
description="",

View File

@ -23,12 +23,12 @@ from git import Repo
commit_hash = Repo(".").head.commit.hexsha
protocol_names = {
0: "iPad",
1: "Android Phone",
2: "Android Watch",
3: "Mac",
5: "iPad",
6: "Android Pad",
0: "่‹นๆžœiPad",
1: "ๅฎ‰ๅ“ๆŽŒๆœบ",
2: "ๅฎ‰ๅ“็ฉฟๆˆด",
3: "Macไธปๆœบ",
5: "่‹นๆžœiPad",
6: "ๅฎ‰ๅ“ๅนณๆฟ",
}
"""
@ -175,7 +175,7 @@ async def get_bots_data(self_id: str = "0") -> dict:
pass
statistics = status.get("stat", {})
app_name = version_info.get("app_name", "UnknownImplementation")
app_name = version_info.get("app_name", "ๆœช็Ÿฅๅบ”็”จๆŽฅๅฃ")
if app_name in ["Lagrange.OneBot", "LLOneBot", "Shamrock", "NapCat.Onebot"]:
icon = f"https://q.qlogo.cn/g?b=qq&nk={bot_id}&s=640"
elif isinstance(bot, satori.Bot):
@ -188,7 +188,7 @@ async def get_bots_data(self_id: str = "0") -> dict:
"icon": icon,
"id": bot_id,
"protocol_name": protocol_names.get(
version_info.get("protocol_name"), "Online"
version_info.get("protocol_name"), "ๅœจ็บฟ"
),
"groups": groups,
"friends": friends,
@ -226,17 +226,19 @@ async def get_hardware_data() -> dict:
except Exception:
pass
swap = psutil.swap_memory()
cpu_brand_raw = cpuinfo.get_cpu_info().get("brand_raw", "Unknown")
cpu_brand_raw = cpuinfo.get_cpu_info().get("brand_raw", "ๆœช็Ÿฅๅค„็†ๅ™จ")
if "AMD" in cpu_brand_raw:
brand = "AMD"
elif "Intel" in cpu_brand_raw:
brand = "Intel"
brand = "่‹ฑ็‰นๅฐ”"
elif "Nvidia" in cpu_brand_raw:
brand = "่‹ฑไผŸ่พพ"
else:
brand = "Unknown"
brand = "ๆœช็Ÿฅๅค„็†ๅ™จ"
result = {
"cpu": {
"percent": psutil.cpu_percent(),
"name": f"{brand} {cpuinfo.get_cpu_info().get('arch', 'Unknown')}",
"name": f"{brand} {cpuinfo.get_cpu_info().get('arch', 'ๆœช็Ÿฅๆžถๆž„')}",
"cores": psutil.cpu_count(logical=False),
"threads": psutil.cpu_count(logical=True),
"freq": psutil.cpu_freq().current, # MHz

View File

@ -137,7 +137,7 @@ async def _(
or ulang.lang_code not in status_card_cache.keys()
or (
ulang.lang_code in status_card_cache.keys()
and time.time() - status_card_cache[ulang.lang_code][1] > 60
and time.time() - status_card_cache[ulang.lang_code][1] > 300 # ็ผ“ๅญ˜
)
):
status_card_cache[ulang.lang_code] = (

View File

@ -44,8 +44,8 @@ data.forEach((item) => {
function timestampToTime(timestamp) {
let date = new Date(timestamp * 1000)
let Y = date.getFullYear() + '-'
let M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '-'
let Y = date.getFullYear() + '/'
let M = (date.getMonth() + 1 < 10 ? '0' + (date.getMonth() + 1) : date.getMonth() + 1) + '/'
let D = date.getDate() + ' '
let h = date.getHours() + ':'
let m = date.getMinutes() + ':'

View File

@ -3,12 +3,12 @@ let data = JSON.parse(document.getElementById("data").innerText) // object
const rowDiv = document.importNode(document.getElementById("row-template").content, true)
function randomHideChar(str) {
// ้šๆœบ้š่—6ไฝไปฅไธŠๅญ—็ฌฆไธฒ็š„ไธญ้—ด่ฟž็ปญๅ››ไฝๅญ—็ฌฆ๏ผŒ็”จ*ไปฃๆ›ฟ
// ้šๆœบ้š่—6ไฝไปฅไธŠๅญ—็ฌฆไธฒ็š„ไธญ้—ด่ฟž็ปญ5ไฝๅญ—็ฌฆ๏ผŒ็”จ ไปฃๆ›ฟ
if (str.length <= 6) {
return str
}
let start = Math.floor(str.length / 2) - 2
return str.slice(0, start) + "****" + str.slice(start + 4)
return str.slice(0, start) + "(ยฌโ€ฟยฌ)" + str.slice(start + 5)
}
data["ranking"].forEach((item) => {
let row = rowDiv.cloneNode(true)

View File

@ -19,7 +19,8 @@
<div class="data-storage" id="data">{{ data | tojson }}</div>
<div class="info-box" id="addition-info"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/echarts/5.5.0/echarts.min.js"></script>
<script
src="https://cdnjs.cloudflare.com/ajax/libs/echarts/5.5.0/echarts.min.js"></script>
<script src="./js/stat_msg.js"></script>
<script src="./js/card.js"></script>
</body>

View File

@ -51,7 +51,8 @@
<div class="data-storage" id="data">{{ data | tojson }}</div>
<div class="info-box" id="addition-info"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/echarts/5.5.0/echarts.min.js"></script>
<script
src="https://cdnjs.cloudflare.com/ajax/libs/echarts/5.5.0/echarts.min.js"></script>
<script src="./js/stat_rank.js"></script>
<script src="./js/card.js"></script>
</body>

File diff suppressed because one or more lines are too long

Binary file not shown.

After

Width:  |  Height:  |  Size: 155 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 122 KiB

View File

@ -153,7 +153,7 @@ function main() {
// ๆทปๅŠ ่ฝป้›ชไฟกๆฏ
let liteyukiInfoDiv = document.importNode(document.getElementById('bot-template').content, true) // ๅคๅˆถๆจกๆฟ
liteyukiInfoDiv.className = 'info-box bot-info'
liteyukiInfoDiv.querySelector('.bot-icon-img').setAttribute('src', './img/liteyuki.png')
liteyukiInfoDiv.querySelector('.bot-icon-img').setAttribute('src', './img/litetrimo.png')
liteyukiInfoDiv.querySelector('.bot-name').innerText = `${liteyukiData['name']} - ็ฟไน`
let tagArray = [
@ -186,7 +186,7 @@ function main() {
const cpuTagArray = [
cpuData['name'],
`${cpuData['cores']}${localData['cores']} ${cpuData['threads']}${localData['threads']}`,
`${(cpuData['freq'] / 1000).toFixed(2)}GHz`
`${(cpuData['freq'] / 1000).toFixed(2)}ๅ‰่ตซๅ…น`
]
const memTagArray = [

View File

@ -7,13 +7,13 @@
<title>Liteyuki Stats</title>
<link rel="stylesheet" href="css/fonts.css">
<link rel="stylesheet" href="css/style.css">
<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/echarts/4.3.0/echarts.min.js"></script>
<script type="text/javascript"
src="https://cdnjs.cloudflare.com/ajax/libs/echarts/4.3.0/echarts.min.js"></script>
</head>
<body>
<div class="info-box" id="hardware-info">
<div class="pie-info" id="cpu-info">
<div class="pie-chart" id="cpu-chart"></div>

View File

@ -8,7 +8,6 @@ import nonebot
__NAME__ = "ๅฐน็ตๆธฉ|่ฝป้›ช-็ฟไน"
__VERSION__ = "6.3.4" # 60201
# __VERSION_I__ = 99060303
import requests