You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
tdepim/konsolekalendar/konsolekalendarvariables.h

400 lines
9.6 KiB

/*******************************************************************************
* konsolekalendarvariables.h *
* *
* KonsoleKalendar is a command line interface to KDE calendars *
* Copyright (C) 2002-2004 Tuukka Pasanen <illuusio@mailcity.com> *
* Copyright (C) 2003-2005 Allen Winter <winter@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. *
* *
* As a special exception, permission is given to link this program *
* with any edition of Qt, and distribute the resulting executable, *
* without including the source code for Qt in the source distribution. *
* *
******************************************************************************/
#ifndef _KONSOLEKALENDARVARIABLES_H_
#define _KONSOLEKALENDARVARIABLES_H_
#include <libkcal/calendarlocal.h>
#include <libkcal/calendarresources.h>
#include <libkcal/resourcelocal.h>
#include <libkcal/resourcecalendar.h>
#include <libkcal/event.h>
#include <qstring.h>
#include <qdatetime.h>
/**
* @file konsolekalendarvariables.h
* Provides the KonsoleKalendarVariables class definition.
*/
namespace KCal
{
/**
* ExportType is the type of Export output
*/
enum ExportType
{
/** Export none */
ExportTypeNone,
/** Export as text (default) */
ExportTypeText,
/** Export as compact text */
ExportTypeTextShort,
/** Export HTML for the specified time span */
ExportTypeHTML,
/** Export HTML for the time span on month boundaries */
ExportTypeMonthHTML,
/** Export XHTML (NOT AVAILABLE YET) */
ExportTypeXHTML,
/** Export XML (NOT AVAILABLE YET) */
ExportTypeXML,
/** Export Comma-Separated Values */
ExportTypeCSV,
/** Export VCard (NOT AVAILABLE YET) */
ExportTypeVCard
};
/**
* This class provides all the variables for the program.
* @author Tuukka Pasanen
* @author Allen Winter
*/
class KonsoleKalendarVariables
{
public:
/**
* Construct an empty KonsoleKalendarVariables object.
*/
KonsoleKalendarVariables();
/**
* Destructor
*/
~KonsoleKalendarVariables();
/**
* Set switch to use Events.
* @param useEvents if true, operation uses Events.
*/
void setUseEvents( bool useEvents );
/**
* Get use Events switch.
* @return true if operation using Events is specified.
*/
bool getUseEvents();
/**
* Set switch to use Todos.
* @param useTodos if true, operation uses Todos.
*/
void setUseTodos( bool useTodos );
/**
* Get use Todos switch.
* @return true if operation using Todos is specified.
*/
bool getUseTodos();
/**
* Set switch to use Journals.
* @param useJournals if true, operation uses Journals.
*/
void setUseJournals( bool useJournals );
/**
* Get use Journals switch.
* @return true if operation using Journals is specified.
*/
bool getUseJournals();
/**
* Sets start date.
* @param start is the start date.
*/
void setStartDateTime( QDateTime start );
/**
* Get start date.
* @return start date.
*/
QDateTime getStartDateTime();
/**
* Is there start date?
* @return true if there is false is there isn't.
*/
bool isStartDateTime();
/**
* Sets end date.
* @param end is the enddate.
*/
void setEndDateTime( QDateTime end );
/**
* Get end date.
* @return end date.
*/
QDateTime getEndDateTime();
/**
* Is there end date?
* @return true if there is false is there isn't.
*/
bool isEndDateTime();
/**
* Sets the UID, the unique tag for VCard entry.
* @param uid unique tag for VCard entry.
*/
void setUID( QString uid );
/**
* Get UID, the unique tag for VCard entry.
* @return UID number.
*/
QString getUID();
/**
* Is there UID set?
* @return true there is UID false there isn't.
*/
bool isUID();
/**
* Show only next activity and exit.
* @param next true or false.
*/
void setNext( bool next );
/**
* Should we show only next activity and exit?
*/
bool isNext();
/**
* Should program be more verbose?
* @param verbose a flag to set verbosity.
*/
void setVerbose( bool verbose );
/**
* Should program be more verbose?
*/
bool isVerbose();
/**
* Should we only try to run it and do nothing?
* @param dryrun false no and true just test it.
*/
void setDryRun( bool dryrun );
/**
* Is this program only in testing mode?
* @return true yes false no.
*/
bool isDryRun();
/**
* Set calendar file
* @param calendar Calendar files full path.
*/
void setCalendarFile( QString calendar );
/**
* Returns fullpath to calendar file.
* @return calendar file.
*/
QString getCalendarFile();
/**
* Set file to import active calendar.
* @param calendar Calendar file to import.
*/
void setImportFile( QString calendar );
/**
* Return import filename.
* @return File that should be imported.
*/
QString getImportFile();
/**
* Add description.
* @param description to event.
*/
void setDescription( QString description );
/**
* Return description.
* @return description of event.
*/
QString getDescription();
/**
* Is there an event description?
* @return true is there is description false there isn't.
*/
bool isDescription();
/**
* Add location information.
* @param location location where the event occurs.
*/
void setLocation( QString location );
/**
* Return location information.
* @return location where event is occurring.
*/
QString getLocation();
/**
* Is there event location information available?
* @return true is there is description false there isn't.
*/
bool isLocation();
/**
* Add summary.
* @param summary event summary.
*/
void setSummary( QString summary );
/**
* Get summary.
* @return summary.
*/
QString getSummary();
/**
* Is there an event summary?
* @return true there is false there isn't.
*/
bool isSummary();
/**
* View all option.
* @param all flag to view all Events.
*/
void setAll( bool all );
/**
* Return all option.
*/
bool getAll();
/**
* Is the all option set?
*/
bool isAll();
/**
* Set if Event is floating.
* @param floating if true then the Event is floating.
*/
void setFloating( bool floating );
/**
* Return if Event is floating.
*/
bool getFloating();
/**
* Set calendar resources for global use.
*/
void setCalendar( CalendarResources *resources );
/**
* Get global calendar resources.
*/
CalendarResources *getCalendar();
/**
* Set output file.
*/
void setExportFile( QString export_file );
/**
* To what file we'll output.
*/
QString getExportFile();
/**
* Has an Export File been set?
*/
bool isExportFile();
/**
* Set export type that'll we use.
*/
void setExportType( ExportType exportType );
/**
* What export type to use.
*/
ExportType getExportType();
/**
* Set how many day should be seen.
*/
void setDaysCount( int count );
/**
* Is there some cound of days should be seen.
*/
bool isDaysCount();
/**
* Get how many day should be seen.
*/
int getDaysCount();
private:
bool m_bIsUID;
QString m_UID;
bool m_bIsStartDateTime;
QDateTime m_startDateTime;
bool m_bIsEndDateTime;
QDateTime m_endDateTime;
bool m_bNext;
bool m_bVerbose;
bool m_bDryRun;
bool m_bUseEvents;
bool m_bUseTodos;
bool m_bUseJournals;
QString m_calendar;
QString m_import;
ExportType m_exportType;
bool m_bIsExportFile;
QString m_exportFile;
bool m_bAll;
bool m_bDescription;
QString m_description;
bool m_bLocation;
QString m_location;
bool m_bSummary;
QString m_summary;
bool m_bFloating;
bool m_bDaysCount;
int m_daysCount;
CalendarResources *m_calendarResources;
};
}
#endif