Как определить, является ли модель действительной? - PullRequest
0 голосов
/ 24 мая 2019

У меня тут какие-то проблемы. Ситуация заключается в обновлении существующей записи, в то же время, сохранении новой строки, если записи нет, сначала выполняя поиск в таблице.

Когда я сохраняю новую запись, проблем нет. Но когда я пытаюсь обновить существующий, нет никаких изменений. Я попытался установить некоторые точки останова специально для кода, который делает это. Это просто заканчивается на линии if(!ModelState.IsValid).

Примечание: Некоторые строки жестко запрограммированы для того, чтобы иметь некоторые фиктивные данные.

Функция для извлечения некоторых данных из БД для передачи на просмотр модели

[HttpGet]
public ActionResult CardNumberAssignment(string empId, int cardNumberId)
{
    var getIdDetails = dbContext.CardNumberAssignments.Where(c => c.CardNumberId == cardNumberId && c.IsActive == true).SingleOrDefault();

    if (cardNumberId == 0) //EMPLOYEE HAS NO CARD NUMBER YET
    {
        var viewModel = new CardNumberQRCodeVM
        {
            CardNumberId = 0,
            CMId = empId,
            OldQRCode = "No QR Code history",
            OldReservedCardNumber = "No Card Number history",
            NewReservedCardNumber = GetRandomCardNumber()
        };

        return View(viewModel);
    }

    else
    {
        if (getIdDetails.CMId != empId) //JUST CHECKING IF THE EMPLOYEE HAS THE CORRECT CARDNUMBERID FROM DB
        {
            return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
        }

        var empCardDetails = dbContext.CardNumberAssignments
                                      .Include(c => c.ReservedCardNumber)
                                      .Where(emp => emp.CMId == empId && emp.IsActive == true)
                                      .Select(fields => new CardNumberQRCodeVM
                                      {
                                          CardNumberId = fields.CardNumberId,
                                          CMId = empId,
                                          OldQRCode = fields.QRCode,
                                          IsActive = fields.IsActive,
                                          OldReservedCardNumber = fields.ReservedCardNumber.CardNumber,
                                      }).FirstOrDefault();

        empCardDetails.NewReservedCardNumber = GetRandomCardNumber();

        return View(empCardDetails);
    }
}

Функция добавления / редактирования записи

[HttpPost]
[ValidateAntiForgeryToken]
public ActionResult SaveIdInformation(CardNumberQRCodeVM vm)
{
    if (!ModelState.IsValid)
    {
        return new HttpStatusCodeResult(HttpStatusCode.BadRequest);
    }

    // JUST ADDING/EDITING SOME CARD NUMBERS....
    else
    {
        if (vm.CardNumberId == 0) //INSERT A NEW ROW FOR NEW CARD NUMBER AND QR CODE
        {
            var newCardNumber = new ReservedCardNumber
            {
                CardNumber = vm.NewReservedCardNumber,
                IsActive = true,
                CreatedDate = DateTime.Now,
                CreatedBy = "Paolo",
                ModifiedDate = DateTime.Now,
                ModifiedBy = "Paolo"
            };

            dbContext.ReservedCardNumbers.Add(newCardNumber);

            var newIdInfo = new CardNumberAssignment
            {
                CardNumberId = newCardNumber.Id,
                QRCode = vm.NewQRCode,
                CMId = vm.CMId,
                IsActive = true,
                CreatedDate = DateTime.Now,
                CreatedBy = "Paolo",
                ModifiedDate = DateTime.Now,
                ModifiedBy = "Paolo"
            };

            dbContext.CardNumberAssignments.Add(newIdInfo);
        }

        else // EDIT EXISTING
        {
            var getEmployeeIdInDb = dbContext.CardNumberAssignments.Single(e => e.Id == vm.CardNumberId);

            getEmployeeIdInDb.ReservedCardNumber.CardNumber = vm.NewReservedCardNumber;
            getEmployeeIdInDb.QRCode = vm.NewQRCode;
            getEmployeeIdInDb.IsActive = true;
            getEmployeeIdInDb.ModifiedDate = DateTime.Now;
            getEmployeeIdInDb.ModifiedBy = "Paolo";
        }

        dbContext.SaveChanges();
    }

    return RedirectToAction("CMDetails", "Admin", new { @empId = vm.CMId });
}

Посмотреть модель

public class CardNumberQRCodeVM
{
    public int CardNumberId { get; set; }

    public string CMId { get; set; }

    [Display(Name = "Existing QR Code")]
    public string OldQRCode { get; set; }

    [Required]
    [Display(Name = "New QR Code")]
    public string NewQRCode { get; set; }

    [Display(Name = "Resigned Cast Member?")]
    public bool IsActive { get; set; }

    public string CreatedBy { get; set; }
    public DateTime CreatedDate { get; set; }
    public string ModifiedBy { get; set; }
    public DateTime ModifiedDate { get; set; }

    public ReservedCardNumber ReservedCardNumber { get; set; }

    [Display(Name = "Old Card Number")]
    public string OldReservedCardNumber { get; set; }

    [Display(Name = "New Card Number")]
    public string NewReservedCardNumber { get; set; }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...