Compare commits

...

5 Commits

Author SHA1 Message Date
dy
be8691ce6d Merge branch 'bugfix' into dev 2023-12-29 16:21:55 +08:00
dy
d5d5d72bad 元旦活动 2023-12-29 16:21:40 +08:00
dy
aa671a332b fix 配件 2023-12-29 15:24:44 +08:00
dy
b56a0c4591 fix 配件 2023-12-29 15:19:43 +08:00
dy
bf39147538 Revert "fix 红点"
This reverts commit e9a27e135e.
2023-12-29 15:19:19 +08:00
9 changed files with 32 additions and 23 deletions

View File

@ -31,5 +31,5 @@ export default async function (call: ApiCall<ReqDMRec, ResDMRec>) {
call.succ({prize})
HongDianChange.sendChangeKey(call.uid, ['yuandan']);
HongDianChange.sendChangeKey(call.uid, ['huodonghd']);
}

View File

@ -32,5 +32,5 @@ export default async function (call: ApiCall<ReqDZRec, ResDZRec>) {
call.succ({[gift.id]: prize})
HongDianChange.sendChangeKey(call.uid, ['yuandan']);
HongDianChange.sendChangeKey(call.uid, ['huodonghd']);
}

View File

@ -25,5 +25,5 @@ export default async function (call: ApiCall<ReqExchange, ResExchange>) {
call.succ({})
HongDianChange.sendChangeKey(call.uid, ['yuandan']);
HongDianChange.sendChangeKey(call.uid, ['huodonghd']);
}

View File

@ -29,9 +29,9 @@ export default async function (call: ApiCall<ReqTaskRec, ResTaskRec>) {
await PlayerFun.sendPrize(call, _prize);
let changedata = { data: _mydata, prize: _prize}
// 推送红点
HongDianChange.sendChangeKey(call.uid, ['huodonghd']);
call.succ(changedata);
// 推送红点
HongDianChange.sendChangeKey(call.uid, ['huodonghd']);
}

View File

@ -40,5 +40,5 @@ export default async function (call: ApiCall<ReqZLRec, ResZLRec>) {
call.succ({[call.req.id]: prize})
HongDianChange.sendChangeKey(call.uid, ['yuandan']);
HongDianChange.sendChangeKey(call.uid, ['huodonghd']);
}

View File

@ -24,7 +24,7 @@ export class Yuandanfun {
exchange: {},
taskfinish: [],
taskval: await this.getTaskVal(call),
qiandaoTime: data?.qiandaoTime || 0,
qiandaoTime: data?.qiandaoTime || 1,
refreshTime: G.time
},
}, {upsert: true, returnDocument: 'after'})).value

View File

@ -349,7 +349,7 @@ export class HuoDongHongDianFun {
ishd = await this.pobinglibao(call, element)
}
if (element.htype == 14) {
// 检测 htype 10 破冰活动红点
// 检测 htype 10 元旦活动红点
ishd = await this.yuandan(call, element)
}
@ -358,7 +358,7 @@ export class HuoDongHongDianFun {
_res.show = true
_res.val.hdid.push(element.hdid)
if (_res.val.htype.indexOf(element.htype) == -1) _res.val.htype.push(element.htype)
_res.val.hdxq[element.stype] = ishd
_res.val.hdxq[element.hdid] = ishd
}
}
return _res;
@ -392,16 +392,15 @@ export class HuoDongHongDianFun {
if (data?.gameNum < _hd.data.gamefree) return {show: true}
if (!PublicShared.chkSameDate(data?.qiandaoTime || 0, G.time)) {
if (!PublicShared.chkSameDate(data?.qiandaoTime || 1, G.time)) {
return {show: true}
}
for (let i = 1; i <= data.taskval.length; i++) {
if (data?.taskval[i] >= _hd?.data?.task?.[i]?.pval && !data?.taskfinish.find(v => v == i + '')) {
for (const i in data.taskval) {
if (data?.taskval[i] >= _hd?.data?.task?.[i]?.pval && !data?.taskfinish.find(v => v == i)) {
return {show: true}
}
}
return {show: false}
}

View File

@ -1,14 +1,14 @@
import { ApiCall } from "tsrpc";
import { ReqGetList, ResGetList } from "../../shared/protocols/peijian/PtlGetList";
import {ApiCall} from "tsrpc";
import {ReqGetList, ResGetList} from "../../shared/protocols/peijian/PtlGetList";
export default async function (call: ApiCall<ReqGetList, ResGetList>) {
let _maxLv = 0
let color = {}
let peijianCon = G.gc.peijian
let dbList = (await G.mongodb.collection('peijian').find({ uid: call.uid }).toArray()).map(p => {
let dbList = (await G.mongodb.collection('peijian').find({uid: call.uid}).toArray()).map(p => {
let np = G.mongodb.conversionIdObj(p);
let { uid, ...ops } = np;
let {uid, ...ops} = np;
if (np.lv > _maxLv) _maxLv = np.lv
if (!color[peijianCon[np.peijianId].colour]) color[peijianCon[np.peijianId].colour] = 0
@ -16,15 +16,25 @@ export default async function (call: ApiCall<ReqGetList, ResGetList>) {
return ops;
});
// 修复配件穿戴在不存在的英雄身上
let heroIds = R.values(call.conn.gud.heroPos)
let fixIds = dbList.filter(i => i.wearId && !heroIds.includes(i.wearId)).map(i => G.mongodb.conversionId(i._id))
if (fixIds.length) {
await G.mongodb.collection('peijian').updateMany({_id: {$in: fixIds}}, {$set: {wearId: ''}})
}
// 记录玩家最大等级,颜色相关数据 注册任务用
await G.mongodb.collection('playerInfo', 'usertasklog').updateOne({ uid: call.conn.uid, type: 'usertasklog' },
{ $set: { maxpeijianlv: _maxLv, peijiancolor: color } }, { upsert: true })
await G.mongodb.collection('playerInfo', 'usertasklog').updateOne({uid: call.conn.uid, type: 'usertasklog'},
{$set: {maxpeijianlv: _maxLv, peijiancolor: color}}, {upsert: true})
let list = Object.fromEntries(dbList.map(p => [G.formatRedisKey(p._id), p]));
G.redis.set('peijian', call.uid, list);
let recLshd = await G.mongodb.collection('playerInfo', 'lshd_peijian').findOne({ uid: call.conn.uid, type: 'lshd_peijian' });
let { uid, _id, type, ...peijians } = (recLshd || {});
let recLshd = await G.mongodb.collection('playerInfo', 'lshd_peijian').findOne({
uid: call.conn.uid,
type: 'lshd_peijian'
});
let {uid, _id, type, ...peijians} = (recLshd || {});
call.conn.lshd.peijian = peijians || {};
call.succ({

View File

@ -55,7 +55,7 @@ export type hongdianKey =
| 'pobinglibao'
| 'payForDiamond'
| 'leichonglibao'
| 'yuandan';
export type hongdianVal = {
show?: boolean;
// 看功能需要