ASP.NET MVC5 Tutorial - Implementing Search and Filter Functionalities in your Web Application

in #utopian-io6 years ago (edited)

Today I will be starting a tutorial series on ASP.NET MVC5 framework. ASP.NET MVC5 is an open source web framework for building modern web apps and services with .NET

aspdotnetlogo-01.jpg
Image Source

For the sake of redundancy, I would not be making a standalone tutorial on setting up your project nor explaining the file structure. I would include all of that in this initial tutorial to cater for those that are not familiar with it before now.

What Will I Learn?

  • You will learn how to install and set up the ASP.NET MVC5 project template.
  • You will learn the basics of, and understand the folder structure of the project template.
  • You will learn to set up your database using entity framework code first approach
  • You will learn how to seed a database with data
  • You will create an application to that keeps record of all your steemit followers and sort/filter them based on certain criteria

Requirements

  • Visual Studio IDE (2015 or 2017 preferably)
  • Browser
  • Basic knowledge of Web development

Difficulty

  • Intermediate

Tutorial Content

For this tutorial, we are going to build an application that gets all your steem followers, search within them and filter them using specific properties that you want to group them with. However, we won't be using real steem followers. We are going to use dummy data that I have created here for this tutorial. In a subsequent tutorial, we would learn how to fetch actual data using the Steem API

  • Installing and Setting Up the MVC project

Open Visual studio, select File->New->Project
Select ASP.NET Web Application (.NET Framework)
Give it a name and click Ok I'm calling mine SteemitUtopianTutorial
Select the MVC template in the next window
Do not change the authentication. Leave it the way it is
Click Ok

MVC5 Project Folder structure

Capture.PNG
The three main folders that would normally concern you are the Model, View and Controller folders, for obvious reasons, and they are pretty straight forward.

Models folder houses your entity models which map to database tables.
Controllers house the controller classes that perform business logic and sends information in the form of models to views.
Views displays the information to the user.

App_Data folder is where portable database files in form of .mdf files are stored
App_Start contains configuration files for the application startup.
Content contains stylesheets and static files such as images(if you wish to put them here)
fonts obviously stores glyphicon fonts
Scripts contain the script files majorly javascript
Web Config file stores general configuration settings for the application.

Just so I don't stray so far from the purpose of this tutorial, I would stop here. This should be enough to get you to understand the file/folder structure in front of you.

Setting Up the Database

Definitely to develop any reasonable application that does the least of interactions, you need to be able to store data in a database. Microsoft provides different approaches to setting up your database - Code First, Database First, Design First.
However, for this tutorial, we are going to use Code First Approach which allows you set up a database from your models without having to actually write any SQL command. EntityFramework takes care of all the implementation and mapping, by the relationships you define in your models.

But first we have to install EntityFramework.
Right Click on your solution and select Manage Nuget Packages for Solution then search for EntityFramework under the browse tab and install

Defining Our Model

Now we want to define our SteemFollower model. This means that we are going to define the properties that a Steem user has. The following properties are some of the important ones that came to my mind. Of course, you can define more for your consumption.

   public class SteemFollower
    {
        public int Id { get; set; }
        public string UserName { get; set; }
        public int Reputation { get; set; }
        public int SteemPower { get; set; }        
    }

Create a Database Context

A database context is a class that interfaces your application to your database. It is that connection with which you can query your database using code.

Right click on your project and add a new folder. Thereafter, add your new database context class in that folder. I called mine SteemFollowerContext

Add the following code to the new class

public class DatabaseInitializer : System.Data.Entity.DropCreateDatabaseIfModelChanges<SteemFollowerContext>
{
    protected override void Seed(SteemFollowerContext context)
    {
        var steemFollowers = new List<SteemFollower>
        {
            new SteemFollower{UserName="johnesan", Reputation= 52, SteemPower=9592123.311},
            new SteemFollower{UserName="udestine", Reputation= 33, SteemPower=35.433},
            new SteemFollower{UserName="sqerter", Reputation= 76, SteemPower=33323.235},
            new SteemFollower{UserName="title32", Reputation= 44, SteemPower=29.432},
            new SteemFollower{UserName="googler33", Reputation= 19, SteemPower=14.904},
            new SteemFollower{UserName="steemwitness", Reputation= 53, SteemPower=175.335},
            new SteemFollower{UserName="utopian-io", Reputation= 64, SteemPower=39034.895},
            new SteemFollower{UserName="aser991", Reputation= 67, SteemPower=1023452.432},
            new SteemFollower{UserName="eddiejones", Reputation= 28, SteemPower=29.235},
            new SteemFollower{UserName="packman5499", Reputation= 34, SteemPower=312.905},
            new SteemFollower{UserName="owerfre", Reputation= 47, SteemPower=35.553},
            new SteemFollower{UserName="oterwd", Reputation= 51, SteemPower=3228.345},
            new SteemFollower{UserName="lordrahl", Reputation= 43, SteemPower=1189.02},
            new SteemFollower{UserName="flaggedman", Reputation= 8, SteemPower=6.325},
            new SteemFollower{UserName="underlin21", Reputation= 52, SteemPower=2266.78},
            new SteemFollower{UserName="cunrered", Reputation= 60, SteemPower=41000.22},
            new SteemFollower{UserName="curie", Reputation= 77, SteemPower=239009.221},
            new SteemFollower{UserName="sycochika", Reputation= 71, SteemPower=37623.325},
            new SteemFollower{UserName="anonym", Reputation= 60, SteemPower=3109235.27},
            new SteemFollower{UserName="retris000", Reputation= 58, SteemPower=3599.78},
            new SteemFollower{UserName="eadde", Reputation= 43, SteemPower=8908654.24},
            new SteemFollower{UserName="realfew123", Reputation= 38, SteemPower=322.675},
            new SteemFollower{UserName="justinwerth", Reputation= 25, SteemPower=25.44},
            new SteemFollower{UserName="resteemed", Reputation= 48, SteemPower=90.3},
            new SteemFollower{UserName="esteem", Reputation= 41, SteemPower=3889.235},
            new SteemFollower{UserName="unidentified", Reputation= 65, SteemPower=97667.5},
            new SteemFollower{UserName="jaff8", Reputation= 62, SteemPower=1700.234},
            new SteemFollower{UserName="pleasth", Reputation= 55, SteemPower=425811.867},
            new SteemFollower{UserName="comings4wel", Reputation= 72, SteemPower=55894.36},
            new SteemFollower{UserName="striken329", Reputation= 28, SteemPower=16.657},
        };
        steemFollowers.ForEach(s => context.SteemFollowers.Add(s));
        context.SaveChanges();

    }
}

This is all just some random data I created on my own for tutorial purposes. None if it has any real world significance or implication. Its only just useful to seed the database with something so we could work with.
Note that, in a real life scenario, this data would be fetched from the steem API (I would make a tutorial on this later)

Adding Connection String

All we've done so far is write the codes that will be executed to scaffold our database. We haven't actually made any connection to the database itself. This process is done with a connection string. A connection string tells the application which, and how to connect to the database.

Open Web.Config file in the root,
Just before the "appsettings" element, add a "connectionStrings" element

 <connectionStrings>
    <add name="SteemFollowerContext" connectionString="Data Source=USER\SQLEXPRESS;Initial Catalog=SteemFollowerDb;Integrated Security=True" providerName="System.Data.SqlClient"/>
  </connectionStrings>

Note that the data source of your connection string would differ from the one I have here. "USER" would be the name of your computer or server(for production purposes). Get more information on connection strings here.

One more thing...
We havent specified anywhere that the database context should use that seed initializer class.
Head on to that same web.config file and add this within the EntityFramework

<contexts>
      <context type="SteemitUtopianTutorial.Data.SteemFollowerContext, SteemFollowerContext">
        <databaseInitializer type="SteemitUtopianTutorial.Data.DatabaseInitializer, SteemFollowerContext" />
      </context>
    </contexts>

This tells EntityFramework to use the database initializer class when the database context is created.

Build the Solution

Creating The Controllers and Views

Now that the database is all set up, let's create our controllers and view and thereafter implement searching within our steem followers.

Right click on the Controllers folder, select Add, then click New Scaffolded Item.
** In the Add Scaffold dialog box, select MVC 5 Controller with views, using Entity Framework. Then click Ok**

Add the following details appropriately as shown in the screenshot
Screenshot (340).png

Click Add
EntityFramework scaffolds for you, a CRUD controller along with the corresponding views. After that is done, Run the application
Now navigate to "http://localhost:58110/SteemFollowers" You should see the seed data we inputted
Screenshot (341).png

Adding Search Functionality

The first thing to think of when dealing with a search, is the "search string". That string is what is going to be used to query the database and deliver related results.
We are going to perform a get request to our Index method of the SteemFollowerController, but this time with a search string to indicate to the database that we want specific data.
To achieve this
we pass in a parameter to the method, and using that parameter, we query the database with LINQ
Now edit the index action of your controller to this:

   public ActionResult Index(string searchString)
        {
            var steemFollowers = from s in db.SteemFollowers
                                 select s;
            if (!String.IsNullOrEmpty(searchString)) {
                steemFollowers = steemFollowers.Where(s => s.UserName.ToUpper().Contains(searchString.ToUpper()));
            }
            return View(steemFollowers.ToList());
        }

Now we have to find a way to let the user pass in their search string and send it to the controller for action

In your Views Folder, open the Index.cshtml file in the SteemFollowers folder
Just before the table, add this chunk of code

@using (Html.BeginForm())
{ 
    <p> Find by name: @Html.TextBox("SearchString") <input type="submit" value="Search" /></p> 
}

Run the application and try to search. You should get results from your steem Followers list containing the string.

Screenshot (342).png

Filtering Users using their Steem Power and Reputation

To filter users, we want to provide "minimum" and "maximum" range values to the controller.
Also, we want to filter users using either their Steem power or Reputation.

In your Index.cshtml View, add the following code just after your search box

@using(Html.BeginForm("Index", "SteemFollowers", FormMethod.Get))
{
    <p>
        <b>Filter By:</b> @Html.RadioButton("FilterBy", "SteemPower", true) Steem Power
        @Html.RadioButton("FilterBy", "Reputation") Reputation
        <input type="number" name="Minimum"/>
        <input type="number" name="Maximum" />
        <input type="submit" value="Filter" />
    </p>
}

Now for the code that actually does the filtering,
Update your Index Controller Action to the following

  public ActionResult Index(string searchString, string FilterBy, int? Minimum, int? Maximum)
        {
            var steemFollowers = from s in db.SteemFollowers
                                 select s;
            if (!String.IsNullOrEmpty(searchString)) {
                steemFollowers = steemFollowers.Where(s => s.UserName.ToUpper().Contains(searchString.ToUpper()));
            }

            if (!String.IsNullOrEmpty(FilterBy))
            {
                if(FilterBy == "SteemPower")
                {
                    steemFollowers = steemFollowers.Where(s => s.SteemPower >= Minimum && s.SteemPower <= Maximum);
                }
                if (FilterBy == "Reputation")
                {
                    steemFollowers = steemFollowers.Where(s => s.Reputation >= Minimum && s.Reputation <= Maximum);
                }
            }
            return View(steemFollowers.ToList());
        }

Run the Application again

Screenshot (343).png

Screenshot (344).png

Notice how you can select to filter by "SteemPower" or "Reputation" . Also, notice how the Url contains the parameters as a query.

You can take this functionality and plug it anywhere, to suit your needs.

This is the first tutorial of this series. Subsequently, I would be giving similar tutorials on technical aspects of developing using ASP.NET MVC5. Also, I will start another tutorial series for those interested in mobile development with Xamarin.



Posted on Utopian.io - Rewarding Open Source Contributors

Sort:  

Thank you for the contribution. It has been approved.

You can contact us on Discord.
[utopian-moderator]

@johnesan, No matter approved or not, I upvote and support you.

Dope idea

This work deserves to be approved. But don't worry, keep steeming

Hey @johnesan I am @utopian-io. I have just upvoted you!

Achievements

  • You have less than 500 followers. Just gave you a gift to help you succeed!
  • Seems like you contribute quite often. AMAZING!

Suggestions

  • Contribute more often to get higher and higher rewards. I wish to see you often!
  • Work on your followers to increase the votes/rewards. I follow what humans do and my vote is mainly based on that. Good luck!

Get Noticed!

  • Did you know project owners can manually vote with their own voting power or by voting power delegated to their projects? Ask the project owner to review your contributions!

Community-Driven Witness!

I am the first and only Steem Community-Driven Witness. Participate on Discord. Lets GROW TOGETHER!

mooncryption-utopian-witness-gif

Up-vote this comment to grow my power and help Open Source contributions like this one. Want to chat? Join me on Discord https://discord.gg/Pc8HG9x