Exemplo n.º 1
0
        public ActionResult Create()
        {
            var regionList = db.RegionTypes.ToList();
            var businessList = db.Businesses.ToList();
            var viewModel = new ViewModelAdvertisement { RegionTypeId = regionList[0].RegionTypeId, RegionTypes = regionList, BusinessId = businessList[0].BusinessId, Businesses = businessList };

            return View(viewModel);
        }
Exemplo n.º 2
0
        public ActionResult Create(ViewModelAdvertisement vmAd)
        {
            // Need to add a cache for this reference data
            var ad = new Advertisement(vmAd)
            {
                Business = db.Businesses.Find(vmAd.BusinessId),
                Regions = new List<Region> { new Region() { RegionId = vmAd.RegionTypeId, Type = db.RegionTypes.Find(vmAd.RegionTypeId) } }
            };

            if (ModelState.IsValid)
            {
                db.Advertisements.Add(ad);
                db.SaveChanges();

                return RedirectToAction("Index");
            }

            return View(ad);
        }
Exemplo n.º 3
0
        public Advertisement(ViewModelAdvertisement vmAd)
            : this()
        {
            this.AdvertisementId = vmAd.AdvertisementId;
            this.EffectiveDate = vmAd.EffectiveDate;
            this.ExporationDate = vmAd.ExporationDate;

            if (this.Heading == null)
            {
               this.Heading = new Heading();
            }

            this.Heading.HeadingId = vmAd.HeadingId;
            this.Heading.Text = vmAd.HeadingText;

            if (this.Regions == null)
            {
                this.Regions = new List<Region>();
            }
        }
Exemplo n.º 4
0
        public ActionResult Edit(ViewModelAdvertisement vmAd)
        {
            var ad = db.Advertisements.Find(vmAd.AdvertisementId);
            ad.Business = db.Businesses.Find(vmAd.BusinessId);

            if (ad.Regions.FirstOrDefault(r => r.RegionId == vmAd.RegionId) != null)
            {
                ad.Regions.First(r => r.RegionId == vmAd.RegionId).Type =
                    vmAd.RegionTypes.Find(r => r.RegionTypeId == vmAd.RegionTypeId);
            }
            else
            {
                ad.Regions = new List<Region> { new Region() { RegionId = vmAd.RegionTypeId, Type = db.RegionTypes.Find(vmAd.RegionTypeId) } };
            }

            if (ModelState.IsValid)
            {
                db.Entry(ad).State = EntityState.Modified;
                // I should nor have to do this. There should be a cascading update?
                db.Entry(ad.Heading).State = EntityState.Modified;

                db.SaveChanges();

                return RedirectToAction("Index");
            }

            return View(ad);
        }
Exemplo n.º 5
0
        //
        // GET: /Advertisement/Edit/5
        public ActionResult Edit(int id = 0)
        {
            var ad = db.Advertisements.Find(id);

            if (ad == null)
            {
                return HttpNotFound();
            }

            var regionList = db.RegionTypes.ToList();
            var businessList = db.Businesses.ToList();

            var viewModel = new ViewModelAdvertisement
            {
                AdvertisementId = ad.AdvertisementId,
                HeadingId = ad.Heading.HeadingId,
                RegionId = ad.Regions.FirstOrDefault() == null ? 1 : ad.Regions.FirstOrDefault().RegionId,
                RegionTypeId = regionList.FirstOrDefault().RegionTypeId,
                RegionTypes = regionList,
                BusinessId = businessList.FirstOrDefault().BusinessId,
                Businesses = businessList,
                HeadingText = ad.Heading.Text,
                EffectiveDate = ad.EffectiveDate,
                ExporationDate = ad.ExporationDate
            };

            return View(viewModel);
        }