Reputation: 184
I Bind dropdown using list of string using recursive function
My dropdown have value like
Home
Home>> Kitchen
Home>> Kitchen>> ABC
and i want to Same dropdown value ABC in database
This is my View code
@{
ViewBag.Title = "Createnewproduct";
}
<h2>
Create new product</h2>
<div>
@using (Html.BeginForm("Createnewproduct", "ProductAdmin", FormMethod.Post, new { id = "sendFileForm", enctype = "multipart/form-data" }))
{
<table>
<tr>
<td>
Category
</td>
<td>
@Html.DropDownList("Test", new SelectList(ViewBag.ListOfDisciplines, Model))
</td>
</tr>
<tr>
<td>
Product Name
</td>
<td>
<input type="text" name="ProductName">
</td>
</tr>
<tr>
<td>
Product Description
</td>
<td>
<input type="text" name="ProductDescription">
</td>
</tr>
<tr>
<td>
Product long Description
</td>
<td>
<input type="text" name=" ProductlongDescription">
</td>
</tr>
<tr>
<td>
UPC
</td>
<td>
<input type="text" name="UPC">
</td>
</tr>
<tr>
<td>
SKU
</td>
<td>
<input type="text" name="SKU">
</td>
</tr>
<tr>
<td>
Stock
</td>
<td>
<input type="text" name="Stock">
</td>
</tr>
<tr>
<td>
Weight
</td>
<td>
<input type="text" name="Weight">
</td>
</tr>
<tr>
<td>
Height
</td>
<td>
<input type="text" name="Height">
</td>
</tr>
<tr>
<td>
Image URL
</td>
<td>
<input type="file" name="file" id="file" style="width: 100%;" id="Imageupload" />
</td>
</tr>
<tr>
<td rowspan="2">
<input type="submit" value="Save" />
</td>
</tr>
</table>
}
</div>
and my controller like this
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Createnewproduct(FormCollection form)
{
}
when i see my FormCollection value there i did not find dropdown value , all other value properly find in FormCollection
Please help me where i did the mistake in this code
public ActionResult Createnewproduct()
{
List<Category> categorylist = _Listofcategory();
var parentcate = categorylist.Where(c => c.ParentCategoryId == 1).ToList();
List<String> categoryList = new List<string>();
string prefix = ">>";
foreach (var item in parentcate)
{
prefix = item.CategoryName;
Setchild(prefix, item, categorylist, categoryList);
}
ViewBag.ListOfDisciplines = categoryList;
return View();
}
private void Setchild(string prefix, Category model, List<Category> listcategory, List<string> catStrings)
{
var childs = listcategory.Where(x => x.ParentCategoryId == model.CategoryId).ToList();
catStrings.Add(prefix);
if (childs.Count > 0)
{
foreach (var child in childs)
{
catStrings.Add(prefix + ">>" + child.CategoryName);
var subchild = listcategory.Where(c => c.ParentCategoryId == child.CategoryId).ToList();
if (subchild.Count > 0)
{
foreach (var subsubchild in subchild)
{
catStrings.Add(prefix + ">>" + child.CategoryName + ">>" + subsubchild.CategoryName);
var subsubsubchild = listcategory.Where(c => c.ParentCategoryId == subsubchild.CategoryId).ToList();
if (subsubsubchild.Count > 0)
{
foreach (var subsubsubsubchild in subsubsubchild)
{
catStrings.Add(prefix + ">>" + child.CategoryName + ">>" + subsubchild.CategoryName + ">>" + subsubsubsubchild.CategoryName);
}
}
}
}
}
}
}
This my List of Category how to use in View model.
Please let me know
Upvotes: 3
Views: 21501
Reputation: 65870
You can use below mentioned sample code for your scenario as well.Here I have used ViewModel.
Domain Models :
public class Product
{
public Product() { Id = Guid.NewGuid(); Created = DateTime.Now; }
public Guid Id { get; set; }
public string ProductName { get; set; }
public virtual ProductCategory ProductCategory { get; set; }
}
public class ProductCategory
{
public int Id { get; set; }
public string CategoryName { get; set; }
public virtual ICollection<Product> Products { get; set; }
}
View Model :
public class ProductViewModel
{
public Guid Id { get; set; }
[Required(ErrorMessage = "required")]
public string ProductName { get; set; }
public int SelectedValue { get; set; }
public virtual ProductCategory ProductCategory { get; set; }
[DisplayName("Product Category")]
public virtual ICollection<ProductCategory> ProductCategories { get; set; }
}
Action Methods :
[HttpGet]
public ActionResult AddProduct() //generate view with categories for enter product data
{
//for get product categories from database
var prodcutCategories = Repository.GetAllProductCategories();
//for initialize viewmodel
var productViewModel = new ProductViewModel();
//assign values for viewmodel
productViewModel.ProductCategories = prodcutCategories;
//send viewmodel into UI (View)
return View("AddProduct", productViewModel);
}
[HttpPost]
public ActionResult AddProduct(ProductViewModel productViewModel) //save entered data
{
//get product category for selected drop down list value
var prodcutCategory = Repository.GetProductCategory(productViewModel.SelectedValue);
//for get all product categories
var prodcutCategories = Repository.GetAllProductCategories();
//for fill the drop down list when validation fails
productViewModel.ProductCategories = prodcutCategories;
//for initialize Product domain model
var productObj = new Product
{
ProductName = productViewModel.ProductName,
ProductCategory = prodcutCategory,
};
if (ModelState.IsValid) //check for any validation errors
{
//save recived data into database
Repository.AddProduct(productObj);
return RedirectToAction("AddProduct");
}
else
{
//when validation failed return viewmodel back to UI (View)
return View(productViewModel);
}
}
View :
@model YourProject.ViewModels.ProductViewModel //set your viewmodel here
<div class="boxedForm">
@using (Html.BeginAbsoluteRouteForm("add", new { action = "AddProduct"},FormMethod.Post }))
{
<ul>
<li style="width: 370px">
@Html.LabelFor(m => m.ProductCategories)
@Html.DropDownListFor(m => m.SelectedValue,new SelectList(Model.ProductCategories, "Id",
"CategoryName"),"-Please select a category -")
@Html.ValidationMessageFor(m => m.ProductCategory.Id)
</li>
<li style="width: 370px">
@Html.CompleteEditorFor(m => m.ProductName, labelOverride: "Product Name")
@Html.ValidationMessageFor(m => m.ProductName)
</li>
</ul>
<div class="action">
<button class="actionButton" type="submit">
<span>Save</span></button>
</div>
}
</div>
Final Output
Upvotes: 4
Reputation: 2284
Assuming your ViewBag.ListOfDisciplines
is a List<Discipline>
and your Discipline class is:
public class Discipline {
public int Id { get; set; }
public string Name { get; set; }
}
If you have a List of strings you could transform it in a Array of anonymous in the controller side
ViewBag.ListOfDIsciplines = from d in ListDisciplines select new { Id = d, Name = d };
In your view you should use
@Html.DropDownList("Test", new SelectList(ViewBag.ListOfDisciplines, "Id", "Name"), "-- Select here --")
Upvotes: 0