mirror of
https://github.com/EpinelPS/EpinelPS.git
synced 2025-12-21 19:34:40 +01:00
Equipment and main quest bug fixes
This commit is contained in:
@@ -13,26 +13,30 @@ namespace nksrv.LobbyServer.Msgs.Inventory
|
||||
|
||||
var response = new ResWearEquipment();
|
||||
|
||||
var pos = NetUtils.GetItemPos(user, req.Isn);
|
||||
|
||||
// unequip old item
|
||||
|
||||
foreach (var item in user.Items.ToArray())
|
||||
{
|
||||
if (item.Csn == req.Csn && item.Position == pos)
|
||||
{
|
||||
item.Csn = 0;
|
||||
}
|
||||
}
|
||||
|
||||
foreach (var item in user.Items.ToArray())
|
||||
{
|
||||
if (item.Isn == req.Isn)
|
||||
{
|
||||
// update character id
|
||||
item.Csn = req.Csn;
|
||||
item.Position = NetUtils.GetItemPos(user, item.Isn);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
foreach (var item in user.Items.ToArray())
|
||||
{
|
||||
if (item.Csn == req.Csn)
|
||||
{
|
||||
item.Position = pos;
|
||||
response.Items.Add(NetUtils.ToNet(item));
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
JsonDb.Save();
|
||||
await WriteDataAsync(response);
|
||||
}
|
||||
|
||||
@@ -13,14 +13,27 @@ namespace nksrv.LobbyServer.Msgs.Inventory
|
||||
|
||||
var response = new ResWearEquipmentList();
|
||||
|
||||
// TODO optimize
|
||||
foreach (var item2 in req.IsnList)
|
||||
{
|
||||
var pos = NetUtils.GetItemPos(user, item2);
|
||||
|
||||
// unequip previous items
|
||||
foreach (var item in user.Items.ToArray())
|
||||
{
|
||||
if (item.Position == pos && item.Csn == req.Csn)
|
||||
{
|
||||
item.Csn = 0;
|
||||
item.Position = 0;
|
||||
}
|
||||
}
|
||||
|
||||
foreach (var item in user.Items.ToArray())
|
||||
{
|
||||
if (item2 == item.Isn)
|
||||
{
|
||||
item.Csn = req.Csn;
|
||||
item.Position = NetUtils.GetItemPos(user, item.Isn);
|
||||
item.Position = pos;
|
||||
response.Items.Add(NetUtils.ToNet(item));
|
||||
}
|
||||
}
|
||||
|
||||
@@ -227,7 +227,7 @@ namespace nksrv.LobbyServer.Msgs.Stage
|
||||
{
|
||||
var quest = StaticDataParser.Instance.GetMainQuestForStageClearCondition(clearedStageId);
|
||||
if (quest != null)
|
||||
user.SetQuest(quest.id, true);
|
||||
user.SetQuest(quest.id, false);
|
||||
|
||||
if (clearedStageId == 6000003)
|
||||
{
|
||||
|
||||
@@ -12,7 +12,7 @@ namespace nksrv.LobbyServer.Msgs.Trigger
|
||||
var req = await ReadData<ReqFinMainQuest>();
|
||||
var user = GetUser();
|
||||
Console.WriteLine("Complete quest: " + req.Tid);
|
||||
user.SetQuest(req.Tid, true);
|
||||
user.SetQuest(req.Tid, false);
|
||||
|
||||
var completedQuest = StaticDataParser.Instance.GetMainQuestByTableId(req.Tid);
|
||||
if (completedQuest == null) throw new Exception("Quest not found");
|
||||
|
||||
Reference in New Issue
Block a user