增加 #全部抽卡记录 命令 和 枫丹 水神瞳 露景泉 显示 (#228)
* 增加 枫丹 水神瞳 露景泉 显示 * 增加 #全部抽卡记录 命令 * fix uid 判断
This commit is contained in:
parent
e923ddd5cf
commit
40e94790b5
|
@ -32,7 +32,7 @@ export class gcLog extends plugin {
|
|||
fnc: 'logJson'
|
||||
},
|
||||
{
|
||||
reg: '^#*(原神|星铁)?(抽卡|抽奖|角色|武器|常驻|up|新手|光锥)池*(记录|祈愿|分析)$',
|
||||
reg: '^#*(原神|星铁)?(全部)?(抽卡|抽奖|角色|武器|常驻|up|新手|光锥)池*(记录|祈愿|分析)$',
|
||||
fnc: 'getLog'
|
||||
},
|
||||
{
|
||||
|
@ -133,10 +133,16 @@ export class gcLog extends plugin {
|
|||
|
||||
/** #抽卡记录 */
|
||||
async getLog () {
|
||||
this.e.isAll = !!(this.e.msg.includes('全部') && !this.e.isSr)
|
||||
let data = await new GachaLog(this.e).getLogData()
|
||||
if (!data) return
|
||||
let url = this.srHead('gachaLog', data)
|
||||
let img = await puppeteer.screenshot(url, data)
|
||||
let name = 'gachaLog'
|
||||
if (this.e.isAll) {
|
||||
name = 'gachaAllLog'
|
||||
} else {
|
||||
name = this.srHead('gachaLog', data)
|
||||
}
|
||||
let img = await puppeteer.screenshot(name, data)
|
||||
if (img) await this.reply(img)
|
||||
}
|
||||
|
||||
|
|
|
@ -59,12 +59,9 @@ export default class GachaLog extends base {
|
|||
}
|
||||
if (i <= 1) await common.sleep(500)
|
||||
}
|
||||
//只去掉结尾的多余一个换行符
|
||||
tmpMsg=tmpMsg.replace(/(\n)$/, '')
|
||||
MakeMsg.push(tmpMsg)
|
||||
MakeMsg.push(`抽卡记录更新完成,您还可回复\n【#${this?.e?.isSr?'星铁光锥':'武器'}记录】统计${this?.e?.isSr?'星铁光锥':'武器'}池数据\n【#${this?.e?.isSr?'星铁':''}角色统计】按卡池统计数据\n【#导出记录】导出记录数据`)
|
||||
let Msg = await common.makeForwardMsg(this.e, MakeMsg, tmpMsg)
|
||||
await this.e.reply(Msg)
|
||||
MakeMsg.push(`\n抽卡记录更新完成,您还可回复\n【#${this?.e?.isSr ? '星铁光锥' : '武器'}记录】统计${this?.e?.isSr ? '星铁光锥' : '武器'}池数据\n【#${this?.e?.isSr ? '星铁' : ''}角色统计】按卡池统计数据\n【#导出记录】导出记录数据`)
|
||||
await this.e.reply(MakeMsg)
|
||||
|
||||
this.isLogUrl = true
|
||||
|
||||
|
@ -92,7 +89,7 @@ export default class GachaLog extends base {
|
|||
dealUrl (url) {
|
||||
// timestamp=1641338980〈=zh-cn 修复链接有奇怪符号
|
||||
url = url.replace(/〈=/g, '&')
|
||||
if (url.includes("getGachaLog?")) url = url.split('getGachaLog?')[1]
|
||||
if (url.includes('getGachaLog?')) url = url.split('getGachaLog?')[1]
|
||||
|
||||
// 处理参数
|
||||
let arr = new URLSearchParams(url).entries()
|
||||
|
@ -202,7 +199,6 @@ export default class GachaLog extends base {
|
|||
logUrl = 'https://hk4e-api-os.mihoyo.com/event/gacha_info/api/getGachaLog?'
|
||||
}
|
||||
|
||||
|
||||
let logParam = new URLSearchParams({
|
||||
authkey_ver: 1,
|
||||
lang: 'zh-cn', // 只支持简体中文
|
||||
|
@ -257,7 +253,7 @@ export default class GachaLog extends base {
|
|||
|
||||
let logJson = this.readJson()
|
||||
/** 第一次获取增加提示 */
|
||||
if (lodash.isEmpty(logJson.list) && this.type == 301) {
|
||||
if (lodash.isEmpty(logJson.list) && this.type === 301) {
|
||||
await this.e.reply(`开始获取${this.typeName}记录,首次获取数据较多,请耐心等待...`)
|
||||
}
|
||||
|
||||
|
@ -362,26 +358,64 @@ export default class GachaLog extends base {
|
|||
|
||||
/** #抽卡记录 */
|
||||
async getLogData () {
|
||||
/** 卡池 */
|
||||
this.getPool()
|
||||
|
||||
/** 判断uid */
|
||||
await this.getUid()
|
||||
|
||||
if (!this.uid) {
|
||||
// await this.e.reply('当前绑定uid暂无抽卡记录')
|
||||
return false
|
||||
}
|
||||
if (this.e?.isAll) {
|
||||
return await this.getAllGcLogData()
|
||||
} else {
|
||||
return await this.getGcLogData()
|
||||
}
|
||||
}
|
||||
|
||||
async getAllGcLogData () {
|
||||
const poolList = ['角色', '武器', '常驻', '新手']
|
||||
const logData = []
|
||||
let fiveMaxNum = 0
|
||||
const originalMsg = this.e.msg
|
||||
for (let i of poolList) {
|
||||
this.e.msg = i
|
||||
this.all = []
|
||||
let data = await this.getGcLogData()
|
||||
if (!data || data.allNum === 0) {
|
||||
continue
|
||||
}
|
||||
if (fiveMaxNum <= data.fiveLog.length) {
|
||||
fiveMaxNum = data.fiveLog.length
|
||||
}
|
||||
data.max = i === '武器' ? 80 : 90
|
||||
logData.push(data)
|
||||
}
|
||||
if (logData.length === 0) {
|
||||
this.e.reply('暂无抽卡记录\n#记录帮助,查看配置说明', false, { at: true })
|
||||
return true
|
||||
}
|
||||
for (let i of logData) {
|
||||
let diffNum = fiveMaxNum - i.fiveLog.length
|
||||
if (diffNum > 0) {
|
||||
i.fiveLog = i.fiveLog.concat(new Array(diffNum).fill({ isUp: false, isNull: true }))
|
||||
}
|
||||
}
|
||||
const data = {
|
||||
...logData[0],
|
||||
data: logData
|
||||
}
|
||||
data.tplFile = './plugins/genshin/resources/html/gachaAllLog/gachaAllLog.html'
|
||||
this.e.msg = originalMsg
|
||||
return data
|
||||
}
|
||||
|
||||
async getGcLogData () {
|
||||
/** 卡池 */
|
||||
this.getPool()
|
||||
/** 更新记录 */
|
||||
if (!this.isLogUrl) await this.updateLog()
|
||||
|
||||
/** 统计计算记录 */
|
||||
let data = this.analyse()
|
||||
|
||||
/** 渲染数据 */
|
||||
data = this.randData(data)
|
||||
|
||||
return data
|
||||
}
|
||||
|
||||
|
@ -405,11 +439,11 @@ export default class GachaLog extends base {
|
|||
this.type = this.e.isSr ? 12 : 302
|
||||
this.typeName = this.e.isSr ? '光锥' : '武器'
|
||||
break
|
||||
case "光锥":
|
||||
case '光锥':
|
||||
this.type = 12
|
||||
this.typeName = '光锥'
|
||||
break
|
||||
case "新手":
|
||||
case '新手':
|
||||
this.type = this.e.isSr ? 2 : 100
|
||||
this.typeName = '新手'
|
||||
break
|
||||
|
@ -428,8 +462,10 @@ export default class GachaLog extends base {
|
|||
this.e.reply('暂无抽卡记录\n#记录帮助,查看配置说明', false, { at: true })
|
||||
return false
|
||||
}
|
||||
|
||||
this.uid = this?.e?.isSr ? this.e.user?._games?.sr?.uid : this.e.user?._games?.gs?.uid
|
||||
if (!this.uid) {
|
||||
this.uid = await redis.get(this.uidKey)
|
||||
}
|
||||
|
||||
/** 记录有绑定的uid */
|
||||
if (this.uid && logs.includes(String(this.uid))) {
|
||||
|
@ -632,15 +668,15 @@ export default class GachaLog extends base {
|
|||
return false
|
||||
}
|
||||
let role5join = {
|
||||
'刻晴': {
|
||||
刻晴: {
|
||||
start: '2021-02-17 18:00:00',
|
||||
end: '2021-03-02 15:59:59'
|
||||
},
|
||||
'提纳里': {
|
||||
提纳里: {
|
||||
start: '2022-08-24 06:00:00',
|
||||
end: '2022-09-09 17:59:59'
|
||||
},
|
||||
'迪希雅': {
|
||||
迪希雅: {
|
||||
start: '2023-03-01 06:00:00',
|
||||
end: '2023-03-21 17:59:59'
|
||||
}
|
||||
|
|
|
@ -22,7 +22,8 @@ export default class RoleIndex extends base {
|
|||
渊下宫: 5,
|
||||
层岩巨渊: 6,
|
||||
层岩地下: 7,
|
||||
须弥: 8
|
||||
须弥: 8,
|
||||
枫丹: 9
|
||||
}
|
||||
|
||||
this.areaName = lodash.invert(this.area)
|
||||
|
@ -133,21 +134,21 @@ export default class RoleIndex extends base {
|
|||
]
|
||||
]
|
||||
|
||||
// 尘歌壶
|
||||
let homesLevel = 0
|
||||
// let homesItem = 0
|
||||
if (resIndex.homes && resIndex.homes.length > 0) {
|
||||
homesLevel = resIndex.homes[0].level
|
||||
// homesItem = resIndex.homes[0].item_num
|
||||
}
|
||||
// // 尘歌壶
|
||||
// let homesLevel = 0
|
||||
// // let homesItem = 0
|
||||
// if (resIndex.homes && resIndex.homes.length > 0) {
|
||||
// homesLevel = resIndex.homes[0].level
|
||||
// // homesItem = resIndex.homes[0].item_num
|
||||
// }
|
||||
|
||||
let worldExplorations = lodash.keyBy(resIndex.world_explorations, 'id')
|
||||
|
||||
let explor = []
|
||||
let explor2 = []
|
||||
|
||||
let expArr = ['须弥', '层岩巨渊', '渊下宫', '稻妻']
|
||||
let expArr2 = ['雪山', '璃月', '蒙德']
|
||||
let expArr = ['枫丹', '须弥', '层岩巨渊', '渊下宫']
|
||||
let expArr2 = ['稻妻', '雪山', '璃月', '蒙德']
|
||||
|
||||
for (let val of expArr) {
|
||||
let tmp = { lable: val, num: `${(worldExplorations[this.area[val]]?.exploration_percentage ?? 0) / 10}%` }
|
||||
|
@ -159,7 +160,7 @@ export default class RoleIndex extends base {
|
|||
explor2.push(tmp)
|
||||
}
|
||||
|
||||
explor2.push({ lable: '家园等级', num: homesLevel })
|
||||
// explor2.push({ lable: '家园等级', num: homesLevel })
|
||||
|
||||
line.push(explor)
|
||||
line.push(explor2)
|
||||
|
@ -349,6 +350,8 @@ export default class RoleIndex extends base {
|
|||
}
|
||||
|
||||
explor2 = explor2.concat([
|
||||
{ lable: '水神瞳', num: stats.hydroculus_number },
|
||||
{ lable: '草神瞳', num: stats.dendroculus_number },
|
||||
{ lable: '雷神瞳', num: stats.electroculus_number },
|
||||
{ lable: '岩神瞳', num: stats.geoculus_number },
|
||||
{ lable: '风神瞳', num: stats.anemoculus_number }
|
||||
|
@ -417,20 +420,30 @@ export default class RoleIndex extends base {
|
|||
{ lable: '普通宝箱', num: stats.common_chest_number }
|
||||
],
|
||||
[
|
||||
{ lable: '水神瞳', num: stats.hydroculus_number },
|
||||
{ lable: '草神瞳', num: stats.dendroculus_number },
|
||||
{ lable: '雷神瞳', num: stats.electroculus_number },
|
||||
{ lable: '岩神瞳', num: stats.geoculus_number },
|
||||
{ lable: '岩神瞳', num: stats.geoculus_number }
|
||||
],
|
||||
[
|
||||
{ lable: '风神瞳', num: stats.anemoculus_number }
|
||||
]
|
||||
]
|
||||
// 尘歌壶
|
||||
if (res.homes && res.homes.length > 0) {
|
||||
line.push([
|
||||
// line.push([
|
||||
// { lable: '家园等级', num: res.homes[0].level },
|
||||
// { lable: '最高仙力', num: res.homes[0].comfort_num },
|
||||
// { lable: '获得摆设', num: res.homes[0].item_num },
|
||||
// { lable: '历史访客', num: res.homes[0].visit_num }
|
||||
// ])
|
||||
const anemoculus = { ...line[3][0] }
|
||||
line[3] = [
|
||||
anemoculus,
|
||||
{ lable: '家园等级', num: res.homes[0].level },
|
||||
{ lable: '最高仙力', num: res.homes[0].comfort_num },
|
||||
{ lable: '获得摆设', num: res.homes[0].item_num },
|
||||
{ lable: '历史访客', num: res.homes[0].visit_num }
|
||||
])
|
||||
{ lable: '获得摆设', num: res.homes[0].item_num }
|
||||
]
|
||||
}
|
||||
|
||||
res.world_explorations = lodash.orderBy(res.world_explorations, ['id'], ['desc'])
|
||||
|
@ -451,7 +464,7 @@ export default class RoleIndex extends base {
|
|||
]
|
||||
}
|
||||
|
||||
if (['蒙德', '璃月', '稻妻', '须弥'].includes(val.name)) {
|
||||
if (['蒙德', '璃月', '稻妻', '须弥', '枫丹'].includes(val.name)) {
|
||||
tmp.line.push({
|
||||
name: '声望',
|
||||
text: `${val.level}级`
|
||||
|
@ -470,7 +483,7 @@ export default class RoleIndex extends base {
|
|||
}
|
||||
}
|
||||
|
||||
if (['雪山', '稻妻', '层岩巨渊', '须弥'].includes(val.name)) {
|
||||
if (['雪山', '稻妻', '层岩巨渊', '须弥', '枫丹'].includes(val.name)) {
|
||||
if (val.offerings[0].name.includes('流明石')) {
|
||||
val.offerings[0].name = '流明石'
|
||||
}
|
||||
|
|
|
@ -0,0 +1,396 @@
|
|||
@font-face {
|
||||
font-family: "tttgbnumber";
|
||||
src: url("../../../../../resources/font/tttgbnumber.ttf");
|
||||
font-weight: normal;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
* {
|
||||
margin: 0;
|
||||
padding: 0;
|
||||
box-sizing: border-box;
|
||||
user-select: none;
|
||||
}
|
||||
|
||||
body {
|
||||
font-size: 18px;
|
||||
color: #1e1f20;
|
||||
font-family: PingFangSC-Medium, PingFang SC, sans-serif;
|
||||
transform: scale(1.5);
|
||||
transform-origin: 0 0;
|
||||
position: absolute;
|
||||
}
|
||||
.container {
|
||||
width: 1500px;
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
justify-content: space-between;
|
||||
padding: 20px 15px 10px 15px;
|
||||
background-color: #f5f6fb;
|
||||
height: 100%; /* 设置容器高度,这里假设容器的父元素有固定高度或是占满整个视口 */
|
||||
}
|
||||
.info_box{
|
||||
width: 465px;
|
||||
margin-right: 15px;
|
||||
margin-left: 15px;
|
||||
flex: 1;
|
||||
align-items: center;
|
||||
justify-content: center;
|
||||
}
|
||||
|
||||
.head_box {
|
||||
border-radius: 15px;
|
||||
font-family: tttgbnumber;
|
||||
padding: 10px 20px;
|
||||
position: relative;
|
||||
box-shadow: 0 5px 10px 0 rgb(0 0 0 / 15%);
|
||||
}
|
||||
|
||||
.head_box .id_text {
|
||||
font-size: 24px;
|
||||
}
|
||||
|
||||
.head_box .day_text {
|
||||
font-size: 20px;
|
||||
}
|
||||
|
||||
.head_box .genshin_logo {
|
||||
position: absolute;
|
||||
top: 1px;
|
||||
right: 15px;
|
||||
width: 97px;
|
||||
}
|
||||
|
||||
.logo {
|
||||
width: 100%;
|
||||
font-size: 12px;
|
||||
font-family: "tttgbnumber";
|
||||
text-align: center;
|
||||
color: #7994a7;
|
||||
position: relative;
|
||||
padding-left: 10px;
|
||||
}
|
||||
|
||||
|
||||
.data_box {
|
||||
border-radius: 15px;
|
||||
margin-top: 20px;
|
||||
margin-bottom: 20px;
|
||||
padding: 20px 0px 5px 10px;
|
||||
background: #fff;
|
||||
box-shadow: 0 5px 10px 0 rgb(0 0 0 / 15%);
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.tab_lable {
|
||||
position: absolute;
|
||||
top: -10px;
|
||||
left: -8px;
|
||||
background: #d4b98c;
|
||||
color: #fff;
|
||||
font-size: 14px;
|
||||
padding: 3px 10px;
|
||||
border-radius: 15px 0px 15px 15px;
|
||||
z-index: 20;
|
||||
}
|
||||
|
||||
.data_line {
|
||||
display: flex;
|
||||
justify-content: space-around;
|
||||
margin-bottom: 14px;
|
||||
padding-right: 10px;
|
||||
}
|
||||
|
||||
.data_line_item {
|
||||
width: 100px;
|
||||
text-align: center;
|
||||
/*margin: 0 20px;*/
|
||||
}
|
||||
|
||||
.num {
|
||||
font-family: tttgbnumber;
|
||||
font-size: 24px;
|
||||
}
|
||||
|
||||
.num .unit {
|
||||
font-size: 12px;
|
||||
}
|
||||
|
||||
.data_box .lable {
|
||||
font-size: 14px;
|
||||
color: #7f858a;
|
||||
line-height: 1;
|
||||
margin-top: 3px;
|
||||
}
|
||||
|
||||
/*body {*/
|
||||
/* width: 510px;*/
|
||||
/*}*/
|
||||
|
||||
/*.container {*/
|
||||
/* width: 510px;*/
|
||||
/*}*/
|
||||
|
||||
.data_box {
|
||||
margin-bottom: 10px;
|
||||
}
|
||||
|
||||
.info_box_border{
|
||||
border-radius: 15px;
|
||||
/* margin-top: 20px; */
|
||||
margin-bottom: 20px;
|
||||
padding: 6px 0px 5px 10px;
|
||||
background: #fff;
|
||||
box-shadow: 0 5px 10px 0 rgb(0 0 0 / 15%);
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.card_list {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
justify-content: flex-start;
|
||||
}
|
||||
|
||||
.card_list .item {
|
||||
margin: 0px 10px 10px 10px;
|
||||
border-radius: 7px;
|
||||
box-shadow: 0 2px 6px 0 rgb(132 93 90 / 30%);
|
||||
height: 90px;
|
||||
position: relative;
|
||||
overflow: hidden;
|
||||
/*background: #e7e5d9;*/
|
||||
}
|
||||
.card_list .item.isNull {
|
||||
margin: 0px 10px 10px 10px;
|
||||
border-radius: 7px;
|
||||
height: 90px;
|
||||
position: relative;
|
||||
overflow: hidden;
|
||||
box-shadow: none !important;
|
||||
background: none !important;
|
||||
}
|
||||
|
||||
.card_list .item img {
|
||||
width: 70px;
|
||||
height: 70px;
|
||||
border-radius: 7px 7px 20px 0;
|
||||
}
|
||||
.card_list .item.star5{
|
||||
width: 70px;
|
||||
}
|
||||
|
||||
.card_list .item.star5 img {
|
||||
background-image: url(../../img/other/bg5.png);
|
||||
width: 100%;
|
||||
height: 70px;
|
||||
/*filter: brightness(1.1);*/
|
||||
background-size: 100%;
|
||||
background-repeat: no-repeat;
|
||||
}
|
||||
|
||||
.card_list .item.star4 img {
|
||||
width: 100%;
|
||||
height: 70px;
|
||||
background-image: url(../../img/other/bg4.png);
|
||||
background-size: 100%;
|
||||
background-repeat: no-repeat;
|
||||
}
|
||||
|
||||
.card_list .item .num {
|
||||
position: absolute;
|
||||
top: 0px;
|
||||
right: 0px;
|
||||
z-index: 9;
|
||||
font-size: 18px;
|
||||
text-align: center;
|
||||
color: #fff;
|
||||
border-radius: 3px;
|
||||
padding: 1px 5px;
|
||||
border-radius: 3px;
|
||||
background: rgb(0 0 0 / 50%);
|
||||
font-family: "tttgbnumber";
|
||||
}
|
||||
|
||||
.card_list .item .name,
|
||||
.card_list .item .num_name {
|
||||
position: absolute;
|
||||
top: 71px;
|
||||
left: 0px;
|
||||
z-index: 9;
|
||||
font-size: 12px;
|
||||
text-align: center;
|
||||
width: 100%;
|
||||
height: 16px;
|
||||
line-height: 18px;
|
||||
}
|
||||
|
||||
.card_list .item .num_name {
|
||||
font-family: "tttgbnumber";
|
||||
font-size: 16px;
|
||||
}
|
||||
|
||||
.base_info {
|
||||
position: relative;
|
||||
padding-left: 10px;
|
||||
margin: 5px 10px;
|
||||
}
|
||||
|
||||
.uid:before {
|
||||
content: " ";
|
||||
position: absolute;
|
||||
width: 5px;
|
||||
height: 24px;
|
||||
border-radius: 1px;
|
||||
left: 0;
|
||||
top: 0;
|
||||
background: #d3bc8d;
|
||||
}
|
||||
|
||||
.label_301 {
|
||||
background-color: rgb(235 106 75);
|
||||
}
|
||||
|
||||
.label_302 {
|
||||
background-color: #E69449;
|
||||
}
|
||||
|
||||
.label_200 {
|
||||
background-color: #757CC8;
|
||||
}
|
||||
|
||||
.label {
|
||||
color: #fff;
|
||||
border-radius: 10px;
|
||||
font-size: 12px;
|
||||
padding: 2px 7px;
|
||||
vertical-align: 2px;
|
||||
}
|
||||
|
||||
.ritem {
|
||||
display: flex;
|
||||
font-size: 12px;
|
||||
margin-bottom: 5px;
|
||||
}
|
||||
|
||||
.info_role {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
padding: 0 0px 5px 9px;
|
||||
}
|
||||
|
||||
.ritem .role {
|
||||
width: 20px;
|
||||
height: 20px;
|
||||
background-color: #ffb285;
|
||||
border-radius: 100%;
|
||||
}
|
||||
|
||||
.ritem .weapon_box {
|
||||
overflow: hidden;
|
||||
width: 20px;
|
||||
height: 20px;
|
||||
border-radius: 100%;
|
||||
}
|
||||
|
||||
.ritem .weapon {
|
||||
width: 20px;
|
||||
height: 20px;
|
||||
background-color: #ffb285;
|
||||
border-radius: 100%;
|
||||
transform: scale(1.5);
|
||||
-webkit-transform: scale(1.5);
|
||||
|
||||
}
|
||||
|
||||
.ritem .role_text {
|
||||
margin: 2px 3px 0 2px;
|
||||
display: flex;
|
||||
align-items: baseline;
|
||||
}
|
||||
|
||||
.ritem .role_name {
|
||||
width: 24px;
|
||||
white-space: nowrap;
|
||||
overflow: hidden;
|
||||
}
|
||||
|
||||
.ritem .role_num {
|
||||
width: 24px;
|
||||
}
|
||||
|
||||
.line_box {
|
||||
height: 32px;
|
||||
width: 100%;
|
||||
display: flex;
|
||||
justify-content: space-between;
|
||||
align-items: center;
|
||||
font-size: 12px;
|
||||
color: #7d7d7d;
|
||||
padding-bottom: 5px;
|
||||
}
|
||||
|
||||
.line_box .line {
|
||||
height: 2px;
|
||||
flex-grow: 1;
|
||||
background-color: #ebebeb;
|
||||
margin: 0px 10px;
|
||||
}
|
||||
|
||||
.red {
|
||||
color: #f21000;
|
||||
}
|
||||
|
||||
.orange {
|
||||
color: #ff8d00;
|
||||
}
|
||||
|
||||
.green {
|
||||
color: #12d88c;
|
||||
}
|
||||
|
||||
.blue {
|
||||
color: #4169E1;
|
||||
}
|
||||
|
||||
.purple {
|
||||
color: #7500ff;
|
||||
}
|
||||
.minimum{
|
||||
position: absolute;
|
||||
top: 0px;
|
||||
right: 0px;
|
||||
z-index: 9;
|
||||
font-size: 12px;
|
||||
text-align: center;
|
||||
color: #fff;
|
||||
border-radius: 3px;
|
||||
padding: 1px 3px;
|
||||
background-color: rgb(0 0 0 / 80%);
|
||||
font-family: "tttgbnumber";
|
||||
}
|
||||
.hasMore{
|
||||
font-size: 12px;
|
||||
margin: 6px 0;
|
||||
color: #7f858a;
|
||||
}
|
||||
|
||||
|
||||
.gold {
|
||||
background: #ffeb73;
|
||||
color: #6f4b00;
|
||||
}
|
||||
|
||||
.good {
|
||||
background: #168b2c;
|
||||
color: #fff;
|
||||
}
|
||||
|
||||
.normal {
|
||||
background: #6939b7;
|
||||
color: #fff;
|
||||
}
|
||||
|
||||
.bad {
|
||||
background: #9d3333;
|
||||
color: #fff;
|
||||
}
|
|
@ -0,0 +1,79 @@
|
|||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta http-equiv="content-type" content="text/html;charset=utf-8"/>
|
||||
<link rel="shortcut icon" href="#"/>
|
||||
<link rel="stylesheet" type="text/css" href="{{pluResPath}}html/gachaAllLog/gachaAllLog.css"/>
|
||||
<link rel="preload" href="{{resPath}}font/tttgbnumber.ttf" as="font">
|
||||
<link rel="preload" href="{{pluResPath}}img/namecard/{{headImg}}.png" as="image">
|
||||
<link rel="preload" href="{{pluResPath}}img/other/bg5.png" as="image">
|
||||
{{@headStyle}}
|
||||
</head>
|
||||
<body id="container" class="body_box">
|
||||
<div class="container" style="width:{{data.length* 500}} px">
|
||||
{{each data log}}
|
||||
<div class="info_box" >
|
||||
<div class="head_box">
|
||||
<div class="id_text">
|
||||
ID: {{log.uid}}
|
||||
</div>
|
||||
<h2 class="day_text">
|
||||
{{log.allNum}}抽
|
||||
<span class="label label_{{type}}">{{log.typeName}}池</span>
|
||||
</h2>
|
||||
<img class="genshin_logo" src="{{pluResPath}}img/other/原神.png"/>
|
||||
</div>
|
||||
<div class="data_box">
|
||||
<div class="tab_lable">数据总览</div>
|
||||
{{each log.line val}}
|
||||
<div class="data_line">
|
||||
{{each val item}}
|
||||
<div class="data_line_item">
|
||||
<div class="num">{{item.num}}<span class="unit">{{item.unit}}</span></div>
|
||||
<div class="lable">{{item.lable}}</div>
|
||||
</div>
|
||||
{{/each}}
|
||||
</div>
|
||||
{{/each}}
|
||||
<div class="line_box">
|
||||
<span class="line"></span>
|
||||
<span class="text">五星历史 {{firstTime}} ~ {{lastTime}}</span>
|
||||
<span class="line"></span>
|
||||
</div>
|
||||
<div class="card_list">
|
||||
{{each log.fiveLog val}}
|
||||
<div class="item {{val.isNull?'isNull':''}} star5 {{val.num<=10?'gold': (val.num<log.max*0.5 ? 'good' : (val.num<log.max*0.83) ? 'normal': 'bad')}}">
|
||||
{{ if val.isUp && typeName == '角色' }}
|
||||
<span class="minimum">UP</span>
|
||||
{{/if}}
|
||||
{{ if val.isNull }}
|
||||
<div class="role"></div>
|
||||
<div class="num_name">{{val.num}}</div>
|
||||
{{/if}}
|
||||
{{ if !val.isNull }}
|
||||
<img class="role"
|
||||
src="{{pluResPath}}img/{{val.item_type=='角色'?'role':'weapon'}}/{{val.name}}.png"
|
||||
onerror="whenError(this,'{{val.item_type=='角色'?'role':'weapon'}}')"/>
|
||||
<!-- <div class="num">{{val.num}}</div>-->
|
||||
<div class="num_name {{val.num<=10?'gold': (val.num<log.max*0.5 ? 'good' : (val.num<log.max*0.83) ? 'normal': 'bad')}}" >{{val.num}}</div>
|
||||
{{/if}}
|
||||
</div>
|
||||
{{/each}}
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
{{/each}}
|
||||
<div class="logo">Created By Miao-Yunzai</div>
|
||||
</div>
|
||||
</body>
|
||||
<script type="text/javascript">
|
||||
function whenError(a, type) {
|
||||
// a.onerror = null;
|
||||
// if(type=="role"){
|
||||
// a.src = "{{_res_path}}/genshin/logo/role/荧.png";
|
||||
// }else{
|
||||
// a.src = "{{_res_path}}/genshin/logo/weapon/旅行剑.png";
|
||||
// }
|
||||
}
|
||||
</script>
|
||||
</html>
|
Loading…
Reference in New Issue