mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-22 15:12:38 +00:00 
			
		
		
		
	git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@29038 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
			
				
	
	
		
			310 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			310 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2005-2010 Alfresco Software Limited.
 | |
|  *
 | |
|  * This file is part of Alfresco
 | |
|  *
 | |
|  * Alfresco is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU Lesser General Public License as published by
 | |
|  * the Free Software Foundation, either version 3 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * Alfresco 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 Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public License
 | |
|  * along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| package org.alfresco.service.cmr.calendar;
 | |
| 
 | |
| import java.io.Serializable;
 | |
| import java.util.ArrayList;
 | |
| import java.util.Calendar;
 | |
| import java.util.Date;
 | |
| import java.util.List;
 | |
| 
 | |
| import org.alfresco.service.cmr.repository.NodeRef;
 | |
| 
 | |
| /**
 | |
|  * This class represents an event in a calendar. 
 | |
|  * 
 | |
|  * @author Nick Burch
 | |
|  * @since 4.0
 | |
|  */
 | |
| public class CalendarEntryDTO implements CalendarEntry, Serializable {
 | |
|    private static final long serialVersionUID = -7997650453677545845L;
 | |
|    
 | |
|    private NodeRef nodeRef;
 | |
|    private NodeRef containerNodeRef;
 | |
|    private String systemName;
 | |
|    
 | |
|    private String title;
 | |
|    private String description;
 | |
|    private String location;
 | |
|    private Date start;
 | |
|    private Date end;
 | |
|    private String recurrenceRule;
 | |
|    private Date lastRecurrence;
 | |
|    private String sharePointDocFolder;
 | |
|    private boolean isOutlook = false;
 | |
|    private String outlookUID;
 | |
|    private List<String> tags = new ArrayList<String>();
 | |
|    
 | |
|    /**
 | |
|     * Creates an empty {@link CalendarEntry}, which can be populated
 | |
|     *  with set calls.
 | |
|     */
 | |
|    public CalendarEntryDTO()
 | |
|    {}
 | |
|    
 | |
|    /**
 | |
|     * Creates a {@link CalendarEntry} with common properties.
 | |
|     */
 | |
|    public CalendarEntryDTO(String title, String description, 
 | |
|          String location, Date start, Date end)
 | |
|    {
 | |
|       this.title = title;
 | |
|       this.description = description;
 | |
|       this.location = location;
 | |
|       this.start = start;
 | |
|       this.end = end;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * @return the NodeRef of the underlying calendar entry
 | |
|     */
 | |
|    public NodeRef getNodeRef() 
 | |
|    {
 | |
|       return nodeRef;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * @return the NodeRef of the calendar's container in the site
 | |
|     */
 | |
|    public NodeRef getContainerNodeRef() 
 | |
|    {
 | |
|       return containerNodeRef;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * @return the System generated name for the event
 | |
|     */
 | |
|    public String getSystemName() 
 | |
|    {
 | |
|       return systemName;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * @return the Title ("what") of the event
 | |
|     */
 | |
|    public String getTitle() 
 | |
|    {
 | |
|       return title;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Sets the Title ("what") of the event
 | |
|     */
 | |
|    public void setTitle(String title)
 | |
|    {
 | |
|       this.title = title;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * @return the Description of the event
 | |
|     */
 | |
|    public String getDescription()
 | |
|    {
 | |
|       return description;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Sets the Description of the event
 | |
|     */
 | |
|    public void setDescription(String description)
 | |
|    {
 | |
|       this.description = description;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * @return the Location of the event
 | |
|     */
 | |
|    public String getLocation()
 | |
|    {
 | |
|       return location;
 | |
|    }
 | |
| 
 | |
|    /**
 | |
|     * Sets the Location of the event
 | |
|     */
 | |
|    public void setLocation(String location)
 | |
|    {
 | |
|       this.location = location;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * @return the Start date and time
 | |
|     */
 | |
|    public Date getStart()
 | |
|    {
 | |
|       return start;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Sets the event start date and time
 | |
|     */
 | |
|    public void setStart(Date start)
 | |
|    {
 | |
|       this.start = start;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * @return the End date and time
 | |
|     */
 | |
|    public Date getEnd()
 | |
|    {
 | |
|       return end;
 | |
|    }
 | |
| 
 | |
|    /**
 | |
|     * Sets the event end date and time
 | |
|     */
 | |
|    public void setEnd(Date end)
 | |
|    {
 | |
|       this.end = end;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Gets the event recurrence rule.
 | |
|     */
 | |
|    public String getRecurrenceRule()
 | |
|    {
 | |
|       return recurrenceRule;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Sets the event recurrence rule
 | |
|     */
 | |
|    public void setRecurrenceRule(String recurrenceRule)
 | |
|    {
 | |
|       this.recurrenceRule = recurrenceRule;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Gets the date of the last instance of this recurring event
 | |
|     */
 | |
|    public Date getLastRecurrence()
 | |
|    {
 | |
|       return lastRecurrence;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Sets the date of the last instance of this recurring event
 | |
|     */
 | |
|    public void setLastRecurrence(Date lastRecurrence)
 | |
|    {
 | |
|       this.lastRecurrence = lastRecurrence;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Is this an outlook based event?
 | |
|     */
 | |
|    public boolean isOutlook()
 | |
|    {
 | |
|       return isOutlook;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Sets if this is an outlook based event or not
 | |
|     */
 | |
|    public void setOutlook(boolean outlook)
 | |
|    {
 | |
|       this.isOutlook = outlook;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Gets the UID used by Outlook for this event.
 | |
|     * See {@link CalendarEntry#isOutlook()}
 | |
|     */
 | |
|    public String getOutlookUID()
 | |
|    {
 | |
|       return outlookUID;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Sets the UID used by Outlook for this event.
 | |
|     * When a UID is set, normally the isOutlook flag is set too.
 | |
|     */
 | |
|    public void setOutlookUID(String outlookUID)
 | |
|    {
 | |
|       this.outlookUID = outlookUID;
 | |
|    }
 | |
| 
 | |
|    /**
 | |
|     * Gets the SharePoint "Doc Folder" for the event. 
 | |
|     * Only used for SharePoint based events
 | |
|     */
 | |
|    public String getSharePointDocFolder() 
 | |
|    {
 | |
|       return sharePointDocFolder;
 | |
|    }
 | |
| 
 | |
|    /**
 | |
|     * Sets the SharePoint "Doc Folder" for the event. 
 | |
|     * Only used for SharePoint based events
 | |
|     */
 | |
|    public void setSharePointDocFolder(String docFolder) 
 | |
|    {
 | |
|       this.sharePointDocFolder = docFolder;
 | |
|    }
 | |
| 
 | |
|    /**
 | |
|     * @return the Tags associated with the event 
 | |
|     */
 | |
|    public List<String> getTags()
 | |
|    {
 | |
|       return tags;
 | |
|    }
 | |
|    
 | |
|    /**
 | |
|     * Does the given {@link CalendarEntry} define an all-day
 | |
|     *  event?
 | |
|     * An All Day Event is defined as one starting at midnight
 | |
|     *  on a day, and ending at midnight.
 | |
|     *  
 | |
|     * For a single day event, the start and end dates should be
 | |
|     *  the same, and the times for both are midnight.
 | |
|     * For a multi day event, the start and end times are midnight,
 | |
|     *  for the first and last days respectively.
 | |
|     * TODO Timezones! 
 | |
|     */
 | |
|    public static boolean isAllDay(CalendarEntry entry)
 | |
|    {
 | |
|       if(entry.getStart() == null || entry.getEnd() == null)
 | |
|       {
 | |
|          // One or both dates is missing
 | |
|          return false;
 | |
|       }
 | |
|       
 | |
|       Calendar start = Calendar.getInstance();
 | |
|       Calendar end = Calendar.getInstance();
 | |
|       start.setTime(entry.getStart());
 | |
|       end.setTime(entry.getEnd());
 | |
|       
 | |
|       if(start.get(Calendar.HOUR_OF_DAY) == 0 &&
 | |
|          start.get(Calendar.MINUTE) == 0 &&
 | |
|          start.get(Calendar.SECOND) == 0 &&
 | |
|          end.get(Calendar.HOUR_OF_DAY) == 0 &&
 | |
|          end.get(Calendar.MINUTE) == 0 &&
 | |
|          end.get(Calendar.SECOND) == 0)
 | |
|       {
 | |
|          // Both midnight, counts as all day
 | |
|          return true;
 | |
|       }
 | |
|       
 | |
|       // In any other case, it isn't an all-day
 | |
|       return false;
 | |
|    }
 | |
| }
 |