Screen for holidays

image_pdfimage_print
   
 
// crudwork
// Copyright 2004 by Steve T. Pham (http://www.crudwork.com)
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with This program.  If not, see <http://www.gnu.org/licenses/>.

using System;
using System.Collections.Generic;
using System.Text;

namespace crudwork.Utilities
{
  /// <summary>
  /// Date Utility
  /// </summary>
  public class DateUtil
  {
    /// <summary>
    /// screen for holidays 
    /// (simple mode)
    /// </summary>
    /// <param name="result"></param>
    /// <param name="addValue"></param>
    /// <returns></returns>
    public static DateTime ScreenHolidays(DateTime result, int addValue)
    {
      #region Sanity Checks
      if ((addValue != -1) &amp;&amp; (addValue != 1))
        throw new ArgumentOutOfRangeException("addValue must be -1 or 1");
      #endregion

      // holidays on fixed date
      switch (MonthDay(result))
      {
        case "01/01":  // Happy New Year
        case "07/04":  // Independent Day
        case "12/25":  // Christmas
          return GetBusinessDay(result, addValue);
        default:
          return result;
      }
    }
    /// <summary>
    /// return the previous business date of the date specified.
    /// </summary>
    /// <param name="today"></param>
    /// <returns></returns>
    public static DateTime PreviousBusinessDay(DateTime today)
    {
      DateTime result;
      switch (today.DayOfWeek)
      {
        case DayOfWeek.Sunday:
          result = today.AddDays(-2);
          break;

        case DayOfWeek.Monday:
          result = today.AddDays(-3);
          break;

        case DayOfWeek.Tuesday:
        case DayOfWeek.Wednesday:
        case DayOfWeek.Thursday:
        case DayOfWeek.Friday:
          result = today.AddDays(-1);
          break;

        case DayOfWeek.Saturday:
          result = today.AddDays(-1);
          break;

        default:
          throw new ArgumentOutOfRangeException("DayOfWeek=" + today.DayOfWeek);
      }
      return ScreenHolidays(result, -1);
    }
    /// <summary>
    /// Return the previous or next business day of the date specified.
    /// </summary>
    /// <param name="today"></param>
    /// <param name="addValue"></param>
    /// <returns></returns>
    public static DateTime GetBusinessDay(DateTime today, int addValue)
    {
      #region Sanity Checks
      if ((addValue != -1) &amp;&amp; (addValue != 1))
        throw new ArgumentOutOfRangeException("addValue must be -1 or 1");
      #endregion

      if (addValue > 0)
        return NextBusinessDay(today);
      else
        return DateUtil.PreviousBusinessDay(today);
    }



    /// <summary>
    /// return the next business date of the date specified.
    /// </summary>
    /// <param name="today"></param>
    /// <returns></returns>
    public static DateTime NextBusinessDay(DateTime today)
    {
      DateTime result;
      switch (today.DayOfWeek)
      {
        case DayOfWeek.Sunday:
        case DayOfWeek.Monday:
        case DayOfWeek.Tuesday:
        case DayOfWeek.Wednesday:
        case DayOfWeek.Thursday:
          result = today.AddDays(1);
          break;

        case DayOfWeek.Friday:
          result = today.AddDays(3);
          break;

        case DayOfWeek.Saturday:
          result = today.AddDays(2);
          break;

        default:
          throw new ArgumentOutOfRangeException("DayOfWeek=" + today.DayOfWeek);
      }
      return ScreenHolidays(result, 1);
    }


    /// <summary>
    /// return the mm/dd string of the date specified.
    /// </summary>
    /// <param name="time"></param>
    /// <returns></returns>
    public static string MonthDay(DateTime time)
    {
      return String.Format("{0:00}/{1:00}", time.Month, time.Day);
    }
   }
}