/// <summary> /// search the project name /// </summary> /// <param name="query">search the project name field</param> /// <returns>returns the project searched </returns> public string SearchProject(string query, SearchArgs args) { query = query.ToLower(); var projectlist = ProjectList.AsEnumerable().Select(row => new projectList { ProjectId = row.Field <int>("ProjectId"), ProjectName = row.Field <string>("ProjectName"), ProjectDescription = row.Field <string>("ProjectDescription"), }).ToList(); var returnObj = new List <object>(); var projects = (from p in projectlist where ((((!string.IsNullOrEmpty(p.ProjectName)) ? p.ProjectName.ToLower() : "").StartsWith(query.ToLower())) || ((!string.IsNullOrEmpty(p.ProjectDescription)) ? p.ProjectDescription.ToLower() : "").StartsWith(query.ToLower()))orderby(p.ProjectName + "" + p.ProjectDescription) select p).Take(10).ToList(); foreach (var project in projects) { var builder = new StringBuilder(); builder.Append("<div id=\""); builder.Append(project.ProjectName); builder.Append("\" class=\"InstantSearch\" >"); builder.Append("<span class=\"details\">"); builder.Append(Regex.Replace(project.ProjectName, query, "<strong>" + CultureInfo.CurrentCulture.TextInfo.ToTitleCase(query) + "<strong>", RegexOptions.IgnoreCase)); builder.Append("</span></div>"); returnObj.Add(new { html = builder.ToString(), fullName = project.ProjectId, }); } if (args.GetPayLoad) { foreach (var project in projects) { returnObj.Add(new { data = project }); } } return(serializer.Serialize(returnObj)); }
/// <summary> /// /// </summary> /// <param name="query"></param> /// <param name="args"></param> /// <returns></returns> public string SearchAll(string query, SearchArgs args) { query = query.ToLower(); var returnObj = new List <object>(); var userlist = UserList.AsEnumerable().Select(row => new userList { UserName = row.Field <string>("UserName"), FullName = row.Field <string>("FullName"), Email = row.Field <string>("Email"), FullNameLower = row.Field <string>("FullNameLower"), }).ToList(); var projectlist = ProjectList.AsEnumerable().Select(row => new projectList { ProjectName = row.Field <string>("ProjectName"), ProjectDescription = row.Field <string>("ProjectDescription"), }).ToList(); var reportlist = ReportList.AsEnumerable().Select(row => new reportList { ReportName = row.Field <string>("ReportName"), ReportDescription = row.Field <string>("ReportDescription"), }).ToList(); var usergrouplist = UserGroupList.AsEnumerable().Select(row => new userGroupList { GroupName = row.Field <string>("GroupName"), GroupDescription = row.Field <string>("GroupDescription"), }).ToList(); var users = (from u in userlist where ((((!string.IsNullOrEmpty(u.UserName)) ? u.UserName.ToLower() : "").StartsWith(query.ToLower())) || (((!string.IsNullOrEmpty(u.FullName)) ? u.FullName.ToLower() : "").StartsWith(query.ToLower())) || (((!string.IsNullOrEmpty(u.FullNameLower)) ? u.FullNameLower.ToLower() : "").StartsWith(query.ToLower())) || u.Email.Substring(0, u.Email.IndexOf('@')).StartsWith(query) || (((!string.IsNullOrEmpty(u.Email)) ? u.Email.ToLower() : "").StartsWith(query.ToLower())))orderby(u.UserName + "" + u.FullName + "" + u.Email + "" + u.FullNameLower) select u).ToList(); var groups = (from g in usergrouplist where ((((!string.IsNullOrEmpty(g.GroupName)) ? g.GroupName.ToLower() : "").StartsWith(query.ToLower())) || ((!string.IsNullOrEmpty(g.GroupDescription)) ? g.GroupDescription.ToLower() : "").StartsWith(query.ToLower()))orderby(g.GroupName + "" + g.GroupDescription) select g).Take(10).ToList(); var reports = (from r in reportlist where ((((!string.IsNullOrEmpty(r.ReportName)) ? r.ReportName.ToLower() : "").StartsWith(query.ToLower())) || ((!string.IsNullOrEmpty(r.ReportDescription)) ? r.ReportDescription.ToLower() : "").StartsWith(query.ToLower()))orderby(r.ReportName + "" + r.ReportDescription) select r).Take(10).ToList(); var projects = (from p in projectlist where ((((!string.IsNullOrEmpty(p.ProjectName)) ? p.ProjectName.ToLower() : "").StartsWith(query.ToLower())) || ((!string.IsNullOrEmpty(p.ProjectDescription)) ? p.ProjectDescription.ToLower() : "").StartsWith(query.ToLower()))orderby(p.ProjectName + "" + p.ProjectDescription) select p).Take(10).ToList(); if (args.ShowImage) { foreach (var user in users) { var builder = new StringBuilder(); builder.Append("<div id=\""); builder.Append(user.FullNameLower); builder.Append("\" class=\"InstantSearch\" >"); //Change this code to the column name which has the user proifile image //if(string.IsNullOrWhiteSpace(user.UserName)) if (10 > 20) { builder.Append("<span class=\"user-avatar\"><img src=\"data:image/png;base64," + ImageResizer(user.UserName, 24, 24) + "\" /></span>"); } else { builder.Append("<span class=\"user-avatar\"><img src=\"\" /></span>"); } builder.Append("<span class=\"details\">"); builder.Append(Regex.Replace(user.FullName, query, "<strong>" + CultureInfo.CurrentCulture.TextInfo.ToTitleCase(query) + "</strong>", RegexOptions.IgnoreCase) + " "); builder.Append(" - " + Regex.Replace(user.Email.Substring(0, user.Email.IndexOf('@')), query, "<strong>" + CultureInfo.CurrentCulture.TextInfo.ToTitleCase(query) + "</strong>", RegexOptions.IgnoreCase) + user.Email.Substring(user.Email.IndexOf("@"))); builder.Append("</span>"); builder.Append("</div>"); returnObj.Add(new { html = builder.ToString(), fullName = user.FullName, }); } } else { foreach (var user in users) { var builder = new StringBuilder(); builder.Append("<div id=\""); builder.Append(user.FullNameLower); builder.Append("\" class=\"InstantSearch\" >"); builder.Append("<span class=\"details\">"); builder.Append(Regex.Replace(user.FullName, query, "<strong>" + CultureInfo.CurrentCulture.TextInfo.ToTitleCase(query) + "</strong>", RegexOptions.IgnoreCase) + " "); builder.Append(" - " + Regex.Replace(user.Email.Substring(0, user.Email.IndexOf('@')), query, "<strong>" + CultureInfo.CurrentCulture.TextInfo.ToTitleCase(query) + "</strong>", RegexOptions.IgnoreCase) + user.Email.Substring(user.Email.IndexOf("@"))); builder.Append("</span>"); builder.Append("</div>"); returnObj.Add(new { html = builder.ToString(), fullName = user.FullName, }); } } foreach (var project in projects) { var builder = new StringBuilder(); builder.Append("<div id=\""); builder.Append(project.ProjectName); builder.Append("\" class=\"InstantSearch\" >"); builder.Append("<span class=\"details\">"); builder.Append(Regex.Replace(project.ProjectName, query, "<strong>" + CultureInfo.CurrentCulture.TextInfo.ToTitleCase(query) + "<strong>", RegexOptions.IgnoreCase)); builder.Append("</span></div>"); returnObj.Add(new { html = builder.ToString(), fullName = project.ProjectName }); } foreach (var group in groups) { var builder = new StringBuilder(); builder.Append("<div id=\""); builder.Append(group.GroupName); builder.Append("\" class=\"InstantSearch\" >"); builder.Append("<span class=\"details\">"); builder.Append(Regex.Replace(group.GroupName, query, "<strong>" + CultureInfo.CurrentCulture.TextInfo.ToTitleCase(query) + "<strong>", RegexOptions.IgnoreCase)); builder.Append("</span></div>"); returnObj.Add(new { html = builder.ToString(), fullName = group.GroupName }); } foreach (var report in reports) { var builder = new StringBuilder(); builder.Append("<div id=\"report_"); builder.Append(report.ReportName); builder.Append("\" class=\"InstantSearch\" >"); //if (report.Image != null) // builder.Append("<span><img src=\"data:image/png;base64," + ImageResizer(report.Image, 24, 24) + "\"/></span>"); //else builder.Append("<span><img/></span>"); builder.Append("<span class=\"details\">"); builder.Append(Regex.Replace(report.ReportName, query, "<strong>" + CultureInfo.CurrentCulture.TextInfo.ToTitleCase(query) + "</strong>", RegexOptions.IgnoreCase)); builder.Append("</span></div>"); returnObj.Add(new { html = builder.ToString(), fullName = report.ReportName }); } if (args.GetPayLoad) { foreach (var user in users) { returnObj.Add(new { data = user, }); } foreach (var group in groups) { returnObj.Add(new { data = group }); } foreach (var report in reports) { returnObj.Add(new { data = report }); } foreach (var project in projects) { returnObj.Add(new { data = project }); } } return(serializer.Serialize(returnObj)); }