Reply to thread

[SPOILER="Item.cs"]

[CODE=csharp]        public void UserWalksOffFurni(RoomUser user)

        {

            if (user == null || user.GetClient() == null || user.GetClient().GetHabbo() == null)

                return;


            if (GetBaseItem().InteractionType == InteractionType.TENT || GetBaseItem().InteractionType == InteractionType.TENT_SMALL)

                GetRoom().RemoveUserFromTent(Id, user);


            GetRoom().GetWired().TriggerEvent(Wired.WiredBoxType.TriggerWalkOffFurni, user.GetClient().GetHabbo(), this);

        }

[/CODE]

[/SPOILER]

[automerge]1596027758[/automerge]

[SPOILER="CatalogDeal.cs"]

[CODE=csharp]using System;

using System.Data;

using System.Collections.Generic;


using Plus.HabboHotel.Items;

using Plus.Database.Interfaces;


namespace Plus.HabboHotel.Catalog

{

    public class CatalogDeal

    {

        public int Id { get; set; }

        public List<CatalogItem> ItemDataList { get; private set; }

        public string DisplayName { get; set; }

        public int RoomId { get; set; }


        public CatalogDeal(int Id, string Items, string DisplayName, int RoomId, ItemDataManager ItemDataManager)

        {

            this.Id = Id;

            this.DisplayName = DisplayName;

            this.RoomId = RoomId;

            this.ItemDataList = new List<CatalogItem>();


            if (RoomId != 0)

            {

                DataTable getRoomItems = null;

                Dictionary<int, int> roomItems = new Dictionary<int, int>();


                using (IQueryAdapter dbClient = PlusEnvironment.GetDatabaseManager().GetQueryReactor())

                {

                    dbClient.SetQuery("SELECT `items`.base_item, COALESCE(`items_groups`.`group_id`, 0) AS `group_id` FROM `items` LEFT OUTER JOIN `items_groups` ON `items`.`id` = `items_groups`.`id` WHERE `items`.`room_id` = @rid;");

                    dbClient.AddParameter("rid", RoomId);

                    getRoomItems = dbClient.GetTable();

                }


                if (getRoomItems != null)

                {

                    foreach (DataRow dRow in getRoomItems.Rows)

                    {

                        int item_id = Convert.ToInt32(dRow["base_item"]);

                        if (roomItems.ContainsKey(item_id))

                            roomItems[item_id]++;

                        else

                            roomItems.Add(item_id, 1);

                    }

                }


                foreach (var roomItem in roomItems)

                    Items += roomItem.Key + "*" + roomItem.Value + ";";


                if (roomItems.Count > 0)

                    Items = Items.Remove(Items.Length - 1);

            }


            string[] SplitItems = Items.Split(';');

            foreach (string Split in SplitItems)

            {

                string[] Item = Split.Split('*');

                int ItemId = 0;

                int Amount = 0;

                if (!int.TryParse(Item[0], out ItemId) || !int.TryParse(Item[1], out Amount))

                    continue;


                ItemData Data = null;

                if (!ItemDataManager.GetItem(ItemId, out Data))

                    continue;


                ItemDataList.Add(new CatalogItem(0, ItemId, Data, string.Empty, 0, 0, 0, 0, Amount, 0, 0, false, "", "", 0));

            }

        }

    }

}

[/CODE]

[/SPOILER]


Top