2016-12-16 20:06:17 -05:00
|
|
|
|
using FFXIVClassic.Common;
|
|
|
|
|
using FFXIVClassic_World_Server.Actor.Group.Work;
|
2016-12-15 12:19:44 -05:00
|
|
|
|
using FFXIVClassic_World_Server.Packets.Send.Subpackets.Groups;
|
|
|
|
|
using System;
|
2016-12-12 19:03:25 -05:00
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
|
|
|
|
|
namespace FFXIVClassic_World_Server.DataObjects.Group
|
|
|
|
|
{
|
|
|
|
|
class RetainerGroup : Group
|
|
|
|
|
{
|
2016-12-15 12:19:44 -05:00
|
|
|
|
public RetainerWork work = new RetainerWork();
|
2016-12-12 19:03:25 -05:00
|
|
|
|
public uint owner;
|
2016-12-18 09:50:23 -05:00
|
|
|
|
public List<RetainerGroupMember> members = new List<RetainerGroupMember>();
|
2016-12-12 19:03:25 -05:00
|
|
|
|
|
|
|
|
|
public RetainerGroup(ulong groupId, uint owner) : base(groupId)
|
|
|
|
|
{
|
|
|
|
|
this.owner = owner;
|
|
|
|
|
}
|
2016-12-15 12:19:44 -05:00
|
|
|
|
|
|
|
|
|
public void setRetainerProperties(int index, byte cdIDOffset, ushort placeName, byte condition, byte level)
|
|
|
|
|
{
|
|
|
|
|
if (members.Count >= index)
|
|
|
|
|
return;
|
|
|
|
|
work._memberSave[index].cdIDOffset = cdIDOffset;
|
|
|
|
|
work._memberSave[index].placeName = placeName;
|
|
|
|
|
work._memberSave[index].conditions = condition;
|
|
|
|
|
work._memberSave[index].level = level;
|
|
|
|
|
}
|
2016-12-16 20:06:17 -05:00
|
|
|
|
|
|
|
|
|
public override void SendInitWorkValues(Session session)
|
2016-12-15 12:19:44 -05:00
|
|
|
|
{
|
2016-12-16 20:06:17 -05:00
|
|
|
|
SynchGroupWorkValuesPacket groupWork = new SynchGroupWorkValuesPacket(groupIndex);
|
2016-12-18 09:50:23 -05:00
|
|
|
|
|
|
|
|
|
for (int i = 0; i < members.Count; i++)
|
|
|
|
|
{
|
|
|
|
|
work._memberSave[i].cdIDOffset = members[i].cdIDOffset;
|
|
|
|
|
work._memberSave[i].placeName = members[i].placeName;
|
|
|
|
|
work._memberSave[i].conditions = members[i].conditions;
|
|
|
|
|
work._memberSave[i].level = members[i].level;
|
|
|
|
|
|
|
|
|
|
groupWork.addProperty(this, String.Format("work._memberSave[{0}].cdIDOffset", i));
|
|
|
|
|
groupWork.addProperty(this, String.Format("work._memberSave[{0}].placeName", i));
|
|
|
|
|
groupWork.addProperty(this, String.Format("work._memberSave[{0}].conditions", i));
|
|
|
|
|
groupWork.addProperty(this, String.Format("work._memberSave[{0}].level", i));
|
|
|
|
|
}
|
|
|
|
|
|
2016-12-15 12:19:44 -05:00
|
|
|
|
groupWork.setTarget("/_init");
|
|
|
|
|
|
2017-06-27 17:31:17 -04:00
|
|
|
|
SubPacket test = groupWork.buildPacket(session.sessionId);
|
|
|
|
|
session.clientConnection.QueuePacket(test);
|
2016-12-15 12:19:44 -05:00
|
|
|
|
}
|
2016-12-16 20:06:17 -05:00
|
|
|
|
|
2016-12-15 12:19:44 -05:00
|
|
|
|
public override int GetMemberCount()
|
|
|
|
|
{
|
2016-12-18 09:50:23 -05:00
|
|
|
|
return members.Count + 1;
|
2016-12-15 12:19:44 -05:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override uint GetTypeId()
|
|
|
|
|
{
|
|
|
|
|
return Group.RetainerGroup;
|
|
|
|
|
}
|
|
|
|
|
|
2016-12-21 21:49:50 -05:00
|
|
|
|
public override List<GroupMember> BuildMemberList(uint id)
|
2016-12-15 12:19:44 -05:00
|
|
|
|
{
|
2016-12-18 09:50:23 -05:00
|
|
|
|
List<GroupMember> groupMembers = new List<GroupMember>();
|
|
|
|
|
|
|
|
|
|
//Add retainers
|
|
|
|
|
foreach (RetainerGroupMember member in members)
|
|
|
|
|
groupMembers.Add(new GroupMember(member.id, -1, 0, false, true, member.name));
|
|
|
|
|
|
|
|
|
|
//Add player
|
|
|
|
|
groupMembers.Add(new GroupMember(owner, -1, 0, false, true, Server.GetServer().GetNameForId(owner)));
|
|
|
|
|
|
2016-12-15 12:19:44 -05:00
|
|
|
|
return groupMembers;
|
|
|
|
|
}
|
2016-12-12 19:03:25 -05:00
|
|
|
|
}
|
|
|
|
|
}
|