Kendo UI Scheduler неправильно вызывает WebAPI - PullRequest
0 голосов
/ 04 декабря 2018

Я просматриваю форумы Telerik и Stackoverflow, чтобы найти ответ на этот вопрос, и я полностью застрял и не могу выяснить проблему.

Я использую пользовательский интерфейс Kendo для управления планировщиком ядра Asp.Net,У меня это читает данные из моего контроллера в порядке.Однако я не могу заставить его правильно вызывать обработчик HttpPut.

При проверке трафика я получаю следующий ответ, и поэтому моя точка останова внутри моего обработчика HttpPut никогда не будет достигнута.

400 - Bad Request
{"":["The input was not valid."]}

Мой код на мой взгляд:

@(Html.Kendo().Scheduler<MeetingViewModel>()
      .Name("SchedulerView")
      .Height(500)
      .Date(DateTime.Now.ToUniversalTime())
      .StartTime(new DateTime(2018, 11, 28, 0, 00, 00).ToUniversalTime())
      .MajorTick(30)
      .ShowWorkHours(false)
      .Footer(false)
      .Editable(edit =>
      {
          //edit.Resize(false);
          edit.Create(false);
      })
      .Views(views =>
      {
          views.TimelineView(timeline => timeline.EventHeight(50));
          //views.TimelineWeekView(timeline => timeline.EventHeight(50));
          //views.TimelineWorkWeekView(timeline => timeline.EventHeight(50));
          //views.TimelineMonthView(timeline =>
          //{
          //    timeline.StartTime(DateTime.Now);
          //    timeline.EndTime(DateTime.Now.AddMonths(1));
          //    timeline.MajorTick(1440);
          //    timeline.EventHeight(50);
          //});

      })
      .Timezone("Etc/UTC")
      .Group(group => group.Resources("WorkCenters" /*,"Attendees"*/).Orientation(SchedulerGroupOrientation.Vertical))
      .Resources(resource =>
      {
          resource.Add(m => m.ScheduleRowID)
              .Title("Work Center")
              .Name("WorkCenters")
              .DataTextField("Text")
              .DataValueField("Value")
              .DataColorField("Color")
              .BindTo(@Model.AvailableWorkCenters);
      })
      .DataSource(d => d
          .ServerOperation(true)
          .WebApi()
          .Model(m =>
          {
              m.Id(f => f.ActivityID);
              m.Field(f => f.Title).DefaultValue("No title");
              //m.RecurrenceId(f => f.RecurrenceID);
              m.Field(f => f.Description).DefaultValue("No Description");
          })
          .Events(events => events.Error("error_handler"))
          .Read(read => read.Action("GetActivities", "Scheduler").Data("setRequestDateTimes"))
          //.Create(create => create.Action("Post", "Scheduler"))
          .Update(update => update.Action("PutActivity", "Scheduler", new { id = "{0}" }).Type(HttpVerbs.Put))
          //.Destroy(destroy => destroy.Action("Delete", "Scheduler", new { id = "{0}" }))
      )))

И мой контроллер API выглядит следующим образом:

[Route("Api/[controller]")]
[ApiController]
public class SchedulerController : DawnController
{
    public SchedulerController(DatabaseContext context) : base(context)
    {
    }

    [HttpGet]
    public DataSourceResult GetActivities([DataSourceRequest] DataSourceRequest request, DateTime requestStartDateTime, DateTime requestEndDateTime)
    {
        //Kendo doesnt seem to send the full date range. so + 1 day to end
        requestEndDateTime = requestEndDateTime.AddDays(1);

        List<MeetingViewModel> test = new List<MeetingViewModel>();

        foreach (JobTask jobTask in Context.JobTask)
        {
            if (JobTask.HasActivityInDateRange(jobTask, requestStartDateTime, requestEndDateTime))
            {
                foreach (Activites jobTaskAct in jobTask.Activites)
                {
                    test.Add(new MeetingViewModel()
                    {
                        JobTaskID = jobTask.JobTaskId,
                        ActivityID = jobTaskAct.ActivityId,
                        Title = jobTaskAct.Name,
                        Description = jobTaskAct.Description,
                        Start = jobTaskAct.StartTime.ToUniversalTime(),
                        End = jobTaskAct.EndTime.ToUniversalTime(),
                        IsAllDay = false,
                        ScheduleRowID = jobTaskAct.Workcenter.WorkCenterId,
                    });
                }
            }
        }
        return test.ToDataSourceResult(request);
    }


    [HttpPut("{id}")]
    public IActionResult PutActivity(int id, MeetingViewModel task)
    {
        if (ModelState.IsValid && id == task.ActivityID)
        {
            try
            {
                //breakpoint here
                bool a = true;
                //update the db here
            }
            catch (DbUpdateConcurrencyException)
            {
                return new NotFoundResult();
            }

            return new StatusCodeResult(200);
        }
        else
        {
            return BadRequest(ModelState.Values.SelectMany(v => v.Errors).Select(error => error.ErrorMessage));
        }
    }
}

Спасибо

1 Ответ

0 голосов
/ 05 декабря 2018

URL, отображающий ваш метод контроллера PutActivity в вашем примере контроллера: PUT api/scheduler/{id}

Для доступа к этому URL используйте этот метод Update.

.Update(update => update.Action("Put", "Scheduler", new { id = "{0}" }))

См.эта демонстрация в качестве примера

В качестве альтернативы

Если вы хотите добавить URL api/Scheduler/PutActivity/{id} (аналогично вашему GET), вам нужно будет изменитьПрисвойте метод put следующим образом.

[HttpPut("PutActivity/{id}")]
public IActionResult PutActivity(int id, MeetingViewModel task)

Затем вы можете вызвать api/Scheduler/PutActivity/{id} с помощью этого вызова действия asp.net.

.Update(update => update.Action("PutActivity", "Scheduler", new { id = "{0}" }).Type(HttpVerbs.Put))
...