|
|
|
using System;
|
|
|
|
using Yavsc;
|
|
|
|
using SalesCatalog;
|
|
|
|
using SalesCatalog.Model;
|
|
|
|
using System.Web.Mvc;
|
|
|
|
using System.Web;
|
|
|
|
using System.Text.RegularExpressions;
|
|
|
|
using System.IO;
|
|
|
|
using Yavsc.Controllers;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using Yavsc.Model;
|
|
|
|
using Yavsc.Model.WorkFlow;
|
|
|
|
using WorkFlowProvider;
|
|
|
|
using System.Web.Security;
|
|
|
|
using System.Threading;
|
|
|
|
|
|
|
|
namespace Yavsc.Controllers
|
|
|
|
{
|
|
|
|
/// <summary>
|
|
|
|
/// Front office controller.
|
|
|
|
/// Access granted to all
|
|
|
|
/// </summary>
|
|
|
|
public class FrontOfficeController : Controller
|
|
|
|
{
|
|
|
|
protected WorkFlowManager wfmgr = null;
|
|
|
|
|
|
|
|
protected override void Initialize (System.Web.Routing.RequestContext requestContext)
|
|
|
|
{
|
|
|
|
base.Initialize (requestContext);
|
|
|
|
wfmgr = new WorkFlowManager ();
|
|
|
|
}
|
|
|
|
|
|
|
|
public ActionResult Index ()
|
|
|
|
{
|
|
|
|
return View ();
|
|
|
|
}
|
|
|
|
|
|
|
|
[Authorize]
|
|
|
|
public ActionResult Estimates ()
|
|
|
|
{
|
|
|
|
string username = Membership.GetUser ().UserName;
|
|
|
|
|
|
|
|
return View(wfmgr.GetEstimates (username));
|
|
|
|
}
|
|
|
|
|
|
|
|
[Authorize]
|
|
|
|
public ActionResult Estimate(Estimate model,string submit)
|
|
|
|
{
|
|
|
|
ViewData ["WebApiBase"] = "http://" + Request.Url.Authority + "/api";
|
|
|
|
ViewData ["WABASEWF"] = ViewData ["WebApiBase"] + "/WorkFlow";
|
|
|
|
if (submit == null) {
|
|
|
|
if (model.Id > 0) {
|
|
|
|
Estimate f = wfmgr.GetEstimate (model.Id);
|
|
|
|
if (f == null) {
|
|
|
|
ModelState.AddModelError ("Id", "Wrong Id");
|
|
|
|
return View (model);
|
|
|
|
}
|
|
|
|
model = f;
|
|
|
|
ModelState.Clear ();
|
|
|
|
string username = HttpContext.User.Identity.Name;
|
|
|
|
if (username != model.Responsible
|
|
|
|
&& username != model.Client
|
|
|
|
&& !Roles.IsUserInRole ("FrontOffice"))
|
|
|
|
throw new UnauthorizedAccessException ("You're not allowed to view this estimate");
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
string username = HttpContext.User.Identity.Name;
|
|
|
|
if (model.Id == 0) {
|
|
|
|
model.Responsible=username;
|
|
|
|
ModelState.Clear ();
|
|
|
|
}
|
|
|
|
if (ModelState.IsValid) {
|
|
|
|
if (username != model.Responsible
|
|
|
|
&& !Roles.IsUserInRole ("FrontOffice"))
|
|
|
|
throw new UnauthorizedAccessException ("You're not allowed to modify this estimate");
|
|
|
|
|
|
|
|
if (model.Id == 0)
|
|
|
|
model = wfmgr.CreateEstimate (
|
|
|
|
username,
|
|
|
|
model.Client, model.Title, model.Description);
|
|
|
|
else {
|
|
|
|
wfmgr.UpdateEstimate (model);
|
|
|
|
model = wfmgr.GetEstimate (model.Id);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return View(model);
|
|
|
|
}
|
|
|
|
|
|
|
|
[AcceptVerbs("GET")]
|
|
|
|
public ActionResult Catalog ()
|
|
|
|
{
|
|
|
|
return View (
|
|
|
|
CatalogManager.GetCatalog (Request.Url.AbsolutePath)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Catalog this instance.
|
|
|
|
/// </summary>
|
|
|
|
[AcceptVerbs("GET")]
|
|
|
|
public ActionResult Brand (string id)
|
|
|
|
{
|
|
|
|
Catalog c = CatalogManager.GetCatalog (Request.Url.AbsolutePath);
|
|
|
|
ViewData ["BrandName"] = id;
|
|
|
|
return View ( c.GetBrand (id) );
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// get the product category
|
|
|
|
/// </summary>
|
|
|
|
/// <returns>The category.</returns>
|
|
|
|
/// <param name="bn">Bn.</param>
|
|
|
|
/// <param name="pc">Pc.</param>
|
|
|
|
[AcceptVerbs("GET")]
|
|
|
|
public ActionResult ProductCategory (string id, string pc)
|
|
|
|
{
|
|
|
|
ViewData ["BrandName"] = id;
|
|
|
|
return View (
|
|
|
|
CatalogManager.GetCatalog (Request.Url.AbsolutePath).GetBrand (id).GetProductCategory (pc)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
[AcceptVerbs("GET")]
|
|
|
|
public ActionResult Product (string id, string pc, string pref)
|
|
|
|
{
|
|
|
|
Product p = null;
|
|
|
|
ViewData ["BrandName"] = id;
|
|
|
|
ViewData ["ProdCatRef"] = pc;
|
|
|
|
ViewData ["ProdRef"] = pref;
|
|
|
|
Catalog cat = CatalogManager.GetCatalog (Request.Url.AbsolutePath);
|
|
|
|
if (cat == null) {
|
|
|
|
ViewData ["Message"] = "Catalog introuvable";
|
|
|
|
ViewData ["RefType"] = "Catalog";
|
|
|
|
return View ("ReferenceNotFound");
|
|
|
|
}
|
|
|
|
Brand b = cat.GetBrand (id);
|
|
|
|
if (b == null) {
|
|
|
|
ViewData ["RefType"] = "Brand";
|
|
|
|
return View ("ReferenceNotFound");
|
|
|
|
}
|
|
|
|
ProductCategory pcat = b.GetProductCategory (pc);
|
|
|
|
if (pcat == null) {
|
|
|
|
ViewData ["RefType"] = "ProductCategory";
|
|
|
|
return View ("ReferenceNotFound");
|
|
|
|
}
|
|
|
|
ViewData ["ProdCatName"] = pcat.Name;
|
|
|
|
p = pcat.GetProduct (pref);
|
|
|
|
if (p.CommandForm==null)
|
|
|
|
p.CommandForm = b.DefaultForm;
|
|
|
|
|
|
|
|
return View ((p is Service)?"Service":"Product", p);
|
|
|
|
}
|
|
|
|
|
|
|
|
public ActionResult Command()
|
|
|
|
{
|
|
|
|
return View ();
|
|
|
|
}
|
|
|
|
|
|
|
|
[HttpPost]
|
|
|
|
[Authorize]
|
|
|
|
public ActionResult Command(FormCollection collection)
|
|
|
|
{
|
|
|
|
try {
|
|
|
|
// get files from the request
|
|
|
|
string fnre = "[A-Za-z0-9~\\-.]+";
|
|
|
|
HttpFileCollectionBase hfc = Request.Files;
|
|
|
|
|
|
|
|
foreach (String h in hfc.AllKeys)
|
|
|
|
{
|
|
|
|
if (!Regex.Match(hfc[h].FileName,fnre).Success)
|
|
|
|
{
|
|
|
|
ViewData ["Message"] = "File name refused";
|
|
|
|
ModelState.AddModelError(
|
|
|
|
h,
|
|
|
|
string.Format(
|
|
|
|
"The file name {0} dosn't match an acceptable file name {1}",
|
|
|
|
hfc[h].FileName,fnre))
|
|
|
|
;
|
|
|
|
return View(collection);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
foreach (String h in hfc.AllKeys)
|
|
|
|
{
|
|
|
|
// TODO Limit with hfc[h].ContentLength
|
|
|
|
hfc[h].SaveAs(Path.Combine(FileSystemController.BaseDir,hfc[h].FileName));
|
|
|
|
}
|
|
|
|
if (Session["Basket"]==null)
|
|
|
|
Session["Basket"]=new List<Commande>();
|
|
|
|
List<Commande> basket = Session["Basket"] as List<Commande>;
|
|
|
|
// Add specified product command to the basket,
|
|
|
|
basket.Add(Commande.Create(collection));
|
|
|
|
return View (collection);
|
|
|
|
} catch (Exception e)
|
|
|
|
{
|
|
|
|
ViewData ["Message"] = "Exception:"+e.Message;
|
|
|
|
return View (collection);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|