kde-playground/kdepim/ktimetracker/task.h
Ivailo Monev a9b00154bc generic: replace forward class declarations with header inclusions
Signed-off-by: Ivailo Monev <xakepa10@laimg.moc>
2019-07-31 18:05:48 +00:00

411 lines
13 KiB
C++

/*
* Copyright (C) 1997 by Stephan Kulow <coolo@kde.org>
*
* 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 2 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, write to the
* Free Software Foundation, Inc.
* 51 Franklin Street, Fifth Floor
* Boston, MA 02110-1301 USA.
*
*/
#ifndef KTIMETRACKER_TASK_H
#define KTIMETRACKER_TASK_H
#include "desktoplist.h" // Required b/c DesktopList is a typedef not a class.
#include "taskview.h" // Required b/c of static cast below.
#include <KCalCore/Todo>
#include <QDateTime>
#include <QPixmap>
#include <QVector>
#include <QObject>
#include <QPixmap>
#include <QString>
class timetrackerstorage;
/** \brief A class representing a task
*
* A "Task" object stores information about a task such as it's name,
* total and session times.
*
* It can log when the task is started, stoped or deleted.
*
* If a task is associated with some desktop's activity it can remember that
* too.
*
* It can also contain subtasks - these are managed using the
* QListViewItem class.
*/
class Task : public QObject, public QTreeWidgetItem
{
Q_OBJECT
public:
Task( const QString& taskname, const QString& taskdescription, long minutes, long sessionTime,
DesktopList desktops, TaskView* parent = 0, bool konsolemode=false );
Task( const QString& taskname, const QString& taskdescription, long minutes, long sessionTime,
DesktopList desktops, Task* parent = 0);
Task( const KCalCore::Todo::Ptr &incident, TaskView* parent, bool konsolemode=false );
/* destructor */
~Task();
/** return parent Task or null in case of TaskView.
* same as QListViewItem::parent()
*/
Task* parent() const { return (Task*)QTreeWidgetItem::parent(); }
/** Return task view for this task */
TaskView* taskView() const
{ return static_cast<TaskView *>( treeWidget() ); }
/** Return unique iCalendar Todo ID for this task. */
QString uid() const;
int depth();
void delete_recursive();
/**
* Set unique id for the task.
*
* The uid is the key used to update the storage.
*
* @param uid The new unique id.
*/
void setUid( const QString &uid );
/** cut Task out of parent Task or the TaskView */
void cut();
/** cut Task out of parent Task or the TaskView and into the
* destination Task */
void move(Task* destination);
/** insert Task into the destination Task */
void paste(Task* destination);
//@{ timing related functions
/**
* Change task time. Adds minutes to both total time and session time by adding an event.
*
* @param minutes minutes to add to - may be negative
* @param storage Pointer to timetrackerstorage instance.
* If zero, don't save changes.
*/
void changeTime( long minutes, timetrackerstorage* storage );
/**
* Add minutes to time and session time by adding an event, and write to storage.
*
* @param minutesSession minutes to add to task session time
* @param minutes minutes to add to task time
* @param storage Pointer to timetrackerstorage instance.
* If zero, don't save changes.
*/
void changeTimes
( long minutesSession, long minutes, timetrackerstorage* storage=0 );
/** adds minutes to total and session time by adding an event
*
* @param minutesSession minutes to add to task total session time
* @param minutes minutes to add to task total time
*/
void changeTotalTimes( long minutesSession, long minutes );
/** Adds minutes to the time of the task and the total time of its supertasks. This does not add an event.
*
* @param minutes minutes to add to the time
* @returns A QString with the error message, in case of no error an empty QString.
*
*/
QString addTime( long minutes );
/** Adds minutes to the total time of the task and its supertasks. This does not add an event.
*
* @param minutes minutes to add to the time
* @returns A QString with the error message, in case of no error an empty QString.
*
*/
QString addTotalTime( long minutes );
/** Adds minutes to the task's session time and its supertasks' total session time. This does not add an event.
*
* @param minutes minutes to add to the session time
* @returns A QString with the error message, in case of no error an empty QString.
*
*/
QString addSessionTime( long minutes );
/** Adds minutes to the task's and its supertasks' total session time. This does not add an event.
*
* @param minutes minutes to add to the session time
* @returns A QString with the error message, in case of no error an empty QString.
*
*/
QString addTotalSessionTime( long minutes );
/** Sets the time (not session time). This does not add an event.
*
* @param minutes minutes to set time to
*
*/
QString setTime( long minutes );
/** Sets the total time, does not change the parent's total time.
This means the parent's total time can run out of sync.
*/
void setTotalTime( long minutes ) { mTotalTime=minutes; };
/** Sets the total session time, does not change the parent's total session time.
This means the parent's total session time can run out of sync.
*/
void setTotalSessionTime( long minutes ) { mTotalSessionTime=minutes; };
/** A recursive function to calculate the total time of a task. */
QString recalculatetotaltime();
/** A recursive function to calculate the total session time of a task. */
QString recalculatetotalsessiontime();
/** Sets the session time.
* Set the session time without changing totalTime nor sessionTime.
* Do not change the parent's totalTime.
* Do not add an event.
* See also: changeTimes(long, long) and resetTimes
*
* @param minutes minutes to set session time to
*
*/
QString setSessionTime( long minutes );
/**
* Reset all times to 0 and adjust parent task's totalTiMes.
*/
void resetTimes();
/** @return time in minutes */
long time() const { return mTime; };
/** @return total time in minutes */
long totalTime() const { return mTotalTime; };
long sessionTime() const { return mSessionTime; };
long totalSessionTime() const { return mTotalSessionTime; };
KDateTime sessionStartTiMe() const;
/**
* Return time the task was started.
*/
QDateTime startTime() const;
/** sets session time to zero. */
void startNewSession();
//@}
//@{ desktop related functions
void setDesktopList ( DesktopList dl );
DesktopList desktops() const;
QString getDesktopStr() const;
//@}
//@{ name related functions
/** sets the name of the task
* @param name a pointer to the name. A deep copy will be made.
* @param storage a pointer to a timetrackerstorage object.
*/
void setName( const QString& name, timetrackerstorage* storage );
/** sets the description of the task
*/
void setDescription( const QString& description);
/** returns the name of this task.
* @return a pointer to the name.
*/
QString name() const;
/** returns the description of this task.
* @return a pointer to the description.
*/
QString description() const;
/**
* Returns that task name, prefixed by parent tree up to root.
*
* Task names are separated by a forward slash: /
*/
QString fullName() const;
//@}
/** Update the display of the task (all columns) in the UI. */
void update();
//@{ the state of a Task - stopped, running
/** starts or stops a task
* @param on true or false for starting or stopping a task
* @param storage a pointer to a timetrackerstorage object.
* @param when time when the task was started or stopped. Normally
QDateTime::currentDateTime, but if calendar has
been changed by another program and being reloaded
the task is set to running with another start date
*/
void setRunning( bool on, timetrackerstorage* storage,
const QDateTime &when = QDateTime::currentDateTime() );
/** Resume the running state of a task.
* This is the same as setrunning, but the storage is not modified.
*/
void resumeRunning();
/** return the state of a task - if it's running or not
* @return true or false depending on whether the task is running
*/
bool isRunning() const;
//@}
/**
* Parses an incidence. This is needed e.g. when you create a task out of a todo.
* You read the todo, extract its custom properties (like session time)
* and use these data to initialize the task.
*/
bool parseIncidence( const KCalCore::Incidence::Ptr &, long& minutes,
long& sessionMinutes, QString& sessionStartTiMe, QString& name, QString& description, DesktopList& desktops,
int& percent_complete, int& priority );
/**
* Load the todo passed in with this tasks info.
*/
KCalCore::Todo::Ptr asTodo(const KCalCore::Todo::Ptr &calendar) const;
/**
* Set a task's description
* A description is a comment.
*/
void setDescription( QString desc, timetrackerstorage* storage );
/**
* Add a comment to this task.
* A comment is called "description" in the context of KCalCore::ToDo
*/
void addComment( const QString &comment, timetrackerstorage* storage );
/** Retrieve the entire comment for the task. */
QString comment() const;
/** tells you whether this task is the root of the task tree */
bool isRoot() const { return parent() == 0; }
/** remove Task with all it's children
* @param storage a pointer to a timetrackerstorage object.
*/
bool remove( timetrackerstorage* storage );
/**
* Update percent complete for this task.
*
* Tasks that are complete (i.e., percent = 100) do not show up in
* taskview. If percent NULL, set to zero. If greater than 100, set to
* 100. If less than zero, set to zero.
*/
void setPercentComplete(const int percent, timetrackerstorage *storage);
int percentComplete() const;
/**
* Update priority for this task.
*
* Priority is allowed from 0 to 9. 0 unspecified, 1 highest and 9 lowest.
*/
void setPriority( int priority );
int priority() const;
/** Sets an appropriate icon for this task based on its level of
* completion */
void setPixmapProgress();
/** Return true if task is complete (percent complete equals 100). */
bool isComplete();
protected:
void changeParentTotalTimes( long minutesSession, long minutes );
Q_SIGNALS:
void totalTimesChanged( long minutesSession, long minutes);
/** signal that we're about to delete a task */
void deletingTask(Task* thisTask);
protected Q_SLOTS:
/** animate the active icon */
void updateActiveIcon();
private:
/** if the time or session time is negative set them to zero */
void noNegativeTimes();
/** initialize a task */
void init( const QString& taskname, const QString& taskdescription, long minutes, long sessionTime, QString sessionStartTiMe,
DesktopList desktops, int percent_complete, int priority, bool konsolemode=false );
static QVector<QPixmap*> *icons;
/** The iCal unique ID of the Todo for this task. */
QString mUid;
/** The comment associated with this Task. */
QString mComment;
int mPercentComplete;
/** task name */
QString mName;
/** task description */
QString mDescription;
/** Last time this task was started. */
QDateTime mLastStart;
/** totals of the whole subtree including self */
long mTotalTime;
long mTotalSessionTime;
/** times spend on the task itself */
long mTime;
long mSessionTime;
/** time when the session was started */
KDateTime mSessionStartTiMe;
DesktopList mDesktops;
QTimer *mTimer;
int mCurrentPic;
/** Don't need to update storage when deleting task from list. */
bool mRemoving;
/** Priority of the task. */
int mPriority;
};
#endif // KTIMETRACKER_TASK_H