예제 #1
0
        /// <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));
        }
예제 #2
0
        /// <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));
        }