Overwrite
Complete Overwrite of the Folder with the free shard. ServUO 57.3 has been added.
This commit is contained in:
203
Scripts/Items/Addons/ElvenDresserSouthAddon.cs
Normal file
203
Scripts/Items/Addons/ElvenDresserSouthAddon.cs
Normal file
@@ -0,0 +1,203 @@
|
||||
using System;
|
||||
|
||||
namespace Server.Items
|
||||
{
|
||||
public class ElvenDresserAddonSouth : BaseAddonContainer
|
||||
{
|
||||
public override BaseAddonContainerDeed Deed { get { return new ElvenDresserDeedSouth(); } }
|
||||
|
||||
public override int DefaultGumpID { get { return 0x51; } }
|
||||
public override int DefaultDropSound { get { return 0x42; } }
|
||||
public override bool RetainDeedHue { get { return true; } }
|
||||
|
||||
[Constructable]
|
||||
public ElvenDresserAddonSouth()
|
||||
: base(0x30E6)
|
||||
{
|
||||
AddComponent(new AddonContainerComponent(0x30E5), -1, 0, 0);
|
||||
}
|
||||
|
||||
public ElvenDresserAddonSouth(Serial serial)
|
||||
: base(serial)
|
||||
{
|
||||
}
|
||||
|
||||
public override void Serialize(GenericWriter writer)
|
||||
{
|
||||
base.Serialize(writer);
|
||||
|
||||
writer.WriteEncodedInt(0); // version
|
||||
}
|
||||
|
||||
public override void Deserialize(GenericReader reader)
|
||||
{
|
||||
base.Deserialize(reader);
|
||||
|
||||
int version = reader.ReadEncodedInt();
|
||||
}
|
||||
}
|
||||
|
||||
public class ElvenDresserDeedSouth : BaseAddonContainerDeed
|
||||
{
|
||||
public override BaseAddonContainer Addon { get { return new ElvenDresserAddonSouth(); } }
|
||||
public override int LabelNumber { get { return 1072864; } }
|
||||
|
||||
[Constructable]
|
||||
public ElvenDresserDeedSouth()
|
||||
{
|
||||
}
|
||||
|
||||
public ElvenDresserDeedSouth(Serial serial)
|
||||
: base(serial)
|
||||
{
|
||||
}
|
||||
|
||||
public override void Serialize(GenericWriter writer)
|
||||
{
|
||||
base.Serialize(writer);
|
||||
|
||||
writer.WriteEncodedInt(0); // version
|
||||
}
|
||||
|
||||
public override void Deserialize(GenericReader reader)
|
||||
{
|
||||
base.Deserialize(reader);
|
||||
|
||||
int version = reader.ReadEncodedInt();
|
||||
}
|
||||
}
|
||||
|
||||
public class ElvenDresserSouthAddon : BaseAddon
|
||||
{
|
||||
[Constructable]
|
||||
public ElvenDresserSouthAddon()
|
||||
{
|
||||
this.AddComponent(new AddonComponent(0x30E5), 0, 0, 0);
|
||||
this.AddComponent(new AddonComponent(0x30E6), 1, 0, 0);
|
||||
}
|
||||
|
||||
public ElvenDresserSouthAddon(Serial serial)
|
||||
: base(serial)
|
||||
{
|
||||
}
|
||||
|
||||
public override BaseAddonDeed Deed
|
||||
{
|
||||
get
|
||||
{
|
||||
return new ElvenDresserSouthDeed();
|
||||
}
|
||||
}
|
||||
public override void Serialize(GenericWriter writer)
|
||||
{
|
||||
base.Serialize(writer);
|
||||
|
||||
writer.WriteEncodedInt(0); // version
|
||||
}
|
||||
|
||||
public override void Deserialize(GenericReader reader)
|
||||
{
|
||||
base.Deserialize(reader);
|
||||
|
||||
int version = reader.ReadEncodedInt();
|
||||
|
||||
Timer.DelayCall(TimeSpan.FromSeconds(10), Replace);
|
||||
}
|
||||
|
||||
private void Replace()
|
||||
{
|
||||
Server.Multis.BaseHouse house = Server.Multis.BaseHouse.FindHouseAt(this);
|
||||
|
||||
if (house != null)
|
||||
{
|
||||
Point3D p = this.Location;
|
||||
Map map = this.Map;
|
||||
|
||||
house.Addons.Remove(this);
|
||||
Delete();
|
||||
|
||||
var addon = new ElvenDresserAddonSouth();
|
||||
addon.MoveToWorld(new Point3D(p.X + 1, p.Y, p.Z), map);
|
||||
house.Addons[addon] = house.Owner;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public class ElvenDresserSouthDeed : BaseAddonDeed
|
||||
{
|
||||
[Constructable]
|
||||
public ElvenDresserSouthDeed()
|
||||
{
|
||||
}
|
||||
|
||||
public ElvenDresserSouthDeed(Serial serial)
|
||||
: base(serial)
|
||||
{
|
||||
}
|
||||
|
||||
public override BaseAddon Addon
|
||||
{
|
||||
get
|
||||
{
|
||||
return new ElvenDresserSouthAddon();
|
||||
}
|
||||
}
|
||||
public override int LabelNumber
|
||||
{
|
||||
get
|
||||
{
|
||||
return 1072864;
|
||||
}
|
||||
}// elven dresser (south)
|
||||
public override void Serialize(GenericWriter writer)
|
||||
{
|
||||
base.Serialize(writer);
|
||||
|
||||
writer.WriteEncodedInt(0); // version
|
||||
}
|
||||
|
||||
public override void Deserialize(GenericReader reader)
|
||||
{
|
||||
base.Deserialize(reader);
|
||||
|
||||
int version = reader.ReadEncodedInt();
|
||||
|
||||
Timer.DelayCall(TimeSpan.FromSeconds(10), Replace);
|
||||
}
|
||||
|
||||
private void Replace()
|
||||
{
|
||||
Container c = this.Parent as Container;
|
||||
|
||||
if (c != null)
|
||||
{
|
||||
var deed = new ElvenDresserDeedSouth();
|
||||
c.DropItem(deed);
|
||||
}
|
||||
else if (this.Parent == null)
|
||||
{
|
||||
Server.Multis.BaseHouse house = Server.Multis.BaseHouse.FindHouseAt(this);
|
||||
|
||||
var deed = new ElvenDresserDeedSouth();
|
||||
deed.MoveToWorld(this.Location, this.Map);
|
||||
|
||||
deed.IsLockedDown = IsLockedDown;
|
||||
deed.IsSecure = IsSecure;
|
||||
deed.Movable = Movable;
|
||||
|
||||
if (house != null && house.LockDowns.ContainsKey(this))
|
||||
{
|
||||
house.LockDowns.Remove(this);
|
||||
house.LockDowns.Add(deed, house.Owner);
|
||||
}
|
||||
else if (house != null && house.IsSecure(this))
|
||||
{
|
||||
house.ReleaseSecure(house.Owner, this);
|
||||
house.AddSecure(house.Owner, deed);
|
||||
}
|
||||
}
|
||||
|
||||
Delete();
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user