org.netbeans.modules.bugtracking.spi.IssueScheduleProvider Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package org.netbeans.modules.bugtracking.spi;
import java.util.Date;
/**
* Provides access to scheduling data for a given task so that they can by used
* by the Tasks Dashboard facilities - filtering or grouping by schedule date.
*
*
* Typically a bugtracking system make it possible to specify a date when an issue
* is due, but this doesn't have to be the same date as the user private date for
* which an Issue was scheduled to start work on.
*
*
*
* It is up to the particular implementation if the values eventually match with
* corresponding remote repository fields or if they are merely handed
* locally as user private.
*
*
*
* Note that an implementation of this interface is not mandatory for a
* NetBeans bugtracking plugin.
*
*
* @author Tomas Stupka
* @param the implementation specific issue type
* @since 1.85
*/
public interface IssueScheduleProvider {
/**
* Issue schedule has changed. Fire this on registered IssueProvider listeners
* in case changes were made plugin-internally and not via the setters on this interface.
*
* @since 1.85
* @see IssueProvider#addPropertyChangeListener(java.lang.Object, java.beans.PropertyChangeListener)
*/
public static final String EVENT_ISSUE_SCHEDULE_CHANGED = "issue.schedule_changed"; // NOI18N
/**
* Sets the schedule info describing the time period for which
* the Issue was scheduled to start work on.
*
* Note that this is a different date as when the Issue is due to be finished.
*
*
* @param i an implementation specific issue instance
* @param scheduleInfo a ScheduleInfo describing the Issues scheduling
* @since 1.85
*/
public void setSchedule(I i, IssueScheduleInfo scheduleInfo);
/**
* Returns the due date or null
if not provided (by the remote repository).
*
*
* Note that this is a different date as for when the Issue is scheduled.
*
*
* @param i an implementation specific issue instance
* @return the Issues due date
* @since 1.85
*/
public Date getDueDate(I i);
/**
* Returns the the schedule info describing the time period for which
* the Issue was scheduled to start work on.
*
*
* Note that this is a different date as when the Issue is due to be finished.
*
*
* @param i an implementation specific issue instance
* @return the Issues schedule info
* @since 1.85
*/
public IssueScheduleInfo getSchedule(I i);
}