/// <summary>
 ///     Converts the comments to string.
 /// </summary>
 /// <param name = "rev">The rev.</param>
 /// <returns></returns>
 public static string ConvertCommentsToString(ref RoomReservation rev)
 {
     var sb = new StringBuilder();
     foreach (var r in rev.RoomReservationCommentsList.OrderByDescending(t => t.DateSent))
     {
         sb.Append(String.Format("<strong>Person: </strong> {0} <br />", r.UserID == r.RoomReservation.Room.UserID ? "Room Poster" : "Room Requester"));
         sb.Append(String.Format("<strong>Date Posted: </strong> {0} <br />", r.DateSent));
         sb.Append(String.Format("<strong>Comments: </strong> {0} <br /> <br />", r.Comments));
     }
     return sb.ToString();
 }
        /// <summary>
        ///     Creates the room reservation.
        /// </summary>
        /// <param name = "userId">The user id.</param>
        /// <param name = "roomId">The room id.</param>
        /// <param name = "comments">The comments.</param>
        /// <returns></returns>
        public static int CreateRoomReservation(int userId, int roomId, string comments, List<ReserveRoomTempObject> timeList)
        {
            if (timeList.Count <= 0)
                return -1;

            var db = new UrbanDataContext();

            var reservation = new RoomReservation
                                  {
                                      Approved = null,
                                      ReserverUserID = userId,
                                      RoomID = roomId,
                                      RequestedDate = DateTime.Now
                                  };
            db.RoomReservation.InsertOnSubmit(reservation);
            db.SubmitChanges();
            //Insert Dates

            foreach (var rTime in timeList.Select(r => new RoomReservationDates
                                                           {
                                                               AllDay = false, 
                                                               EndDate = r.Date.Add(r.End),
                                                               StartDate = r.Date.Add(r.Start),
                                                               RoomReservationID = reservation.Id
                                                           }))
            {
                db.RoomReservationDates.InsertOnSubmit(rTime);
            }

            if (comments.Trim() != string.Empty)
            {
                var revComments = new RoomReservationComments
                                      {
                                          Comments = comments.Trim(),
                                          DateSent = DateTime.Now,
                                          RoomReservationID = reservation.Id,
                                          UserID = userId
                                      };
                db.RoomReservationComments.InsertOnSubmit(revComments);
            }
            db.SubmitChanges();
            var room = db.Manager.Room.GetByKey(roomId);
            var user = db.Manager.User.GetByKey(room.UserID);
            RoomReservationEmailUtilities.InitiateRoomReservationRequest(room, user, reservation.Id, comments);
            return 1;
        }
Beispiel #3
0
 private void OnRoomReservationListRemove(RoomReservation entity)
 {
     SendPropertyChanging(null);
     entity.Room = null;
     SendPropertyChanged(null);
 }
Beispiel #4
0
 private void OnRoomReservationListAdd(RoomReservation entity)
 {
     SendPropertyChanging(null);
     entity.Room = this;
     SendPropertyChanged(null);
 }
 private void OnReserverRoomReservationListRemove(RoomReservation entity)
 {
     SendPropertyChanging(null);
     entity.ReserverUser = null;
     SendPropertyChanged(null);
 }
 private void OnReserverRoomReservationListAdd(RoomReservation entity)
 {
     SendPropertyChanging(null);
     entity.ReserverUser = this;
     SendPropertyChanged(null);
 }
 partial void OnRoomReservationChanging(RoomReservation value);
 partial void OnRoomReservationChanging(RoomReservation value);