How to work Area in MVC || RAJESH GAMI






Working with Area

Basically, Area are used to better manage large projects. For example, you might have an e-commerce application with admins, shops, billing sections, and admins managing back-end tasks such as creating categories, catalogs, prices, and so on. The store is an end-user portal for searching, which you add to your cart selection and where billing is done and delivery is managed.
 
As you can see, each of these sections is functionally very large and can be easily divided into sections. Let's see how to start from the Area.

Add an area in a MVC project

1. In the new MVC4 application, right-click on the project and select Add> Area

add-area

2. Name the Area ‘Admin’

3. This will create an Areas folder  with the following hierarchy added to your project

new-area-folder-hierarchy

4. AdminAreaRegistration.cs file. The generated class looks like this

public class AdminAreaRegistration : AreaRegistration
{
public override string AreaName
{
  get
  {
   return "Admin";
  }
}
public override void RegisterArea(AreaRegistrationContext context)
{
  context.MapRoute(
   "Admin_default",
   "Admin/{controller}/{action}/{id}",
   new { action = "Index", id = UrlParameter.Optional }
   );
}
}

As you can see from the class, it derives from the AreaRegistration class and overrides the AreaName  and  RegisterArea properties. 

a. AreaName returns the name you specified when you created the area. 

b. RegisterArea registers a new route for an area that begins with "Admin" (the name of the area) by calling the MapRoute method of the context. 

5. Next, let's open Global.asax and check the order of the routes. Note that AreaRegistration.RegisterAllAreas () is called before RouteConfig.RegisterRoutes (). This basically means  that the above route is registered before the default ASP.NET root is installed. This is important because you can call / HomeController / Index / and / Admin / HomeController / Index. If / HomeController / Index is registered first, navigation to / Admin / HomeController / Index will be redirected to the wrong controller class.


protected void Application_Start()
{
AreaRegistration.RegisterAllAreas();
WebApiConfig.Register(GlobalConfiguration.Configuration);
FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters);
RouteConfig.RegisterRoutes(RouteTable.Routes);
BundleConfig.RegisterBundles(BundleTable.Bundles);
AuthConfig.RegisterAuth();
}

Now that we've added a new area, let's add a controller and a view. Also call the  controller HomeController in the new area to test the routing. 

add-controller

Next, add a new view named Index to the Areas \ Admin \ View \ Home folder, add _ViewStart.cshtml to the Areas \ Admin \ View \ folder, and add the Areas \ Admin \ View \ Shared folder. Add _Layout.cshtml. .. 

adding-views

@{
    ViewBag.Title = "Index";
}

<h2>Areas\Home\Index</h2>
Listing 3 Index.cshtml

@{
Layout = "~/Views/Shared/_Layout.cshtml";
}
Listing 4 _ViewStart.cshtml
@{
Layout = null;
}
<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>Admin Area</title>
</head>
<body>
<h1>Admin Area</h1>
<div>
  @RenderBody()
</div>
</body>
</html>

Listing 5 _Layout.cshtml

 Now let's run the application. Before you reach the home page, it will be the next YSoD (Yellow Screen of Death).

multiple-controller-ysod

Don't you like the redundancy of exceptions? In plain language, this means: If you  have two controllers named HomeController, you need to specify their namespace when you register the route.

The AreaRegistrationContext is said to have used the namespace when registering the route with the RegisterArea method  we saw earlier. This leaves a default route registration with no namespace defined. Go to App_Start \ RouteConfig.cs and add the Namespaces parameter to your MapRoute method call. Pass the MvcAreasDemo.Controllers namespace as a parameter of the default HomeController.

public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");
routes.MapRoute(
  name: "Default",
  url: "{controller}/{action}/{id}",
  defaults: new {
   controller = "Home",
   action = "Index",
   id = UrlParameter.Optional },
   // add the explicit namespaces param when using Areas
   namespaces: new [] { "MvcAreasDemo.Controllers" }
);
}

  

Default MVC launch page

default-view-one-aread

Now when you go to the admin / home URL, you'll see that the home controller in the admin panel is working. 

Adding another Area

Now that the new scope has been added  and is working fine, how can I tell if the second scope is causing a  routing conflict? Now, as mentioned earlier, the AreaRegistrationContext internally passes the NameSpace to the root configuration. Therefore, multiple areas registered via the AreaRegistrationContext do not cause any problems. For your safety, add another scope called Store and add a HomeController  (do not copy from the admin scope or create a subclass between the admin scope and the store scope). You can copy the view and update it accordingly. 
Run the  application and go to all  three HomeControllers to view the pages individually.

 default-view-two-areas

Conclusion

In summary, sections are a useful configuration when trying to build a large front-end system with well-separated functional sections. The only problem is that controllers with the same name in scope must have different namespaces, and the default route (if used)  explicitly provides namespace parameters during controller configuration. That's what you need to do.


Set route as shown below into RouteConfig.cs file

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using System.Web.Routing;

namespace CableSoft
{
    public class RouteConfig
    {
        public static void RegisterRoutes(RouteCollection routes)
        {
            routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

            routes.MapRoute(
                name: "Default",
                url: "{controller}/{action}/{id}",
                defaults: new {area="Admin",controller = "Login", action = "Index", id = UrlParameter.Optional }
            ).DataTokens.Add("area""Admin");
        }
    }
}

Simple CRUD [ Insert, Update, Delete ] in MVC || RAJESH GAMI


Simple CRUD [Insert, Update, Delete]

Here I have explain how to create simple insert update delete using asp.net MVC, So simply follow below steps and see the result.

Step 1 
Let's create model and give name CompanyMaster and Create table in database as shown as model fields 
Model
using System.Data.Entity;
using System.ComponentModel.DataAnnotations;
using System.ComponentModel.DataAnnotations.Schema;

namespace MyProject.Models
{
    [Table("CompanyMaster")]
    public class CompanyMaster
    {
        [Key]
        [DatabaseGeneratedAttribute(DatabaseGeneratedOption.Identity)]

        public int CMPId { get; set; }
        public string CMPEnc { get; set; }
        [Display(Name = "Company Name")]
        public string CMPName { get; set; }
    }

    public class CompanyMasterContext : DbContext
    {
        public CompanyMasterContext() : base("ConString_Name")
        {
        }
        public DbSet<CompanyMaster> CompanyMaster { get; set; }

    }
}

Step 2

Now add new controller and give name "AdminCompanyController",And add all methods as shown as in below controller. it's Area controller but we can use simple controller also

Controller
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
using MyProject.Models;
using System.Data.Entity;

namespace MyProject.Areas.Admin.Controllers
{
    public class AdminCompanyController : Controller
    {
        CompanyMasterContext _companyContext = new CompanyMasterContext();

        public ActionResult Index()
        {
            if (Session["AdminId"] != null)
            {
                var list = _companyContext.CompanyMaster.ToList();
                return View(list);
            }
            else
            {
                return RedirectToAction("Login", "Admin", new { area = "Admin" });
            }

        }

        public ActionResult Create()
        {
            if (Session["AdminId"] != null)
            {
                return View();
            }
            else
            {
                return RedirectToAction("Login", "Admin", new { area = "Admin" });
            }
        }
        [HttpPost]
        public ActionResult Create(CompanyMaster companyMaster)
        {
            if (Session["AdminId"] != null)
            {
                if (ModelState.IsValid)
                {
                    _companyContext.CompanyMaster.Add(companyMaster);
                    _companyContext.SaveChanges();
                    companyMaster.CMPEnc = enc.Encrypt(companyMaster.CMPId);
                    _companyContext.SaveChanges();
                    return RedirectToAction("Index");
                }
                else
                {
                    return View(companyMaster);
                }
           
            }
            else
            {
                return RedirectToAction("Login", "Admin", new { area = "Admin" });
            }
        }

        public ActionResult Edit(string id)
        {
            if (Session["AdminId"] != null)
            {
                string myId = id.Substring(1, 6);
                int ID = enc.Decrypt(myId);
                var update = _companyContext.CompanyMaster.Where(b => b.CMPId.Equals(ID)).FirstOrDefault();
                return View(update);
            }
            else
            {
                return RedirectToAction("Login", "Admin", new { area = "Admin" });
            }
        }
        [HttpPost]
        public ActionResult Edit(CompanyMaster companyMaster)
        {
            if (Session["AdminId"] != null)
            {
                if (ModelState.IsValid)
                {
                    _companyContext.Entry(companyMaster).State = EntityState.Modified;
                    _companyContext.SaveChanges();
                    return RedirectToAction("Index");
                }
                else
                {
                    return View(companyMaster);
                }
            }
            else
            {
                return RedirectToAction("Login", "Admin", new { area = "Admin" });
            }
        }

        public ActionResult Details(string id)
        {
            if (Session["AdminId"] != null)
            {
                string myId = id.Substring(1, 6);
                int ID = enc.Decrypt(myId);
                var detail = _companyContext.CompanyMaster.Where(b => b.CMPId.Equals(ID)).FirstOrDefault();
                return View(detail);
            }
            else
            {
                return RedirectToAction("Login", "Admin", new { area = "Admin" });
            }
        }

        [HttpPost]
        public ActionResult Delete(string id)
        {
            if (Session["AdminId"] != null)
            {
                string myID = id.Substring(1, 6);
                int ID = enc.Decrypt(myID);
                var del = _companyContext.CompanyMaster.Where(b => b.CMPId.Equals(ID)).FirstOrDefault();
                _companyContext.CompanyMaster.Remove(del);
                _companyContext.SaveChanges();
                return RedirectToAction("Index");
            }
            else
            {
                return RedirectToAction("Login", "Admin", new { area = "Admin" });
            }
        }
    }
}

Step 3
It's time to add Views for all methods like List, Create, Edit, Detail and Detail
Add view like below, See below views I have created all of them

View:
Index [ List ]
@model IEnumerable<MyProject.Models.CompanyMaster>

@{
    ViewBag.Title = "Company";
    Layout = "~/Areas/Admin/Views/Shared/_Layout.cshtml";
}

<div class="entry">
    <h4>Company List</h4>
    <div class="row nt-table table-responsive">
        <table class="">
            <tr>
                <th>
                    <div class="tbl-srNo">
                        Sr No
                    </div>
                </th>
                <th>
                    <div class="tbl-name">
                        @Html.DisplayNameFor(model => model.CMPName)
                    </div>
                 
                </th>
                <th colspan="3">
                    <div class=" tbl-contact">
                        Action
                    </div>
                </th>
            </tr>
            @{
                int SrNo = 0;
            }
            @foreach (var item in Model)
            {
                <tr>
                    @{
                        SrNo++;
                    }

                    <td>@SrNo</td>

                    <td>
                        @Html.DisplayFor(modelItem => item.CMPName)
                    </td>
                    <td style="width:40px">
                        <a href="~/Admin/AdminArea/Edit/@item.CMPEnc" title="Edit"><i class="icofont icofont-open-eye"></i></a>
                    </td>
                    <td style="width:40px">
                        <a href="~/Admin/AdminArea/Details/@item.CMPEnc" title="Details"><i class="icofont icofont-info-square"></i></a>
                    </td>
                    <td style="width:6%">

                        @using (Html.BeginForm("Delete", "AdminCompany", FormMethod.Post, new { id = item.CMPEnc, @class = "myForm" }))
                {

                            <input type="hidden" value="@item.CMPEnc" name="id" />
                            var myModal = "myModal" + item.CMPEnc;
                            <a href="" type="button" class="btn btn-sqr2 form-delete" data-toggle="modal" data-target="#@myModal" title="Delete"><i class="icofont icofont-basket"></i></a>
                            <!--Modal-->

                            <div class="modal fade" id="@myModal" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">
                                <div class="modal-dialog modal-sm" role="document" style="position: initial;width: 410px; margin-top:140px">
                                    <div class="modal-content">
                                        <div class="modal-header">
                                            <button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
                                            <h3 class="modal-title" id="myModalLabel" style="color: #f20000;">Confirm Delete</h3>
                                        </div>
                                        <div class="modal-body">
                                            Are you sure you want to delete : <span><b style="color: red;font-size: 16px;"> @item.CMPName </b>?</span>
                                        </div>
                                        <div class="modal-footer">
                                            <button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
                                            <input type="submit" value="Delete" class="btn btn-danger" />
                                        </div>
                                    </div>
                                </div>
                            </div>
                        }
                    </td>
                </tr>
                        }

        </table>
    </div>
</div>

Create [ Add Company ]
@model MyProject.Models.CompanyMaster

@{
    ViewBag.Title = "Create";
    Layout = "~/Areas/Admin/Views/Shared/_Layout.cshtml";
}


@using (Html.BeginForm())
{
    @Html.AntiForgeryToken()
    <div class="entry">
        <h4>Add Company <a href="~/Admin/AdminCompany" class="btn btn-info" style="float:right;margin:-7px">Company List</a></h4>
        @Html.ValidationSummary(true, "", new { @class = "text-danger" })
        <div class="row">
            <div class="col-md-4 form-group">
                <div class="entry-1">
                    @Html.LabelFor(model => model.CMPName, htmlAttributes: new { @class = "" })
                    @Html.EditorFor(model => model.CMPName, new { htmlAttributes = new { @class = "form-control" } })
                    @Html.ValidationMessageFor(model => model.CMPName, "", new { @class = "text-danger" })
                </div>
            </div>
            <div class="col-md-8">
                <div class="entry-1">
                    <button type="submit" class="btn btn-success" style="background-color: #218838;">Submit</button>
                </div>
            </div>
        </div>
    </div>

}


@section Scripts {
    @Scripts.Render("~/bundles/jqueryval")
}

Edit [ Update company ]
@model MyProject.Models.CompanyMaster

@{
    ViewBag.Title = "Edit";
    Layout = "~/Areas/Admin/Views/Shared/_Layout.cshtml";
}

@using (Html.BeginForm())
{
    @Html.AntiForgeryToken()
    <div class="entry">
        <h4>Edit Company</h4>
        @Html.ValidationSummary(true, "", new { @class = "text-danger" })
        @Html.HiddenFor(model => model.CMPId)
        @Html.HiddenFor(model => model.CMPEnc)
        <div class="row">
            <div class="col-md-4 form-group">
                <div class="entry-1">
                    @Html.LabelFor(model => model.CMPName, htmlAttributes: new { @class = "" })
                    @Html.EditorFor(model => model.CMPName, new { htmlAttributes = new { @class = "form-control" } })
                    @Html.ValidationMessageFor(model => model.CMPName, "", new { @class = "text-danger" })
                </div>
            </div>
            <div class="col-md-8">
                <div class="entry-1">
                    <button type="submit" class="btn btn-success" style="background-color: #218838;">Submit</button>
                    <a class="btn btn-success" href="~/Admin/AdminCompany" style="background-color: #218838; margin-top:35px;">Back</a>
                </div>
            </div>
        </div>
    </div>
}


@section Scripts {
    @Scripts.Render("~/bundles/jqueryval")
}


Details [ Company details ]

@model MyProject.Models.CompanyMaster

@{
    ViewBag.Title = "Details";
    Layout = "~/Areas/Admin/Views/Shared/_Layout.cshtml";
}

<div class="entry">
    <h4>Company Details</h4>
    @Html.ValidationSummary(true, "", new { @class = "text-danger" })
    @Html.HiddenFor(model => model.CMPId)
    @Html.HiddenFor(model => model.CMPEnc)
    <div class="row">
        <div class="col-md-4 form-group">
            <div class="entry-1 entry-view">
                @Html.LabelFor(model => model.CMPName, htmlAttributes: new { @class = "" })
                @Html.EditorFor(model => model.CMPName, new { htmlAttributes = new { @class = "", @disabled = "disabled" } })
                @Html.ValidationMessageFor(model => model.CMPName, "", new { @class = "text-danger" })
            </div>
        </div>
        <div class="col-md-8">
            <div class="entry-1">
                <a class="btn btn-success" href="~/Admin/AdminCompany" style="background-color: #218838; margin-top:35px;">Back</a>
            </div>
        </div>
    </div>
</div>



Let's run the project and see the result 

RAJESH GAMI - Blog

Digital Signature Pad in Angular | RAJESH GAMI

  What is Signature Pad? Signature Pad could be a JavaScript library for drawing fancy signatures. It supports HTML5 canvas and uses variabl...