Рассчитать временной интервал в модели MVC с помощью C # - PullRequest
0 голосов
/ 01 июня 2019

В моем проекте MVC есть Модель, в которой хранятся Действия.Мне нужно отобразить разницу между временем начала и времени окончания.Вот мой класс модели:

[Table("DailyCrewActivity")]
public partial class DailyCrewActivity
{
    [Key]
    public int id { get; set; }

    [Display(Name = "Crew Name")]
    [ForeignKey("DailyCrew")]
    public int daily_crew_id { get; set; }

    [Display(Name = "Task Number")]
    [ForeignKey("ContractTask")]
    public int contract_task_id { get; set; }

    [Display(Name = "Activity Date")]
    [DisplayFormat(DataFormatString = "{0:MM/dd/yyyy}")]
    public DateTime activity_date { get; set; }

    [Required]
    [StringLength(50)]
    [Display(Name = "Activity Code")]
    public string activity_code { get; set; }

    [Display(Name = "Start Time")]
    [DisplayFormat(DataFormatString = "{0:hh:mm}")]
    public string activity_start { get; set; }

    [Display(Name = "End Time")]
    [DisplayFormat(DataFormatString = "{0:hh:mm}")]
    public string activity_end { get; set; }

    [NotMapped]
    [Display(Name = "Hours")]
    [DisplayFormat(DataFormatString = "{0:#.##}")]
    public decimal ElapsedTime
    {
        get
        {
            decimal duration = 0;
            if (String.IsNullOrEmpty(activity_start) && String.IsNullOrEmpty(activity_end))
            {

                TimeSpan spanStart;
                TimeSpan spanEnd;
                if (TimeSpan.TryParse(activity_start, out spanStart) && TimeSpan.TryParse(activity_end, out spanEnd))
                {
                    duration = Convert.ToDecimal(spanEnd - spanStart);
                }

            }
            return duration;
        }
    }

    public DailyCrew DailyCrew { get; set; }
    public ContractTask ContractTask { get; set; }

}

Я не получаю расчет, возвращенный ElapsedTime.Это потому, что я храню время в строке, а затем анализирую его в TimeSpan?Я не уверен, что это происходит.

Спасибо

Райан

1 Ответ

0 голосов
/ 01 июня 2019

Вы проверяете, чтобы оба значения были нулевыми, что вам ничего не даст.Вместо этого вам нужно проверить наличие пустых / пустых значений на обоих:

if (!String.IsNullOrEmpty(activity_start) && !String.IsNullOrEmpty(activity_end))
{
    ...
}
...