public string CreatePVPTable(WowRealm _Realm, int _Count, PlayerColumn[] _Columns, Func <KeyValuePair <string, Player>, double> _SortLambda, Func <Player, bool> _RequirementLambda) { int pageIndex = PageUtility.GetQueryInt(Request, "page", 1) - 1;//Change range from 0 to * instead of 1 to * bool needHistory = false; if (_Columns.Contains(PlayerColumn.RankChange)) { needHistory = true; } string table = "<table id='characters-table' class='table'>"; table += "<thead>" + PageUtility.CreatePlayerTableHeaderRow(_Columns) + "</thead>"; table += "<tbody>"; var playerArray = DatabaseAccess.GetRealmPlayers(this, _Realm, NotLoadedDecision.RedirectAndWait).OrderByDescending(_SortLambda); var playersHistoryArray = DatabaseAccess._GetRealmPlayersHistory(this, _Realm, NotLoadedDecision.ReturnNull); int nr = 0; foreach (var player in playerArray) { if (_RequirementLambda(player.Value) == true) { nr++; if (nr > pageIndex * _Count && nr <= (pageIndex + 1) * _Count) { if (needHistory == true) { VF_RealmPlayersDatabase.PlayerData.PlayerHistory playerHistory = null; if (playersHistoryArray != null) { if (playersHistoryArray.TryGetValue(player.Key, out playerHistory) == false) { playerHistory = null; } } table += PageUtility.CreatePlayerRow(nr, _Realm, player.Value, _Columns, playerHistory); } else { table += PageUtility.CreatePlayerRow(nr, _Realm, player.Value, _Columns); } } } if (nr >= (pageIndex + 1) * _Count) { break; } } table += "</tbody></table>"; if (nr != 0 && nr <= pageIndex * _Count) { pageIndex = (nr - 1) / _Count; Response.Redirect(PageUtility.CreateUrlWithNewQueryValue(Request, "page", (pageIndex + 1).ToString())); } return(table); }
protected void Page_Load(object sender, EventArgs e) { int pageNr = PageUtility.GetQueryInt(Request, "page", 1); int pageIndex = pageNr - 1;//Change range from 0 to * instead of 1 to * int count = PageUtility.GetQueryInt(Request, "count", 100); if (count > 500) { count = 500; } string searchStr = PageUtility.GetQueryString(Request, "search", "null"); string searchRealm = PageUtility.GetQueryString(Request, "realm", "All"); string searchRace = PageUtility.GetQueryString(Request, "race", "All"); string searchClass = PageUtility.GetQueryString(Request, "class", "All"); string searchLevel = PageUtility.GetQueryString(Request, "level", "All"); string searchSort = PageUtility.GetQueryString(Request, "sort", "NameSearch"); if (searchStr != "") { this.Title = "Search \"" + searchStr + "\" | RealmPlayers"; } else { this.Title = "Search | RealmPlayers"; } //List<Tuple<WowRealm, Player>> WowRealm realm = StaticValues.ConvertRealm(searchRealm); if (realm == WowRealm.Unknown) { realm = WowRealm.All; } int nr = 0; if (searchStr.Length >= 4 || searchStr.Contains(' ')) { var guildSummaryDB = Hidden.ApplicationInstance.Instance.GetGuildSummaryDatabase(); var searchStrLower = searchStr.ToLower(); var guildArray = guildSummaryDB.GetGuilds(realm).Where((_Value) => _Value.Value.GuildName.ToLower().Contains(searchStrLower)); if (guildArray.Count() > pageIndex * count) { Dictionary <string, Player> realmDB = null; if (realm != WowRealm.All) { realmDB = DatabaseAccess.GetRealmPlayers(this, realm); } var realmDBRealm = realm; System.Text.StringBuilder guildResultTable = new System.Text.StringBuilder(10000); guildResultTable.Append("<h3>Guilds matching "" + searchStr + ""</h3>"); guildResultTable.Append("<table id=\"guild-table\" class=\"table\"><thead>"); guildResultTable.Append(PageUtility.CreateGuildTableHeaderRow(Table_GuildColumns)); guildResultTable.Append("</thead><tbody>"); var orderedGuildArray = guildArray.OrderBy((_Value) => _Value.Key); foreach (var guild in orderedGuildArray) { if (realmDBRealm != guild.Value.Realm) { realmDB = DatabaseAccess.GetRealmPlayers(this, guild.Value.Realm); realmDBRealm = guild.Value.Realm; } guild.Value.GenerateCache(realmDB); } orderedGuildArray = orderedGuildArray.OrderByDescending((_Value) => _Value.Value.GetMembers().Count); foreach (var guild in orderedGuildArray) { if (guild.Value.GetMembers().Count < 2) { continue; } nr++; if (nr > pageIndex * count && nr <= (pageIndex + 1) * count) { guildResultTable.Append(PageUtility.CreateGuildRow(0, guild.Value, Table_GuildColumns)); } if (nr >= (pageIndex + 1) * count) { break; } } guildResultTable.Append("</tbody></table>"); guildResultTable.Append("<h3>Players matching "" + searchStr + ""</h3>"); if (nr > 0) { m_GuildResultTableHTML = new MvcHtmlString(guildResultTable.ToString()); } } else { m_GuildResultTableHTML = null; nr += guildArray.Count(); } } var playersList = FindPlayersMatching(searchStr, searchRealm, searchRace, searchClass, searchLevel, searchSort);//.OrderBy((_Value) => { return ((int)_Value.Item1).ToString() + _Value.Item2.Name; }); System.Text.StringBuilder page = new System.Text.StringBuilder(10000); IEnumerable <Player> orderedPlayersList = playersList; //if (playersList.Count() > 500 || searchStr.Length < 2) // orderedPlayersList = playersList;//.OrderBy(_Player => _Player.Item2.Name); //else //if (searchStr.Length >= 1) //{ // string nameFormattedSearchStr = char.ToUpper(searchStr[0]) + searchStr.Substring(1).ToLower(); // orderedPlayersList = playersList.OrderByDescending(_Player => _Player.LastSeen.AddYears(_Player.Name.StartsWith(nameFormattedSearchStr) ? 2 : 0)); //} //else //{ // orderedPlayersList = playersList.OrderBy(_Player => _Player.Name); //} var playerListCount = playersList.Count(); foreach (Player player in orderedPlayersList) { if (playerListCount < count && player.Character.Level < 10 && searchStr.Length <= (double)player.Name.Length * 0.7) { continue; } nr++; if (nr > pageIndex * count && nr <= (pageIndex + 1) * count) { page.Append(PageUtility.CreatePlayerRow(0, player.Realm, player, Table_Columns)); } if (nr >= (pageIndex + 1) * count) { break; } } if (nr != 0 && nr <= pageIndex * count) { pageIndex = (nr - 1) / count; Response.Redirect(PageUtility.CreateUrlWithNewQueryValue(Request, "page", (pageIndex + 1).ToString())); } m_BreadCrumbHTML = new MvcHtmlString(PageUtility.BreadCrumb_AddHome() + PageUtility.BreadCrumb_AddFinish("Characters")); m_CharListInfoHTML = new MvcHtmlString(CreateCharListInfo(searchStr, playersList.Count())); m_TableHeadHTML = new MvcHtmlString(PageUtility.CreatePlayerTableHeaderRow(Table_Columns, null, Request)); m_TableBodyHTML = new MvcHtmlString(page.ToString()); m_PaginationHTML = new MvcHtmlString(PageUtility.CreatePagination(Request, pageNr, ((playersList.Count() - 1) / count) + 1)); }
protected void Page_Load(object sender, EventArgs e) { int pageNr = PageUtility.GetQueryInt(Request, "page", 1); int pageIndex = pageNr - 1;//Change range from 0 to * instead of 1 to * int count = PageUtility.GetQueryInt(Request, "count", 50); if (count > 500) { count = 500; } var realm = RealmControl.Realm; if (realm == WowRealm.Unknown) { return; } this.Title = "Guilds @ " + StaticValues.ConvertRealmParam(realm) + " | RealmPlayers"; var realmDB = DatabaseAccess.GetRealmPlayers(this, realm, NotLoadedDecision.RedirectAndWait); var guildSummaryDB = Hidden.ApplicationInstance.Instance.GetGuildSummaryDatabase(); //;// DatabaseAccess.GetRealmGuilds(this, realm, NotLoadedDecision.RedirectAndWait).Where((guild) => { return guild.Value.GetTotalPlayers() > 0; }) var guildArray = guildSummaryDB.GetGuilds(realm);//.OrderByDescending((guild) => { return guild.Value.Players.Count; }); string page = ""; int nr = 0; string guildProgressData = ""; List <Tuple <int, Tuple <VF_RPDatabase.GuildSummary, string> > > progressGuilds = new List <Tuple <int, Tuple <VF_RPDatabase.GuildSummary, string> > >(); foreach (var guild in guildArray) { guild.Value.GenerateCache(realmDB); if (guild.Value.GetMembers().Count > 0) { string thisGuildProgressData = guild.Value.m_GuildProgressData.Item1; int progressComparisonValue = guild.Value.m_GuildProgressData.Item2; if (thisGuildProgressData == "" && guild.Value.Stats_GetTotalMaxLevels() >= 25) { try { thisGuildProgressData = CreateProgressStr(this, guild.Value, realm, out progressComparisonValue); guild.Value.m_GuildProgressData = Tuple.Create(thisGuildProgressData, progressComparisonValue); } catch (Exception ex) { Logger.LogException(ex); } } progressGuilds.Add(Tuple.Create(progressComparisonValue, Tuple.Create(guild.Value, thisGuildProgressData))); } } var orderedProgressGuilds = progressGuilds.OrderByDescending(_Value => { UInt64 sortValue = (((UInt64)_Value.Item1) << 32); if (sortValue != 0) { //sortValue |= (((UInt64)(UInt32)_Value.Item2.Item1.Stats_GetAveragePVPRank()) << 16) | ((UInt64)(UInt32)_Value.Item2.Item1.GetMembers().Count); sortValue |= (((UInt64)(UInt32)_Value.Item2.Item1.Stats_GetAverageMemberHKs()) << 16) | ((UInt64)(UInt32)_Value.Item2.Item1.GetMembers().Count); } else { sortValue |= (UInt64)(UInt32)_Value.Item2.Item1.Stats_GetTotalMaxLevels(); } return(sortValue); }); if (orderedProgressGuilds.Count() > 0) { if (GuildProgress.GetProgressAQ40(orderedProgressGuilds.First().Item1) == 0) //AQ Content not released { guildProgressData += "g_AQReleased = false;"; } else { guildProgressData += "g_AQReleased = true;"; } if (GuildProgress.GetProgressNaxx(orderedProgressGuilds.First().Item1) == 0) //Naxx Content not released { guildProgressData += "g_NaxxReleased = false;"; } else { guildProgressData += "g_NaxxReleased = true;"; } } foreach (var guild in orderedProgressGuilds) { nr++; if (nr > pageIndex * count && nr <= (pageIndex + 1) * count) { page += PageUtility.CreateGuildRow(nr, guild.Item2.Item1, Table_Columns); guildProgressData += guild.Item2.Item2; } if (nr >= (pageIndex + 1) * count) { break; } } if (nr != 0 && nr <= pageIndex * count) { pageIndex = (nr - 1) / count; Response.Redirect(PageUtility.CreateUrlWithNewQueryValue(Request, "page", (pageIndex + 1).ToString())); } m_BreadCrumbHTML = new MvcHtmlString(PageUtility.BreadCrumb_AddHome() + PageUtility.BreadCrumb_AddRealm(RealmControl.Realm) + PageUtility.BreadCrumb_AddFinish("Guilds")); m_GuildListInfoHTML = new MvcHtmlString(CreateGuildListInfo(StaticValues.GetWowVersion(RealmControl.Realm), progressGuilds.Count)); m_TableHeadHTML = new MvcHtmlString(PageUtility.CreateGuildTableHeaderRow(Table_Columns)); m_TableBodyHTML = new MvcHtmlString(page); m_PaginationHTML = new MvcHtmlString(PageUtility.CreatePagination(Request, pageNr, ((guildArray.Count() - 1) / count) + 1)); m_GuildScriptData = new MvcHtmlString("<script>var guildProgress = new Array();" + guildProgressData + "</script>"); }
public string CreateStandingsTable(WowRealm _Realm, int _Count, Func <Player, bool> _RequirementLambda) { int pageIndex = PageUtility.GetQueryInt(Request, "page", 1) - 1;//Change range from 0 to * instead of 1 to * string commonTable = "<table id='characters-table' class='table'>"; commonTable += "<thead>" + PageUtility.CreatePlayerTableHeaderRow(Table_Standings_Columns) + "</thead>"; string hordeTable = commonTable + "<tbody>"; string allianceTable = commonTable + "<tbody>"; Func <KeyValuePair <string, Player>, double> sortLambda = (KeyValuePair <string, Player> player) => { double daysSinceLastSeen = (DateTime.UtcNow - player.Value.LastSeen).TotalDays; if (daysSinceLastSeen > 7) { return(int.MaxValue); } return((double)player.Value.Honor.LastWeekStanding + (daysSinceLastSeen / 10.0)); }; var playerArray = DatabaseAccess.GetRealmPlayers(this, _Realm, NotLoadedDecision.RedirectAndWait).OrderBy(sortLambda); DateTime lastRankUpdateDateUTC = StaticValues.CalculateLastRankUpdadeDateUTC(_Realm); int hordeCount = 0; int allianceCount = 0; foreach (var player in playerArray) { if ((player.Value.LastSeen - lastRankUpdateDateUTC).TotalHours > 0) { var playerFaction = StaticValues.GetFaction(player.Value.Character.Race); if (playerFaction == VF_RealmPlayersDatabase.PlayerFaction.Horde && hordeCount < (pageIndex + 1) * _Count && _RequirementLambda(player.Value) == true) { hordeCount++; if (hordeCount > pageIndex * _Count && hordeCount <= (pageIndex + 1) * _Count) { hordeTable += PageUtility.CreatePlayerRow(hordeCount, _Realm, player.Value, Table_Standings_Columns); } } else if (playerFaction == VF_RealmPlayersDatabase.PlayerFaction.Alliance && allianceCount < (pageIndex + 1) * _Count && _RequirementLambda(player.Value) == true) { allianceCount++; if (allianceCount > pageIndex * _Count && allianceCount <= (pageIndex + 1) * _Count) { allianceTable += PageUtility.CreatePlayerRow(allianceCount, _Realm, player.Value, Table_Standings_Columns); } } } if (hordeCount >= (pageIndex + 1) * _Count && allianceCount >= (pageIndex + 1) * _Count) { break; } } hordeTable += "</tbody></table>"; allianceTable += "</tbody></table>"; string pageTable = ""; pageTable += PageUtility.CreateDiv("span6", hordeTable); pageTable += PageUtility.CreateDiv("span6", allianceTable); pageTable = PageUtility.CreateDiv("row", pageTable); if ((hordeCount != 0 && hordeCount < pageIndex * _Count) && (allianceCount != 0 && allianceCount < pageIndex * _Count)) { pageIndex = (hordeCount - 1) / _Count; if (pageIndex < (allianceCount - 1) / _Count) { pageIndex = (allianceCount - 1) / _Count; } Response.Redirect(PageUtility.CreateUrlWithNewQueryValue(Request, "page", (pageIndex + 1).ToString())); } return(pageTable); }
protected void Page_Load(object sender, EventArgs e) { string sectionStr = PageUtility.GetQueryString(Request, "section", "ranks"); int count = PageUtility.GetQueryInt(Request, "count", 100); if (count > 500) { count = 500; } var realm = RealmControl.Realm; if (realm == WowRealm.Unknown) { return; } var wowVersion = StaticValues.GetWowVersion(realm); PlayerColumn[] lifetimeKillsColumns = Table_Lifetime_Kills_Columns; PlayerColumn[] rankColumns = Table_Ranks_Columns; Func <KeyValuePair <string, Player>, double> rankSorterLambda = (KeyValuePair <string, Player> _Player) => { return(_Player.Value.GetRankTotal()); }; Func <Player, bool> rankShowLambda = (Player _Player) => { return(_Player.ReceivedStandingLastWeek() == true && ((DateTime.UtcNow - _Player.LastSeen).TotalDays <= 7.0)); }; if (wowVersion == VF_RealmPlayersDatabase.WowVersionEnum.TBC) { lifetimeKillsColumns = Table_Lifetime_Kills_Columns_TBC; rankColumns = Table_Ranks_Columns_TBC; rankSorterLambda = (KeyValuePair <string, Player> _Player) => { return(_Player.Value.GetArenaRatingTotal()); }; rankShowLambda = (Player _Player) => { return(_Player.Arena != null); }; } if (sectionStr == "standings") { this.Title = "Standings @ " + StaticValues.ConvertRealmParam(realm) + " | RealmPlayers"; m_PageHTML = new MvcHtmlString(CreateStandingsTable(realm, count, (player) => { return(player.ReceivedStandingLastWeek()); })); if (wowVersion == VF_RealmPlayersDatabase.WowVersionEnum.TBC) { GeneratePageDetails("Standings", count * 2, "TBC works with a different PVP system so there are no standings."); } else { var rankUpdateDay = StaticValues.GetRankUpdadeDayType(realm); switch (rankUpdateDay) { case VF_RealmPlayersDatabase.StaticValues.RankUpdateDayType.Wednesday_Morning: GeneratePageDetails("Standings", count * 2, "Last weeks standings for players. Only shows players who received a standing last week. This list resets when the realm calculates new standings for players every wednesday morning."); break; case VF_RealmPlayersDatabase.StaticValues.RankUpdateDayType.Wednesday_Midday: GeneratePageDetails("Standings", count * 2, "Last weeks standings for players. Only shows players who received a standing last week. This list resets when the realm calculates new standings for players every wednesday."); break; case VF_RealmPlayersDatabase.StaticValues.RankUpdateDayType.Sunday_Midnight: GeneratePageDetails("Standings", count * 2, "Last weeks standings for players. Only shows players who received a standing last week. This list resets when the realm calculates new standings for players every sunday midnight."); break; default: break; } } } else if (sectionStr == "twink_ranks") { this.Title = "Twinks @ " + StaticValues.ConvertRealmParam(realm) + " | RealmPlayers"; m_PageHTML = new MvcHtmlString(CreatePVPTable(realm, count, Table_Twink_Ranks_Columns , (KeyValuePair <string, Player> _Player) => { return(_Player.Value.GetRankTotal()); } , (Player _Player) => { return(_Player.Character.Level > 10 && _Player.Character.Level < 60 && _Player.Honor.CurrentRank > 0 && (DateTime.UtcNow - _Player.LastSeen).TotalDays <= 30); })); GeneratePageDetails("Twinks", count, "PVP Ranks for players that are below lvl 60. This is meant to show active twinks on the realm. Only shows players that was seen less than 30 days ago"); } else if (sectionStr == "lifetime_kills") { this.Title = "Lifetime Kills @ " + StaticValues.ConvertRealmParam(realm) + " | RealmPlayers"; m_PageHTML = new MvcHtmlString(CreatePVPTable(realm, count, lifetimeKillsColumns , (KeyValuePair <string, Player> _Player) => { return(_Player.Value.Honor.LifetimeHK); } , (Player _Player) => { return(true); })); GeneratePageDetails("Lifetime Kills", count, "List sorted by the amount of total honorable kills received. This is to show the players who have pvped the most overall."); } else if (sectionStr == "highest_ranks") { this.Title = "Highest Ranks @ " + StaticValues.ConvertRealmParam(realm) + " | RealmPlayers"; if (wowVersion == VF_RealmPlayersDatabase.WowVersionEnum.TBC) { m_PageHTML = new MvcHtmlString(""); GeneratePageDetails("Highest Ranks", count, "TBC works with a different PVP system so there are no lifetime highest ranks."); } else { var playerSummaryDB = Hidden.ApplicationInstance.Instance.GetPlayerSummaryDatabase(); var pvpSummaries = playerSummaryDB.GetPVPSummaries(realm); DateTime referenceDateTime = new DateTime(2010, 1, 1); var orderedPVPSummaries = pvpSummaries.OrderByDescending((_Value) => ((int)_Value.Value.m_HighestRank.Key) * 100000 - (_Value.Value.m_HighestRank.Value != DateTime.MinValue ? (int)((_Value.Value.m_HighestRank.Value - referenceDateTime).TotalDays) : 0)); ////////////////////////////////// int pageIndex = PageUtility.GetQueryInt(Request, "page", 1) - 1;//Change range from 0 to * instead of 1 to * PlayerColumn[] playerColumns = new PlayerColumn[] { PlayerColumn.Number, PlayerColumn.Character_And_Guild, PlayerColumn.Race_And_Class, PlayerColumn.Total_HKs, PlayerColumn.LastSeen, }; Dictionary <PlayerColumn, string[]> extraColumns = new Dictionary <PlayerColumn, string[]>(); extraColumns[PlayerColumn.Number] = new string[] { "Rank", "Date Achieved" }; //extraColumns[PlayerColumn.Total_HKs] = new string[] { "Weeks with standing" }; string table = "<table class='table'>"; table += "<thead>" + PageUtility.CreatePlayerTableHeaderRow(playerColumns, extraColumns) + "</thead>"; table += "<tbody>"; var playerArray = DatabaseAccess.GetRealmPlayers(this, realm, NotLoadedDecision.RedirectAndWait); int nr = 0; foreach (var pvpSummary in orderedPVPSummaries) { nr++; if (nr > pageIndex * count && nr <= (pageIndex + 1) * count) { Player playerData = null; if (playerArray.TryGetValue(playerSummaryDB.GetPlayer(pvpSummary), out playerData) == true) { VF_RealmPlayersDatabase.PlayerFaction playerFaction = StaticValues.GetFaction(playerData.Character.Race); int rank = (int)pvpSummary.Value.m_HighestRank.Key; float rankProgress = pvpSummary.Value.m_HighestRank.Key - (float)rank; extraColumns[PlayerColumn.Number] = new string[] { PageUtility.CreatePlayerRankDiv(rank, rankProgress, playerFaction), pvpSummary.Value.m_HighestRank.Value.ToString("yyyy-MM-dd") }; //extraColumns[PlayerColumn.Total_HKs] = new string[] { pvpSummary.Value.m_ActivePVPWeeks.ToString() }; table += PageUtility.CreatePlayerRow(nr, realm, playerData, playerColumns, null, extraColumns); } } if (nr >= (pageIndex + 1) * count) { break; } } table += "</tbody></table>"; if (nr != 0 && nr <= pageIndex * count) { pageIndex = (nr - 1) / count; Response.Redirect(PageUtility.CreateUrlWithNewQueryValue(Request, "page", (pageIndex + 1).ToString())); } m_PageHTML = new MvcHtmlString(table); ////////////////////////////////// GeneratePageDetails("Highest Ranks", count, "Highest lifetime achieved PVP Ranks for players, sorted by date of achievment"); } } else// if (sectionStr == "ranks") { this.Title = "Ranks @ " + StaticValues.ConvertRealmParam(realm) + " | RealmPlayers"; if (realm == WowRealm.Nostalrius || realm == WowRealm.NostalriusPVE) { rankShowLambda = (Player _Player) => { return((DateTime.UtcNow - _Player.LastSeen).TotalDays < 14); }; GeneratePageDetails("Ranks", count, "Highest PVP Ranks for active players."); } else if (wowVersion == VF_RealmPlayersDatabase.WowVersionEnum.TBC) { GeneratePageDetails("Arena Ranking", count, "Shows the highest rated arena teams, sorted by a sum of the total rating for 5v5, 3v3 and 2v2."); } else { GeneratePageDetails("Ranks", count, "Highest PVP Ranks for players. Only lists players who received standing last week. This is because no rank decay would make the list extremely boring(filled with players that dont even pvp)."); } m_PageHTML = new MvcHtmlString(CreatePVPTable(realm, count, rankColumns , rankSorterLambda, rankShowLambda)); } //href='javascript:navigateWithNewQuery(\"page\",\"1\")' int pageNr = PageUtility.GetQueryInt(Request, "page", 1); int maxPageNr = 1000000 / count; m_PaginationHTML = new MvcHtmlString(PageUtility.CreatePagination(Request, pageNr, maxPageNr)); }
protected void Page_Load(object sender, EventArgs e) { string pageView = RealmPlayersServer.PageUtility.GetQueryString(Request, "view", "players"); var realm = PageUtility.GetQueryRealm(Request); if (realm == WowRealm.Unknown) { return; } var wowVersion = StaticValues.GetWowVersion(realm); string guildStr = PageUtility.GetQueryString(Request, "guild"); var realmDB = DatabaseAccess.GetRealmPlayers(this, realm); var guildSummaryDB = Hidden.ApplicationInstance.Instance.GetGuildSummaryDatabase(); var guild = guildSummaryDB.GetGuildSummary(realm, guildStr);// DatabaseAccess.GetRealmGuild(this, realm, guildStr, NotLoadedDecision.RedirectAndWait); if (guild == null) { return; } guild.GenerateCache(realmDB); this.Title = guildStr + " @ " + StaticValues.ConvertRealmParam(realm) + " | RealmPlayers"; m_ProgressInfoHTML = new MvcHtmlString("<div id='" + guild.GuildName.Replace(' ', '_') + "-Progress'></div>"); var membersArray = guild.GetMembers(); var orderedPlayersArray = membersArray.OrderBy((player) => { return(player.Item2.History.Last().GuildRankNr); }); int progressComparisonValue = 0; string guildProgressData = GuildList.CreateProgressStr(this, guild, realm, out progressComparisonValue); m_GuildScriptData = new MvcHtmlString("<script>var guildProgress = new Array();" + guildProgressData + "</script>"); if (pageView == "players") { m_BreadCrumbHTML = new MvcHtmlString(PageUtility.BreadCrumb_AddHome() + PageUtility.BreadCrumb_AddRealm(realm) + PageUtility.BreadCrumb_AddGuilds(realm) + PageUtility.BreadCrumb_AddFinish(guild.GuildName)); m_GuildInfoHTML = new MvcHtmlString("<h1><img src='assets/img/icons/ui-pvp-" + StaticValues.GetFactionCSSName(guild.Faction) + ".png'/><span class='" + StaticValues.GetFactionCSSName(guild.Faction) + "-color'>" + guild.GuildName + "</span><span class='badge badge-inverse'>" + membersArray.Count + " Members</span></h1>" + "<p>Guild on the server " + StaticValues.ConvertRealmViewing(realm) + "</p>" + "<p><a href='/GuildViewer.aspx?realm=" + StaticValues.ConvertRealmParam(realm) + "&guild=" + guildStr + "&view=latestevents'>View Latest Events</a></p>" + "<p><a href='/RaidStats/RaidList.aspx?realm=" + StaticValues.ConvertRealmParam(realm) + "&guild=" + guildStr + "'>View recorded raids on RaidStats</a></p>"); string page = ""; foreach (var player in orderedPlayersArray) { page += PageUtility.CreatePlayerRow(0, realm, player.Item1, Table_Columns); } m_CharactersTableHeadHTML = new MvcHtmlString(PageUtility.CreatePlayerTableHeaderRow(Table_Columns)); m_CharactersTableBodyHTML = new MvcHtmlString(page); } else if (pageView == "latestmembers") { m_BreadCrumbHTML = new MvcHtmlString(PageUtility.BreadCrumb_AddHome() + PageUtility.BreadCrumb_AddRealm(realm) + PageUtility.BreadCrumb_AddGuilds(realm) + PageUtility.BreadCrumb_AddGuild(realm, guild.GuildName) + PageUtility.BreadCrumb_AddFinish("Latest Members")); m_GuildInfoHTML = new MvcHtmlString("<h1><img src='assets/img/icons/ui-pvp-" + StaticValues.GetFactionCSSName(guild.Faction) + ".png'/><span class='" + StaticValues.GetFactionCSSName(guild.Faction) + "-color'>" + guild.GuildName + "</span><span class='badge badge-inverse'>" + membersArray.Count + " Members</span></h1>" + "<p>Guild on the server " + StaticValues.ConvertRealmViewing(realm) + "</p>" + "<p><a href='/GuildViewer.aspx?realm=" + StaticValues.ConvertRealmParam(realm) + "&guild=" + guildStr + "'>View Members</a></p>" + "<p><a href='/RaidStats/RaidList.aspx?realm=" + StaticValues.ConvertRealmParam(realm) + "&guild=" + guildStr + "'>View recorded raids on RaidStats</a></p>"); } else if (pageView == "latestitems") { m_BreadCrumbHTML = new MvcHtmlString(PageUtility.BreadCrumb_AddHome() + PageUtility.BreadCrumb_AddRealm(realm) + PageUtility.BreadCrumb_AddGuilds(realm) + PageUtility.BreadCrumb_AddGuild(realm, guild.GuildName) + PageUtility.BreadCrumb_AddFinish("Latest Items")); m_GuildInfoHTML = new MvcHtmlString("<h1><img src='assets/img/icons/ui-pvp-" + StaticValues.GetFactionCSSName(guild.Faction) + ".png'/><span class='" + StaticValues.GetFactionCSSName(guild.Faction) + "-color'>" + guild.GuildName + "</span><span class='badge badge-inverse'>" + membersArray.Count + " Members</span></h1>" + "<p>Guild on the server " + StaticValues.ConvertRealmViewing(realm) + "</p>" + "<p><a href='/GuildViewer.aspx?realm=" + StaticValues.ConvertRealmParam(realm) + "&guild=" + guildStr + "'>View Members</a></p>" + "<p><a href='/RaidStats/RaidList.aspx?realm=" + StaticValues.ConvertRealmParam(realm) + "&guild=" + guildStr + "'>View recorded raids on RaidStats</a></p>"); } else if (pageView == "latestevents") { m_BreadCrumbHTML = new MvcHtmlString(PageUtility.BreadCrumb_AddHome() + PageUtility.BreadCrumb_AddRealm(realm) + PageUtility.BreadCrumb_AddGuilds(realm) + PageUtility.BreadCrumb_AddGuild(realm, guild.GuildName) + PageUtility.BreadCrumb_AddFinish("Latest Events")); m_GuildInfoHTML = new MvcHtmlString("<h1><img src='assets/img/icons/ui-pvp-" + StaticValues.GetFactionCSSName(guild.Faction) + ".png'/><span class='" + StaticValues.GetFactionCSSName(guild.Faction) + "-color'>" + guild.GuildName + "</span><span class='badge badge-inverse'>" + membersArray.Count + " Members</span></h1>" + "<p>Guild on the server " + StaticValues.ConvertRealmViewing(realm) + "</p>" + "<p><a href='/GuildViewer.aspx?realm=" + StaticValues.ConvertRealmParam(realm) + "&guild=" + guildStr + "'>View Members</a></p>" + "<p><a href='/RaidStats/RaidList.aspx?realm=" + StaticValues.ConvertRealmParam(realm) + "&guild=" + guildStr + "'>View recorded raids on RaidStats</a></p>"); } if (pageView == "latestmembers" || pageView == "latestevents") { var guildSummary = Hidden.ApplicationInstance.Instance.GetGuildSummary(realm, guildStr); if (guildSummary == null) { return; } var statusChanges = guildSummary.GenerateLatestStatusChanges(DateTime.UtcNow.AddDays(-14)); string latestmembersStr = ""; statusChanges.Reverse(); foreach (var sChange in statusChanges) { if (realmDB.ContainsKey(sChange.Player)) { var playerData = realmDB[sChange.Player]; string statusChangeDescription = ""; if (sChange.FromStatus == null || sChange.FromStatus.IsInGuild == false) { if (sChange.ToStatus.IsInGuild == true) { statusChangeDescription = "Added to the Guild as Rank \"" + sChange.ToStatus.GuildRank + "\""; } else { continue; } } else if (sChange.ToStatus.IsInGuild == false) { statusChangeDescription = "Removed from the Guild"; } else { statusChangeDescription = "Changed Rank From \"" + sChange.FromStatus.GuildRank + "\" to \"" + sChange.ToStatus.GuildRank + "\""; } latestmembersStr += PageUtility.CreateTableRow("" , PageUtility.CreateTableColumn(PageUtility.CreateColorCodedPlayerLink(realm, playerData)) + PageUtility.CreateTableColumn("<div style='overflow: hidden;white-space: nowrap;'>" + statusChangeDescription + "</div>") + PageUtility.CreateTableColumn("<div style='overflow: hidden;white-space: nowrap;'>" + sChange.ToStatus.DateTime.ToLocalTime().ToString("yyyy-MM-dd") + "</div>")); } } m_LatestMembersHTML = new MvcHtmlString(latestmembersStr); } if (pageView == "latestitems" || pageView == "latestevents") { List <Tuple <DateTime, Player, List <Tuple <PlayerItemInfo, ItemInfo> > > > latestItems = new List <Tuple <DateTime, Player, List <Tuple <PlayerItemInfo, ItemInfo> > > >(); var realmHistory = DatabaseAccess._GetRealmPlayersHistory(this, realm, NotLoadedDecision.SpinWait); foreach (var data in orderedPlayersArray) { Player player = data.Item1; PlayerHistory playerHistory = null; if (realmHistory.TryGetValue(player.Name, out playerHistory) == true) { var recvItems = HistoryGenerator.GenerateLatestReceivedItems(playerHistory, DateTime.MinValue); var orderedRecvItems = recvItems.OrderByDescending(_Value => _Value.Key); int i = 0; foreach (var recvItem in orderedRecvItems) { if (i++ > 10) { break; } List <Tuple <PlayerItemInfo, ItemInfo> > newestItems = new List <Tuple <PlayerItemInfo, ItemInfo> >(); foreach (var item in recvItem.Value) { var itemInfo = DatabaseAccess.GetItemInfo(item.ItemID, wowVersion); if (itemInfo.ItemQuality >= 4) //Atleast epic(4) { newestItems.Add(Tuple.Create(item, itemInfo)); } } if (newestItems.Count > 0) { latestItems.Add(Tuple.Create(recvItem.Key, player, newestItems)); } } } } string latestItemsStr = ""; { var itemSummaryDB = Hidden.ApplicationInstance.Instance.GetItemSummaryDatabase(); string currentItemDatabase = DatabaseAccess.GetCurrentItemDatabaseAddress(); var orderedLatestItems = latestItems.OrderByDescending((_Value) => _Value.Item1); int i = 0; foreach (var recvItem in orderedLatestItems) { if (i++ > 100) { break; } int recvItemIndex = 0; int xMax = 58 * 3; int yMax = (int)((recvItem.Item3.Count - 1) / 3) * 58; yMax += 58; string itemLinks = "<div class='inventory' style='background: none; width: " + xMax + "px; height: " + yMax + "px;'>"; foreach (var item in recvItem.Item3) { int xPos = (recvItemIndex % 3) * 58; int yPos = (int)(recvItemIndex / 3) * 58; //string itemLink = currentItemDatabase + "?item=" + item.Item1.ItemID + "' rel='rand=" + item.Item1.SuffixID + ";ench=0"; var itemInfo = item.Item2; itemLinks += "<div style='background: none; width: 58px; height: 58px;margin: " + yPos + "px " + xPos + "px;'>" + "<img class='itempic' src='" + "http://realmplayers.com/" + itemInfo.GetIconImageAddress() + "'/>" + "<div class='quality' id='" + CharacterViewer.ItemQualityConversion[itemInfo.ItemQuality] + "'></div>" + "<img class='itemframe' src='assets/img/icons/ItemNormalFrame.png'/>" + CharacterViewer.GenerateItemLink(currentItemDatabase, item.Item1, wowVersion); var itemUsageCount = itemSummaryDB.GetItemUsageCount(realm, item.Item1); itemLinks += "<a class='itemplayersframe' href='ItemUsageInfo.aspx?realm=" + StaticValues.ConvertRealmParam(realm) + "&item=" + item.Item1.ItemID + (item.Item1.SuffixID != 0 ? "&suffix=" + item.Item1.SuffixID : "") + "'>" + itemUsageCount + "</a>"; itemLinks += "</div>"; ++recvItemIndex; } itemLinks += "</div>"; latestItemsStr += PageUtility.CreateTableRow("" , PageUtility.CreateTableColumn(itemLinks) + PageUtility.CreateTableColumn(PageUtility.CreateColorCodedPlayerLink(realm, recvItem.Item2)) + PageUtility.CreateTableColumn("<div style='overflow: hidden;white-space: nowrap;'>" + recvItem.Item1.ToString("yyyy-MM-dd") + "</div>")); } } m_LatestItemsHTML = new MvcHtmlString(latestItemsStr); } }