public async Task <Collection> RemoveCollectionProduct(int id, int idp) { var collection = await context.Collection.FindAsync(id); var product = await context.Product.FindAsync(idp); CollectionProduct cprod = null; if (product == null || collection == null) { return(null); } foreach (CollectionProduct cp in collection.CollectionProducts) { if (cp.ProdutctId == idp) { cprod = cp; } } if (cprod == null) { return(null); } context.CollectionProduct.Remove(cprod); await context.SaveChangesAsync(); return(collection); }
/// <summary> /// insert a record to table /// </summary> /// <param name="collectionProduct"></param> /// <returns></returns> public int Insert(CollectionProduct collectionProduct) { try { string query = "insert into CollectionProduct (ProductID,CollectionID) values (@ProductID,@CollectionID) select @@IDENTITY"; int temp = connect.Query <int>(query, new { collectionProduct.ProductID, collectionProduct.CollectionID }).FirstOrDefault <int>(); return(SNumber.ToNumber(temp)); } catch (Exception ex) { LogService.WriteException(ex); return(0); } }
public async Task <Collection> AddCollectionProduct(int id, int idp) { var collection = await context.Collection.FindAsync(id); var product = await context.Product.FindAsync(idp); if (product == null || collection == null) { return(null); } if (context.CollectionProduct.Any(cps => cps.ProdutctId == idp && cps.CollectionId == id)) { return(null); } CollectionProduct cp = new CollectionProduct(); cp.ProdutctId = product.ProductId; cp.Product = product; cp.Collection = collection; cp.CollectionId = collection.CollectionId; product.CollectionProducts.Add(cp); collection.CollectionProducts.Add(cp); context.Entry(collection).State = EntityState.Modified; context.Entry(product).State = EntityState.Modified; context.CollectionProduct.Add(cp); try { await context.SaveChangesAsync(); } catch (DbUpdateConcurrencyException) { return(null); } return(collection); }
public string create(Collection collection, HttpPostedFileBase file) { collection.TemplateLayouts = new SelectList(new List <SelectListItem> { new SelectListItem { Selected = true, Text = "collection", Value = "collection" }, new SelectListItem { Selected = true, Text = "collection.list", Value = "collection.list" }, }, "Value", "Text", "1"); string strErrorMessage = ""; if (ModelState.IsValid) { // insert collection if (collection.CollectionType == "custom") { collection.ConditionForCollection = false; } else { bool flg = false; for (int i = 0; i < collection.TblRules.Count; i++) { if (string.IsNullOrEmpty(collection.TblRules[i].ConditionValue.Trim())) { strErrorMessage += "Giá trị lọc không được để trống<br/>"; flg = true; } } if (flg) { return(strErrorMessage); } } collection.CreatedDateTime = SDateTime.GetYYYYMMddHmmSSNow(); int collectionID = collectionService.Insert(collection); if (collectionID > 0) { collection.CollectionID = collectionID; LogService.WriteLog2DB(accountService.GetUserId(User.Identity.GetUserName()), (int)Common.ActionID.Insert, collectionID, SDateTime.GetYYYYMMddHmmSSNow(), General.GetIPAddress(), TableNameID, collection.CollectionName); // update collection image url string imageUrl = UploadImage(collectionID, file); if (!string.IsNullOrEmpty(imageUrl)) { collection.CollectionImage = imageUrl; collectionService.Update(collection); } // add rule for collection if (collection.CollectionType == "smart") { if (collection.TblRules != null && collection.TblRules.Count > 0) { for (int i = 0; i < collection.TblRules.Count; i++) { TblRule rule = collection.TblRules[i]; rule.CollectionID = collectionID; if (tblRuleService.CheckRuleValid(rule)) { tblRuleService.Insert(rule); } } } string linkCondition = ""; if (collection.ConditionForCollection) { linkCondition = "and"; } else { linkCondition = "or"; } string strConditionProductByRule = "1=1 and " + tblRuleService.GetConditionProductByListRule(collection.TblRules, linkCondition); List <Product> listProduct = productService.GetByWhere(strConditionProductByRule); foreach (var item in listProduct) { CollectionProduct collectionProduct = new CollectionProduct(); collectionProduct.CollectionID = collectionID; collectionProduct.ProductID = item.ProductID; collectionProductService.Insert(collectionProduct); } } return(collectionID.ToString()); } } foreach (ModelState modelState in ViewData.ModelState.Values) { foreach (ModelError error in modelState.Errors) { strErrorMessage += error.ErrorMessage; } } return(strErrorMessage); }
public static void Initialize(IServiceProvider serviceProvider) { using (var context = new SiCContext( serviceProvider.GetRequiredService <DbContextOptions <SiCContext> >())) { if (context.Product.Any()) { return; // DB has been seeded } City c = new City("Aveiro", 40.641190, -8.653620); City c1 = new City("Beja", 38.015621, -7.865230); City c2 = new City("Braga", 41.545448, -8.426507); City c3 = new City("Braganca", 41.806114, -6.756738); City c4 = new City("Castelo Branco", 39.819714, -7.496466); City c5 = new City("Coimbra", 40.203316, -8.410257); City c6 = new City("Evora", 38.571430, -7.913502); City c7 = new City("Faro", 37.015362, -7.935110); City c8 = new City("Guarda", 40.537128, -7.267850); City c9 = new City("Leiria", 39.749535, -8.807683); City c10 = new City("Lisboa", 38.722252, -9.139337); City c11 = new City("Portalegre", 39.296707, -7.428476); City c12 = new City("Porto", 41.157944, -8.629105); City c13 = new City("Santarem", 39.236179, -8.687080); City c14 = new City("Setubal", 38.525406, -8.894100); City c15 = new City("Viana do Castelo", 41.691807, -8.834451); City c16 = new City("Vila Real", 41.295898, -7.746350); City c17 = new City("Viseu", 40.656586, -7.912471); Factory Factory = new Factory(); Factory.City = c12; Factory.Description = "Fabrica situada no Porto"; Measure Depth = new Measure(20.0, 40.0); Measure Height = new Measure(80); Measure Width = new Measure(30, 50); Measure Depth_Part = new Measure(10.0, 20.0); Measure Height_Part = new Measure(40); Measure Width_Part = new Measure(15, 25); Dimension Dimension_Product = new Dimension(); Dimension_Product.Depth = Depth; Dimension_Product.Height = Height; Dimension_Product.Width = Width; Dimension Dimension_Product_Part_A1 = new Dimension(); Dimension_Product_Part_A1.Depth = Depth_Part; Dimension_Product_Part_A1.Height = Height_Part; Dimension_Product_Part_A1.Width = Width_Part; Dimension Dimension_Product_Part_A2 = new Dimension(); Dimension_Product_Part_A2.Depth = Depth_Part; Dimension_Product_Part_A2.Height = Height_Part; Dimension_Product_Part_A2.Width = Width_Part; Price Finishing_Price = new Price(); Finishing_Price.date = DateTime.Parse("2019-01-06"); Finishing_Price.designation = "Polimento"; Finishing_Price.price = 2.50; Price Material_Price = new Price(); Material_Price.date = DateTime.Parse("2019-01-06"); Material_Price.designation = "Madeira"; Material_Price.price = 5.0; Finishing Finishing = new Finishing(); Finishing.name = "Polimento"; Finishing.description = "Acabamento que confere brilho e protecao do material quando aplicado"; Finishing.MaterialFinishings = new List <MaterialFinishing>(); Finishing.Prices = new List <Price>(); Material Material = new Material(); Material.name = "Madeira"; Material.description = "Madeira de pinho de elevada durabilidade"; Material.MaterialFinishings = new List <MaterialFinishing>(); Material.ProductMaterials = new List <ProductMaterial>(); Material.Prices = new List <Price>(); Category Category = new Category(); Category.name = "armario"; Category.description = "Esta categoria representa o topo da taxonomia"; Category Category_Part = new Category(); Category_Part.name = "gaveta"; Category_Part.description = "Categoria desenvolvida para teste"; Category_Part.parent = Category; Product Product = new Product(); Product.name = "G8579"; Product.description = "Produto desenvolvido para teste"; Product.category = Category; Product.ProductMaterials = new List <ProductMaterial>(); Product.CatalogProducts = new List <CatalogProduct>(); Product.CollectionProducts = new List <CollectionProduct>(); Product.dimensions = new List <Dimension>(); Product.dimensions.Add(Dimension_Product); Product Product_Part1 = new Product(); Product_Part1.name = "G8579_Part_A1"; Product_Part1.description = "Produto desenvolvido para teste"; Product_Part1.category = Category_Part; Product_Part1.ProductMaterials = new List <ProductMaterial>(); Product_Part1.CatalogProducts = new List <CatalogProduct>(); Product_Part1.CollectionProducts = new List <CollectionProduct>(); Product_Part1.dimensions = new List <Dimension>(); Product_Part1.dimensions.Add(Dimension_Product_Part_A1); Product Product_Part2 = new Product(); Product_Part2.name = "G8579_Part_A2"; Product_Part2.description = "Produto desenvolvido para teste"; Product_Part2.category = Category_Part; Product_Part2.ProductMaterials = new List <ProductMaterial>(); Product_Part2.CatalogProducts = new List <CatalogProduct>(); Product_Part2.CollectionProducts = new List <CollectionProduct>(); Product_Part2.dimensions = new List <Dimension>(); Product_Part2.dimensions.Add(Dimension_Product_Part_A2); Combination Combination_P_P1 = new Combination(Product, Product_Part1, true); Combination Combination_P_P2 = new Combination(Product, Product_Part2, false); Catalog Catalog = new Catalog(); Catalog.CatalogName = "Catalogo G8579"; Catalog.CatalogDescription = "Catalogo desenvolvido para teste"; Catalog.Date = "2019-01-06"; Catalog.CatalogProducts = new List <CatalogProduct>(); Collection Collection = new Collection(); Collection.collectionName = "Madeira e mais Madeira"; Collection.aestheticParameter = "Madeira"; Collection.CollectionProducts = new List <CollectionProduct>(); MaterialFinishing MF = new MaterialFinishing(); MF.Finishing = Finishing; MF.Material = Material; Finishing.MaterialFinishings.Add(MF); Material.MaterialFinishings.Add(MF); ProductMaterial PM = new ProductMaterial(); PM.Material = Material; PM.Product = Product; Product.ProductMaterials.Add(PM); Material.ProductMaterials.Add(PM); CatalogProduct CatP = new CatalogProduct(); CatP.Catalog = Catalog; CatP.Product = Product; Product.CatalogProducts.Add(CatP); Catalog.CatalogProducts.Add(CatP); CollectionProduct ColP = new CollectionProduct(); ColP.Collection = Collection; ColP.Product = Product; Product.CollectionProducts.Add(ColP); Collection.CollectionProducts.Add(ColP); context.City.Add(c); context.City.Add(c1); context.City.Add(c2); context.City.Add(c3); context.City.Add(c4); context.City.Add(c5); context.City.Add(c6); context.City.Add(c7); context.City.Add(c8); context.City.Add(c9); context.City.Add(c10); context.City.Add(c11); context.City.Add(c12); context.City.Add(c13); context.City.Add(c14); context.City.Add(c15); context.City.Add(c16); context.City.Add(c17); context.Factory.Add(Factory); context.Measure.Add(Depth); context.Measure.Add(Height); context.Measure.Add(Width); context.Measure.Add(Depth_Part); context.Measure.Add(Height_Part); context.Measure.Add(Width_Part); context.Dimension.Add(Dimension_Product); context.Dimension.Add(Dimension_Product_Part_A1); context.Dimension.Add(Dimension_Product_Part_A2); context.Price.Add(Material_Price); context.Price.Add(Finishing_Price); context.Finishing.Add(Finishing); context.Material.Add(Material); context.Category.Add(Category); context.Category.Add(Category_Part); context.Product.Add(Product); context.Product.Add(Product_Part1); context.Product.Add(Product_Part2); context.Combination.Add(Combination_P_P1); context.Combination.Add(Combination_P_P2); context.Catalog.Add(Catalog); context.Collection.Add(Collection); MF.MaterialId = Material.MaterialId; MF.FinishingId = Finishing.FinishingId; context.MaterialFinishing.Add(MF); PM.MaterialId = Material.MaterialId; PM.ProductId = Product.ProductId; context.ProductMaterial.Add(PM); CatP.CatalogId = Catalog.CatalogId; CatP.ProductId = Product.ProductId; context.CatalogProduct.Add(CatP); ColP.CollectionId = Collection.CollectionId; ColP.ProdutctId = Product.ProductId; context.CollectionProduct.Add(ColP); context.SaveChanges(); } }