diff options
Diffstat (limited to 'kplato/kptview.cc')
-rw-r--r-- | kplato/kptview.cc | 1519 |
1 files changed, 1519 insertions, 0 deletions
diff --git a/kplato/kptview.cc b/kplato/kptview.cc new file mode 100644 index 00000000..321bff42 --- /dev/null +++ b/kplato/kptview.cc @@ -0,0 +1,1519 @@ +/* This file is part of the KDE project + Copyright (C) 1998, 1999, 2000 Torben Weis <weis@kde.org> + Copyright (C) 2002 - 2005 Dag Andersen <danders@get2net.dk> + + This library is free software; you can redistribute it and/or + modify it under the terms of the GNU Library General Public + License as published by the Free Software Foundation; either + version 2 of the License, or (at your option) any later version. + + This library 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 + Library General Public License for more details. + + You should have received a copy of the GNU Library General Public License + along with this library; see the file COPYING.LIB. If not, write to + the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + * Boston, MA 02110-1301, USA. +*/ + +#include <kprinter.h> +#include <kmessagebox.h> + +#include <KoMainWindow.h> + +#include <qapplication.h> +#include <qpainter.h> +#include <qiconset.h> +#include <qlayout.h> +#include <qsplitter.h> +#include <qcanvas.h> +#include <qscrollview.h> +#include <qcolor.h> +#include <qlabel.h> +#include <qstring.h> +#include <qstringlist.h> +#include <qvbox.h> +#include <qgrid.h> +#include <qsize.h> +#include <qheader.h> +#include <qtabwidget.h> +#include <qwidgetstack.h> +#include <qtimer.h> +#include <qpopupmenu.h> +#include <qpair.h> + +#include <kiconloader.h> +#include <kaction.h> +#include <kstdaction.h> +#include <klocale.h> +#include <kdebug.h> +#include <klistview.h> +#include <kstdaccel.h> +#include <kaccelgen.h> +#include <kdeversion.h> +#include <kstatusbar.h> +#include <kxmlguifactory.h> + +#include <kstandarddirs.h> +#include <kdesktopfile.h> +#include <kcommand.h> +#include <kfiledialog.h> + +#include "kptview.h" +#include "kptaccountsview.h" +#include "kptfactory.h" +#include "kptmilestoneprogressdialog.h" +#include "kptnode.h" +#include "kptpart.h" +#include "kptproject.h" +#include "kptmainprojectdialog.h" +#include "kptprojectdialog.h" +#include "kpttask.h" +#include "kptsummarytaskdialog.h" +#include "kpttaskdialog.h" +#include "kpttaskprogressdialog.h" +#include "kptganttview.h" +#include "kptpertview.h" +//#include "kptreportview.h" +#include "kptdatetime.h" +#include "kptcommand.h" +#include "kptrelation.h" +#include "kptrelationdialog.h" +#include "kptresourceview.h" +#include "kptresourcedialog.h" +#include "kptresource.h" +#include "kptresourcesdialog.h" +#include "kptcalendarlistdialog.h" +#include "kptstandardworktimedialog.h" +#include "kptcanvasitem.h" +#include "kptconfigdialog.h" +#include "kptwbsdefinitiondialog.h" +#include "kptaccountsdialog.h" + +#include "KDGanttView.h" +#include "KDGanttViewTaskItem.h" +#include "KPtViewIface.h" + +namespace KPlato +{ + +View::View(Part* part, QWidget* parent, const char* /*name*/) + : KoView(part, parent, "Main View"), + m_ganttview(0), + m_ganttlayout(0), + m_pertview(0), + m_pertlayout(0), +// m_reportview(0), + m_baselineMode(false), + m_currentEstimateType(Effort::Use_Expected) +{ + //kdDebug()<<k_funcinfo<<endl; + getProject().setCurrentSchedule(Schedule::Expected); + + setInstance(Factory::global()); + if ( !part->isReadWrite() ) + setXMLFile("kplato_readonly.rc"); + else + setXMLFile("kplato.rc"); + m_dcop = 0L; + // build the DCOP object + dcopObject(); + + m_tab = new QWidgetStack(this); + QVBoxLayout *layout = new QVBoxLayout(this); + layout->add(m_tab); + + m_ganttview = new GanttView(m_tab, part->isReadWrite()); + m_tab->addWidget(m_ganttview); + m_updateGanttview = false; + m_ganttview->draw(getPart()->getProject()); + + m_pertview = new PertView( this, m_tab, layout ); + m_tab->addWidget(m_pertview); + + m_resourceview = new ResourceView( this, m_tab ); + m_updateResourceview = true; + m_tab->addWidget(m_resourceview); + + m_accountsview = new AccountsView( getProject(), this, m_tab ); + m_updateAccountsview = true; + m_tab->addWidget(m_accountsview); + + //m_reportview = new ReportView(this, m_tab); + //m_tab->addWidget(m_reportview); + + connect(m_tab, SIGNAL(aboutToShow(QWidget *)), this, SLOT(slotAboutToShow(QWidget *))); + + connect(m_pertview, SIGNAL(addRelation(Node*, Node*)), SLOT(slotAddRelation(Node*, Node*))); + connect(m_pertview, SIGNAL(modifyRelation(Relation*)), SLOT(slotModifyRelation(Relation*))); + + connect(m_ganttview, SIGNAL(enableActions(bool)), SLOT(setTaskActionsEnabled(bool))); + connect(m_ganttview, SIGNAL(addRelation(Node*, Node*, int)), SLOT(slotAddRelation(Node*, Node*, int))); + connect(m_ganttview, SIGNAL(modifyRelation(Relation*, int)), SLOT(slotModifyRelation(Relation*, int))); + connect(m_ganttview, SIGNAL(modifyRelation(Relation*)), SLOT(slotModifyRelation(Relation*))); + connect(m_ganttview, SIGNAL(itemDoubleClicked()), SLOT(slotOpenNode())); + connect(m_ganttview, SIGNAL(itemRenamed(Node*, const QString&)),this,SLOT(slotRenameNode(Node*, const QString&))); + connect(m_ganttview, SIGNAL(requestPopupMenu(const QString&, const QPoint &)),this,SLOT(slotPopupMenu(const QString&, const QPoint&))); + connect(m_resourceview, SIGNAL(itemDoubleClicked()), SLOT(slotEditResource())); + + // The menu items + // ------ Edit + actionCut = KStdAction::cut( this, SLOT( slotEditCut() ), actionCollection(), "edit_cut" ); + actionCopy = KStdAction::copy( this, SLOT( slotEditCopy() ), actionCollection(), "edit_copy" ); + actionPaste = KStdAction::paste( this, SLOT( slotEditPaste() ), actionCollection(), "edit_paste" ); + + actionIndentTask = new KAction(i18n("Indent Task"), "indent_task", 0, this, + SLOT(slotIndentTask()), actionCollection(), "indent_task"); + actionUnindentTask = new KAction(i18n("Unindent Task"), "unindent_task", 0, this, + SLOT(slotUnindentTask()), actionCollection(), "unindent_task"); + actionMoveTaskUp = new KAction(i18n("Move Up"), "move_task_up", 0, this, + SLOT(slotMoveTaskUp()), actionCollection(), "move_task_up"); + actionMoveTaskDown = new KAction(i18n("Move Down"), "move_task_down", 0, this, + SLOT(slotMoveTaskDown()), actionCollection(), "move_task_down"); + + // ------ View + actionViewGantt = new KAction(i18n("Gantt"), "gantt_chart", 0, this, SLOT(slotViewGantt()), actionCollection(), "view_gantt"); + + QString group = "EstimationType"; + actionViewExpected = new KRadioAction(i18n("Expected"), 0, 0, this, SLOT(slotViewExpected()), actionCollection(), "view_expected"); + actionViewExpected->setExclusiveGroup(group); + actionViewOptimistic = new KRadioAction(i18n("Optimistic"), 0, 0, this, SLOT(slotViewOptimistic()), actionCollection(), "view_optimistic"); + actionViewOptimistic->setExclusiveGroup(group); + actionViewPessimistic = new KRadioAction(i18n("Pessimistic"), 0, 0, this, SLOT(slotViewPessimistic()), actionCollection(), "view_pessimistic"); + actionViewPessimistic->setExclusiveGroup(group); + + actionViewGanttResources = new KToggleAction(i18n("Resources"), 0, 0, this, SLOT(slotViewGanttResources()), actionCollection(), "view_gantt_showResources"); + actionViewGanttTaskName = new KToggleAction(i18n("Task Name"), 0, 0, this, SLOT(slotViewGanttTaskName()), actionCollection(), "view_gantt_showTaskName"); + actionViewGanttTaskLinks = new KToggleAction(i18n("Task Links"), 0, 0, this, SLOT(slotViewGanttTaskLinks()), actionCollection(), "view_gantt_showTaskLinks"); + actionViewGanttProgress = new KToggleAction(i18n("Progress"), 0, 0, this, SLOT(slotViewGanttProgress()), actionCollection(), "view_gantt_showProgress"); + actionViewGanttFloat = new KToggleAction(i18n("Float"), 0, 0, this, SLOT(slotViewGanttFloat()), actionCollection(), "view_gantt_showFloat"); + actionViewGanttCriticalTasks = new KToggleAction(i18n("Critical Tasks"), 0, 0, this, SLOT(slotViewGanttCriticalTasks()), actionCollection(), "view_gantt_showCriticalTasks"); + actionViewGanttCriticalPath = new KToggleAction(i18n("Critical Path"), 0, 0, this, SLOT(slotViewGanttCriticalPath()), actionCollection(), "view_gantt_showCriticalPath"); + +// actionViewGanttNotScheduled = new KToggleAction(i18n("Not Scheduled"), 0, 0, this, SLOT(slotViewGanttNotScheduled()), actionCollection(), "view_gantt_showNotScheduled"); + + actionViewTaskAppointments = new KToggleAction(i18n("Show Allocations"), 0, 0, this, SLOT(slotViewTaskAppointments()), actionCollection(), "view_task_appointments"); + + actionViewPert = new KAction(i18n("Network"), "pert_chart", 0, this, SLOT(slotViewPert()), actionCollection(), "view_pert"); + + actionViewResources = new KAction(i18n("Resources"), "resources", 0, this, SLOT(slotViewResources()), actionCollection(), "view_resources"); + + actionViewResourceAppointments = new KToggleAction(i18n("Show Allocations"), 0, 0, this, SLOT(slotViewResourceAppointments()), actionCollection(), "view_resource_appointments"); + + actionViewAccounts = new KAction(i18n("Accounts"), "accounts", 0, this, SLOT(slotViewAccounts()), actionCollection(), "view_accounts"); + + //actionViewReports = new KAction(i18n("Reports"), "reports", 0, this, SLOT(slotViewReports()), actionCollection(), "view_reports"); + + // ------ Insert + actionAddTask = new KAction(i18n("Task..."), "add_task", 0, this, + SLOT(slotAddTask()), actionCollection(), "add_task"); + actionAddSubtask = new KAction(i18n("Sub-Task..."), "add_sub_task", 0, this, + SLOT(slotAddSubTask()), actionCollection(), "add_sub_task"); + actionAddMilestone = new KAction(i18n("Milestone..."), "add_milestone", 0, this, + SLOT(slotAddMilestone()), actionCollection(), "add_milestone"); + + // ------ Project + actionEditMainProject = new KAction(i18n("Edit Main Project..."), "edit", 0, this, SLOT(slotProjectEdit()), actionCollection(), "project_edit"); + actionEditStandardWorktime = new KAction(i18n("Edit Standard Worktime..."), "edit", 0, this, SLOT(slotProjectWorktime()), actionCollection(), "project_worktime"); + actionEditCalendar = new KAction(i18n("Edit Calendar..."), "edit", 0, this, SLOT(slotProjectCalendar()), actionCollection(), "project_calendar"); + actionEditAccounts = new KAction(i18n("Edit Accounts..."), "edit", 0, this, SLOT(slotProjectAccounts()), actionCollection(), "project_accounts"); + actionEditResources = new KAction(i18n("Edit Resources..."), "edit", 0, this, SLOT(slotProjectResources()), actionCollection(), "project_resources"); + + actionCalculate = new KActionMenu(i18n("Calculate"), "project_calculate", actionCollection(), "project_calculate"); + connect(actionCalculate, SIGNAL(activated()), SLOT(slotProjectCalculate())); + + actionCalculateExpected = new KAction(i18n("Expected"), 0, 0, this, SLOT(slotProjectCalculateExpected()), actionCollection(), "project_calculate_expected"); + actionCalculate->insert(actionCalculateExpected); + + actionCalculateOptimistic = new KAction(i18n("Optimistic"), 0, 0, this, SLOT(slotProjectCalculateOptimistic()), actionCollection(), "project_calculate_optimistic"); + actionCalculate->insert(actionCalculateOptimistic); + + actionCalculatePessimistic = new KAction(i18n("Pessimistic"), 0, 0, this, SLOT(slotProjectCalculatePessimistic()), actionCollection(), "project_calculate_pessimistic"); + actionCalculate->insert(actionCalculatePessimistic); + +/* // ------ Reports + actionFirstpage = KStdAction::firstPage(m_reportview,SLOT(slotPrevPage()),actionCollection(),"go_firstpage"); + connect(m_reportview, SIGNAL(setFirstPageActionEnabled(bool)), actionFirstpage, SLOT(setEnabled(bool))); + actionPriorpage = KStdAction::prior(m_reportview,SLOT(slotPrevPage()),actionCollection(),"go_prevpage"); + connect(m_reportview, SIGNAL(setPriorPageActionEnabled(bool)), actionPriorpage, SLOT(setEnabled(bool))); + actionNextpage = KStdAction::next(m_reportview,SLOT(slotNextPage()),actionCollection(), "go_nextpage"); + connect(m_reportview, SIGNAL(setNextPageActionEnabled(bool)), actionNextpage, SLOT(setEnabled(bool))); + actionLastpage = KStdAction::lastPage(m_reportview,SLOT(slotLastPage()),actionCollection(), "go_lastpage"); + connect(m_reportview, SIGNAL(setLastPageActionEnabled(bool)), actionLastpage, SLOT(setEnabled(bool))); + m_reportview->enableNavigationBtn();*/ + mainWindow()->toolBar("report")->hide(); + +// new KAction(i18n("Design..."), "report_design", 0, this, +// SLOT(slotReportDesign()), actionCollection(), "report_design"); + + + // ------ Tools + actionDefineWBS = + new KAction(i18n("Define WBS Pattern..."), "tools_define_wbs", 0, this, + SLOT(slotDefineWBS()), actionCollection(), "tools_generate_wbs"); + actionGenerateWBS = + new KAction(i18n("Generate WBS Code"), "tools_generate_wbs", 0, this, + SLOT(slotGenerateWBS()), actionCollection(), "tools_define_wbs"); + + // ------ Export (testing) + //actionExportGantt = new KAction(i18n("Export Ganttview"), "export_gantt", 0, this, + // SLOT(slotExportGantt()), actionCollection(), "export_gantt"); + + // ------ Settings + actionConfigure = new KAction(i18n("Configure KPlato..."), "configure", 0, this, + SLOT(slotConfigure()), actionCollection(), "configure"); + + // ------ Popup + actionOpenNode = new KAction(i18n("Edit..."), "edit", 0, this, + SLOT(slotOpenNode()), actionCollection(), "node_properties"); + actionTaskProgress = new KAction(i18n("Progress..."), "edit", 0, this, + SLOT(slotTaskProgress()), actionCollection(), "task_progress"); + actionDeleteTask = new KAction(i18n("Delete Task"), "editdelete", 0, this, + SLOT(slotDeleteTask()), actionCollection(), "delete_task"); + + actionEditResource = new KAction(i18n("Edit Resource..."), "edit", 0, this, + SLOT(slotEditResource()), actionCollection(), "edit_resource"); + + // ------------------- Actions with a key binding and no GUI item + // Temporary, till we get a menu entry + actNoInformation = new KAction("Toggle no information", CTRL+SHIFT+Key_T, this, SLOT(slotViewGanttNoInformation()), actionCollection(), "show_noinformation"); + +#ifndef NDEBUG + //new KAction("Print Debug", CTRL+SHIFT+Key_P, this, SLOT( slotPrintDebug()), actionCollection(), "print_debug"); + new KAction("Print Debug", CTRL+SHIFT+Key_P, this, SLOT(slotPrintSelectedDebug()), actionCollection(), "print_debug"); + new KAction("Print Calendar Debug", CTRL+SHIFT+Key_C, this, SLOT(slotPrintCalendarDebug()), actionCollection(), "print_calendar_debug"); +// new KAction("Print Test Debug", CTRL+SHIFT+Key_T, this, SLOT(slotPrintTestDebug()), actionCollection(), "print_test_debug"); + + KAction* actExportGantt = new KAction( i18n( "Export Gantt" ), CTRL+SHIFT+Key_G, + this, SLOT( slotExportGantt() ), actionCollection(), "export_gantt" ); + +#endif + // Stupid compilers ;) +#ifndef NDEBUG +/* Q_UNUSED( actPrintSelectedDebug ); + Q_UNUSED( actPrintCalendarDebug );*/ + Q_UNUSED( actExportGantt ); +#endif + + m_estlabel = new KStatusBarLabel("", 0); + addStatusBarItem(m_estlabel, 0, true); + actionViewExpected->setChecked(true); //TODO: context + setScheduleActionsEnabled(); + slotViewExpected(); + + setTaskActionsEnabled(false); +} + +View::~View() +{ + delete m_dcop; + removeStatusBarItem(m_estlabel); + delete m_estlabel; +} + +DCOPObject * View::dcopObject() +{ + if ( !m_dcop ) + m_dcop = new ViewIface( this ); + + return m_dcop; +} + + +Project& View::getProject() const +{ + return getPart()->getProject(); +} + +void View::setZoom(double zoom) { + m_ganttview->setZoom(zoom); + m_pertview->setZoom(zoom); +} + +void View::setupPrinter(KPrinter &/*printer*/) { + //kdDebug()<<k_funcinfo<<endl; +} + +void View::print(KPrinter &printer) { + //kdDebug()<<k_funcinfo<<endl; + if (printer.previewOnly()) { + //HACK: KoMainWindow shows setup on print, but not on print preview! + if (!printer.setup()) { + return; + } + } + if (m_tab->visibleWidget() == m_ganttview) + { + m_ganttview->print(printer); + } + else if (m_tab->visibleWidget() == m_pertview) + { + m_pertview->print(printer); + } + else if (m_tab->visibleWidget() == m_resourceview) + { + m_resourceview->print(printer); + } + else if (m_tab->visibleWidget() == m_accountsview) + { + m_accountsview->print(printer); + } +// else if (m_tab->visibleWidget() == m_reportview) +// { +// m_reportview->print(printer); +// } + +} + +void View::slotEditCut() { + //kdDebug()<<k_funcinfo<<endl; +} + +void View::slotEditCopy() { + //kdDebug()<<k_funcinfo<<endl; +} + +void View::slotEditPaste() { + //kdDebug()<<k_funcinfo<<endl; +} + +void View::slotViewExpected() { + //kdDebug()<<k_funcinfo<<endl; + m_currentEstimateType = Effort::Use_Expected; + getProject().setCurrentSchedulePtr(getProject().findSchedule(Schedule::Expected)); + slotUpdate(false); +} + +void View::slotViewOptimistic() { + //kdDebug()<<k_funcinfo<<endl; + m_currentEstimateType = Effort::Use_Optimistic; + getProject().setCurrentSchedulePtr(getProject().findSchedule(Schedule::Optimistic)); + slotUpdate(false); +} + +void View::slotViewPessimistic() { + //kdDebug()<<k_funcinfo<<endl; + m_currentEstimateType = Effort::Use_Pessimistic; + getProject().setCurrentSchedulePtr(getProject().findSchedule(Schedule::Pessimistic)); + slotUpdate(false); +} + +void View::slotViewGanttResources() { + //kdDebug()<<k_funcinfo<<endl; + m_ganttview->setShowResources(actionViewGanttResources->isChecked()); + if (m_tab->visibleWidget() == m_ganttview) + slotUpdate(false); +} + +void View::slotViewGanttTaskName() { + //kdDebug()<<k_funcinfo<<endl; + m_ganttview->setShowTaskName(actionViewGanttTaskName->isChecked()); + if (m_tab->visibleWidget() == m_ganttview) + slotUpdate(false); +} + +void View::slotViewGanttTaskLinks() { + //kdDebug()<<k_funcinfo<<endl; + m_ganttview->setShowTaskLinks(actionViewGanttTaskLinks->isChecked()); + if (m_tab->visibleWidget() == m_ganttview) + slotUpdate(false); +} + +void View::slotViewGanttProgress() { + //kdDebug()<<k_funcinfo<<endl; + m_ganttview->setShowProgress(actionViewGanttProgress->isChecked()); + if (m_tab->visibleWidget() == m_ganttview) + slotUpdate(false); +} + +void View::slotViewGanttFloat() { + //kdDebug()<<k_funcinfo<<endl; + m_ganttview->setShowPositiveFloat(actionViewGanttFloat->isChecked()); + if (m_tab->visibleWidget() == m_ganttview) + slotUpdate(false); +} + +void View::slotViewGanttCriticalTasks() { + //kdDebug()<<k_funcinfo<<endl; + m_ganttview->setShowCriticalTasks(actionViewGanttCriticalTasks->isChecked()); + if (m_tab->visibleWidget() == m_ganttview) + slotUpdate(false); +} + +void View::slotViewGanttCriticalPath() { + //kdDebug()<<k_funcinfo<<endl; + m_ganttview->setShowCriticalPath(actionViewGanttCriticalPath->isChecked()); + if (m_tab->visibleWidget() == m_ganttview) + slotUpdate(false); +} + +void View::slotViewGanttNoInformation() { + kdDebug()<<k_funcinfo<<m_ganttview->showNoInformation()<<endl; + m_ganttview->setShowNoInformation(!m_ganttview->showNoInformation()); //Toggle + if (m_tab->visibleWidget() == m_ganttview) + slotUpdate(false); +} + +void View::slotViewTaskAppointments() { + //kdDebug()<<k_funcinfo<<endl; + m_ganttview->setShowAppointments(actionViewTaskAppointments->isChecked()); + m_updateGanttview = true; + if (m_tab->visibleWidget() == m_ganttview) + slotUpdate(false); +} + +void View::slotViewGantt() { + //kdDebug()<<k_funcinfo<<endl; + m_tab->raiseWidget(m_ganttview); +} + +void View::slotViewPert() { + //kdDebug()<<k_funcinfo<<endl; + m_tab->raiseWidget(m_pertview); +} + +void View::slotViewResources() { + //kdDebug()<<k_funcinfo<<endl; + m_tab->raiseWidget(m_resourceview); +} + +void View::slotViewResourceAppointments() { + //kdDebug()<<k_funcinfo<<endl; + m_resourceview->setShowAppointments(actionViewResourceAppointments->isChecked()); + m_updateResourceview = true; + if (m_tab->visibleWidget() == m_resourceview) + slotUpdate(false); +} + +void View::slotViewAccounts() { + //kdDebug()<<k_funcinfo<<endl; + m_tab->raiseWidget(m_accountsview); +} + +void View::slotProjectEdit() { + MainProjectDialog *dia = new MainProjectDialog(getProject()); + if (dia->exec()) { + KCommand *cmd = dia->buildCommand(getPart()); + if (cmd) { + getPart()->addCommand(cmd); + } + } + delete dia; +} + +void View::slotProjectCalendar() { + CalendarListDialog *dia = new CalendarListDialog(getProject()); + if (dia->exec()) { + KCommand *cmd = dia->buildCommand(getPart()); + if (cmd) { + //kdDebug()<<k_funcinfo<<"Modifying calendar(s)"<<endl; + getPart()->addCommand(cmd); //also executes + } + } + delete dia; +} + +void View::slotProjectAccounts() { + AccountsDialog *dia = new AccountsDialog(getProject().accounts()); + if (dia->exec()) { + KCommand *cmd = dia->buildCommand(getPart()); + if (cmd) { + //kdDebug()<<k_funcinfo<<"Modifying account(s)"<<endl; + getPart()->addCommand(cmd); //also executes + } + } + delete dia; +} + +void View::slotProjectWorktime() { + StandardWorktimeDialog *dia = new StandardWorktimeDialog(getProject()); + if (dia->exec()) { + KCommand *cmd = dia->buildCommand(getPart()); + if (cmd) { + //kdDebug()<<k_funcinfo<<"Modifying calendar(s)"<<endl; + getPart()->addCommand(cmd); //also executes + } + } + delete dia; +} + +void View::slotProjectResources() { + ResourcesDialog *dia = new ResourcesDialog(getProject()); + if (dia->exec()) { + KCommand *cmd = dia->buildCommand(getPart()); + if (cmd) { + //kdDebug()<<k_funcinfo<<"Modifying resources"<<endl; + getPart()->addCommand(cmd); //also executes + } + } + delete dia; +} + +void View::slotProjectCalculate() { + //kdDebug()<<k_funcinfo<<endl; + slotUpdate(true); +} + +void View::slotProjectCalculateExpected() { + m_currentEstimateType = Effort::Use_Expected; + m_updateGanttview = true; + m_updateResourceview = true; + m_updateAccountsview = true; + slotUpdate(true); +} + +void View::slotProjectCalculateOptimistic() { + m_currentEstimateType = Effort::Use_Optimistic; + m_updateGanttview = true; + m_updateResourceview = true; + m_updateAccountsview = true; + slotUpdate(true); +} + +void View::slotProjectCalculatePessimistic() { + m_currentEstimateType = Effort::Use_Pessimistic; + m_updateGanttview = true; + m_updateResourceview = true; + m_updateAccountsview = true; + slotUpdate(true); +} + +void View::projectCalculate() { + if (false /*getProject().actualEffort() > 0*/) { + // NOTE: This can be removed when proper baselining etc is implemented + if (KMessageBox::warningContinueCancel(this, i18n("Progress information will be deleted if the project is recalculated."), i18n("Calculate"), i18n("Calculate")) == KMessageBox::Cancel) { + return; + } + } + QApplication::setOverrideCursor(Qt::waitCursor); + Schedule *ns = getProject().findSchedule((Schedule::Type)m_currentEstimateType); + KCommand *cmd; + if (ns) { + cmd = new RecalculateProjectCmd(getPart(), getProject(), *ns, i18n("Calculate")); + } else { + cmd = new CalculateProjectCmd(getPart(), getProject(), i18n("Standard"), (Effort::Use)m_currentEstimateType, i18n("Calculate")); + } + getPart()->addCommand(cmd); + QApplication::restoreOverrideCursor(); +} + +void View::slotViewReportDesign() { + //kdDebug()<<k_funcinfo<<endl; +} + +void View::slotViewReports() { + //kdDebug()<<k_funcinfo<<endl; + //m_tab->raiseWidget(m_reportview); +} + +void View::slotAddSubTask() { + // If we are positionend on the root project, then what we really want to + // do is to add a first project. We will silently accept the challenge + // and will not complain. + Task* node = getProject().createTask(getPart()->config().taskDefaults(), currentTask()); + TaskDialog *dia = new TaskDialog(*node, getProject().accounts(), getProject().standardWorktime(), getProject().isBaselined()); + if (dia->exec()) { + Node *currNode = currentTask(); + if (currNode) + { + KCommand *m = dia->buildCommand(getPart()); + m->execute(); // do changes to task + delete m; + SubtaskAddCmd *cmd = new SubtaskAddCmd(getPart(), &(getProject()), node, currNode, i18n("Add Subtask")); + getPart()->addCommand(cmd); // add task to project + return; + } + else + kdDebug()<<k_funcinfo<<"Cannot insert new project. Hmm, no current node!?"<<endl; + } + delete node; + delete dia; +} + + +void View::slotAddTask() { + Task* node = getProject().createTask(getPart()->config().taskDefaults(), currentTask()); + TaskDialog *dia = new TaskDialog(*node, getProject().accounts(), getProject().standardWorktime(), getProject().isBaselined()); + if (dia->exec()) { + Node* currNode = currentTask(); + if (currNode) + { + KCommand *m = dia->buildCommand(getPart()); + m->execute(); // do changes to task + delete m; + TaskAddCmd *cmd = new TaskAddCmd(getPart(), &(getProject()), node, currNode, i18n("Add Task")); + getPart()->addCommand(cmd); // add task to project + return; + } + else + kdDebug()<<k_funcinfo<<"Cannot insert new task. Hmm, no current node!?"<<endl; + } + delete node; + delete dia; +} + +void View::slotAddMilestone() { + Task* node = getProject().createTask(currentTask()); + node->effort()->set(Duration::zeroDuration); + + TaskDialog *dia = new TaskDialog(*node, getProject().accounts(), getProject().standardWorktime(), getProject().isBaselined()); + if (dia->exec()) { + Node *currNode = currentTask(); + if (currNode) + { + KCommand *m = dia->buildCommand(getPart()); + m->execute(); // do changes to task + delete m; + TaskAddCmd *cmd = new TaskAddCmd(getPart(), &(getProject()), node, currNode, i18n("Add Milestone")); + getPart()->addCommand(cmd); // add task to project + return; + } + else + kdDebug()<<k_funcinfo<<"Cannot insert new milestone. Hmm, no current node!?"<<endl; + } + delete node; + delete dia; +} + +void View::slotDefineWBS() { + //kdDebug()<<k_funcinfo<<endl; + WBSDefinitionDialog *dia = new WBSDefinitionDialog(getPart()->wbsDefinition()); + dia->exec(); + + delete dia; +} + +void View::slotGenerateWBS() { + //kdDebug()<<k_funcinfo<<endl; + getPart()->generateWBS(); + slotUpdate(false); +} + +void View::slotConfigure() { + //kdDebug()<<k_funcinfo<<endl; + ConfigDialog *dia = new ConfigDialog(getPart()->config(), getProject()); + dia->exec(); + delete dia; +} + +Node *View::currentTask() +{ + Node* task = 0; + if (m_tab->visibleWidget() == m_ganttview) { + task = m_ganttview->currentNode(); + } + else if (m_tab->visibleWidget() == m_pertview) { + task = m_pertview->currentNode(); + } + else if (m_tab->visibleWidget() == m_resourceview) { + task = m_resourceview->currentNode(); + } + if ( 0 != task ) { + return task; + } + return &(getProject()); +} + +void View::slotOpenNode() { + //kdDebug()<<k_funcinfo<<endl; + Node *node = currentTask(); + if (!node) + return; + + switch (node->type()) { + case Node::Type_Project: { + Project *project = dynamic_cast<Project *>(node); + MainProjectDialog *dia = new MainProjectDialog(*project); + if (dia->exec()){ + KCommand *m = dia->buildCommand(getPart()); + if (m) { + getPart()->addCommand(m); + } + } + delete dia; + break; + } + case Node::Type_Subproject: + //TODO + break; + case Node::Type_Task: { + Task *task = dynamic_cast<Task *>(node); + TaskDialog *dia = new TaskDialog(*task, getProject().accounts(), getProject().standardWorktime(), getProject().isBaselined()); + if (dia->exec()) { + KCommand *m = dia->buildCommand(getPart()); + if (m) { + getPart()->addCommand(m); + } + } + delete dia; + break; + } + case Node::Type_Milestone: { + // Use the normal task dialog for now. + // Maybe milestone should have it's own dialog, but we need to be able to + // enter a duration in case we accidentally set a tasks duration to zero + // and hence, create a milestone + Task *task = dynamic_cast<Task *>(node); + TaskDialog *dia = new TaskDialog(*task, getProject().accounts(), getProject().standardWorktime(), getProject().isBaselined()); + if (dia->exec()) { + KCommand *m = dia->buildCommand(getPart()); + if (m) { + getPart()->addCommand(m); + } + } + delete dia; + break; + } + case Node::Type_Summarytask: { + Task *task = dynamic_cast<Task *>(node); + SummaryTaskDialog *dia = new SummaryTaskDialog(*task); + if (dia->exec()) { + KCommand *m = dia->buildCommand(getPart()); + if (m) { + getPart()->addCommand(m); + } + } + delete dia; + break; + } + default: + break; // avoid warnings + } +} + +void View::slotTaskProgress() { + //kdDebug()<<k_funcinfo<<endl; + Node *node = currentTask(); + if (!node) + return; + + switch (node->type()) { + case Node::Type_Project: { + break; + } + case Node::Type_Subproject: + //TODO + break; + case Node::Type_Task: { + Task *task = dynamic_cast<Task *>(node); + TaskProgressDialog *dia = new TaskProgressDialog(*task, getProject().standardWorktime()); + if (dia->exec()) { + KCommand *m = dia->buildCommand(getPart()); + if (m) { + getPart()->addCommand(m); + } + } + delete dia; + break; + } + case Node::Type_Milestone: { + Task *task = dynamic_cast<Task *>(node); + MilestoneProgressDialog *dia = new MilestoneProgressDialog(*task); + if (dia->exec()) { + KCommand *m = dia->buildCommand(getPart()); + if (m) { + getPart()->addCommand(m); + } + } + delete dia; + break; + } + case Node::Type_Summarytask: { + // TODO + break; + } + default: + break; // avoid warnings + } +} + +void View::slotDeleteTask() +{ + //kdDebug()<<k_funcinfo<<endl; + Node *node = currentTask(); + if (node == 0 || node->getParent() == 0) { + kdDebug()<<k_funcinfo<<(node ? "Task is main project" : "No current task")<<endl; + return; + } + KMacroCommand *cmd = new KMacroCommand(i18n("Delete Task")); + cmd->addCommand(new NodeDeleteCmd(getPart(), node)); + QPtrListIterator<Relation> it = node->dependChildNodes(); + for (; it.current(); ++it) { + cmd->addCommand(new DeleteRelationCmd(getPart(), it.current())); + } + it = node->dependParentNodes(); + for (; it.current(); ++it) { + cmd->addCommand(new DeleteRelationCmd(getPart(),it.current())); + } + getPart()->addCommand(cmd); +} + +void View::slotIndentTask() +{ + //kdDebug()<<k_funcinfo<<endl; + Node *node = currentTask(); + if (node == 0 || node->getParent() == 0) { + kdDebug()<<k_funcinfo<<(node ? "Task is main project" : "No current task")<<endl; + return; + } + if (getProject().canIndentTask(node)) { + NodeIndentCmd *cmd = new NodeIndentCmd(getPart(), *node, i18n("Indent Task")); + getPart()->addCommand(cmd); + } +} + +void View::slotUnindentTask() +{ + //kdDebug()<<k_funcinfo<<endl; + Node *node = currentTask(); + if (node == 0 || node->getParent() == 0) { + kdDebug()<<k_funcinfo<<(node ? "Task is main project" : "No current task")<<endl; + return; + } + if (getProject().canUnindentTask(node)) { + NodeUnindentCmd *cmd = new NodeUnindentCmd(getPart(), *node, i18n("Unindent Task")); + getPart()->addCommand(cmd); + } +} + +void View::slotMoveTaskUp() +{ + //kdDebug()<<k_funcinfo<<endl; + + Node* task = currentTask(); + if ( 0 == task ) { + // is always != 0. At least we would get the Project, but you never know who might change that + // so better be careful + kdError()<<k_funcinfo<<"No current task"<<endl; + return; + } + + if ( Node::Type_Project == task->type() ) { + kdDebug()<<k_funcinfo<<"The root node cannot be moved up"<<endl; + return; + } + if (getProject().canMoveTaskUp(task)) { + NodeMoveUpCmd *cmd = new NodeMoveUpCmd(getPart(), *task, i18n("Move Task Up")); + getPart()->addCommand(cmd); + } +} + +void View::slotMoveTaskDown() +{ + //kdDebug()<<k_funcinfo<<endl; + + Node* task = currentTask(); + if ( 0 == task ) { + // is always != 0. At least we would get the Project, but you never know who might change that + // so better be careful + return; + } + + if ( Node::Type_Project == task->type() ) { + kdDebug()<<k_funcinfo<<"The root node cannot be moved down"<<endl; + return; + } + if (getProject().canMoveTaskDown(task)) { + NodeMoveDownCmd *cmd = new NodeMoveDownCmd(getPart(), *task, i18n("Move Task Down")); + getPart()->addCommand(cmd); + } +} + +void View::slotAddRelation(Node *par, Node *child) { + //kdDebug()<<k_funcinfo<<endl; + Relation *rel = new Relation(par, child); + AddRelationDialog *dia = new AddRelationDialog(rel, this); + if (dia->exec()) { + KCommand *cmd = dia->buildCommand(getPart()); + if (cmd) + getPart()->addCommand(cmd); + } else { + delete rel; + } + delete dia; +} + +void View::slotAddRelation(Node *par, Node *child, int linkType) { + //kdDebug()<<k_funcinfo<<endl; + if (linkType == Relation::FinishStart || + linkType == Relation::StartStart || + linkType == Relation::FinishFinish) + { + Relation *rel = new Relation(par, child, static_cast<Relation::Type>(linkType)); + getPart()->addCommand(new AddRelationCmd(getPart(), rel, i18n("Add Relation"))); + } else { + slotAddRelation(par, child); + } +} + +void View::slotModifyRelation(Relation *rel) { + //kdDebug()<<k_funcinfo<<endl; + ModifyRelationDialog *dia = new ModifyRelationDialog(rel, this); + if (dia->exec()) { + if (dia->relationIsDeleted()) { + getPart()->addCommand(new DeleteRelationCmd(getPart(), rel, i18n("Delete Relation"))); + } else { + KCommand *cmd = dia->buildCommand(getPart()); + if (cmd) { + getPart()->addCommand(cmd); + } + } + } + delete dia; +} + +void View::slotModifyRelation(Relation *rel, int linkType) { + //kdDebug()<<k_funcinfo<<endl; + if (linkType == Relation::FinishStart || + linkType == Relation::StartStart || + linkType == Relation::FinishFinish) + { + getPart()->addCommand(new ModifyRelationTypeCmd(getPart(), rel, static_cast<Relation::Type>(linkType))); + } else { + slotModifyRelation(rel); + } +} + +// testing +void View::slotExportGantt() { + //kdDebug()<<k_funcinfo<<endl; + if (!m_ganttview) { + return; + } + QString fn = KFileDialog::getSaveFileName( QString::null, QString::null, this ); + if (!fn.isEmpty()) { + QFile f(fn); + m_ganttview->exportGantt(&f); + } +} + +void View::slotEditResource() { + //kdDebug()<<k_funcinfo<<endl; + Resource *r = m_resourceview->currentResource(); + if (!r) + return; + ResourceDialog *dia = new ResourceDialog(getProject(), r); + if (dia->exec()) { + KCommand *cmd = dia->buildCommand(getPart()); + if (cmd) + getPart()->addCommand(cmd); + } + delete dia; +} + +void View::updateReadWrite(bool /*readwrite*/) { +} + +Part *View::getPart()const { + return (Part *)koDocument(); +} + +void View::slotConnectNode() { + //kdDebug()<<k_funcinfo<<endl; +/* NodeItem *curr = m_ganttview->currentItem(); + if (curr) { + kdDebug()<<k_funcinfo<<"node="<<curr->getNode().name()<<endl; + }*/ +} + +QPopupMenu * View::popupMenu( const QString& name ) +{ + //kdDebug()<<k_funcinfo<<endl; + Q_ASSERT(factory()); + if ( factory() ) + return ((QPopupMenu*)factory()->container( name, this )); + return 0L; +} + +void View::slotChanged(QWidget *) +{ + //kdDebug()<<k_funcinfo<<endl; + slotUpdate(false); +} + +void View::slotChanged() +{ + //kdDebug()<<k_funcinfo<<endl; + slotUpdate(false); +} + +void View::slotUpdate(bool calculate) +{ + //kdDebug()<<k_funcinfo<<"calculate="<<calculate<<endl; + if (calculate) + projectCalculate(); + + m_updateGanttview = true; + m_updateResourceview = true; + m_updateAccountsview = true; + + updateView(m_tab->visibleWidget()); +} + +void View::slotAboutToShow(QWidget *widget) { + updateView(widget); +} + +void View::updateView(QWidget *widget) +{ + QApplication::setOverrideCursor(Qt::waitCursor); + setScheduleActionsEnabled(); + setTaskActionsEnabled(false); + mainWindow()->toolBar("report")->hide(); + if (widget == m_ganttview) + { + //kdDebug()<<k_funcinfo<<"draw gantt"<<endl; + m_ganttview->setShowExpected(actionViewExpected->isChecked()); + m_ganttview->setShowOptimistic(actionViewOptimistic->isChecked()); + m_ganttview->setShowPessimistic(actionViewPessimistic->isChecked()); + if (m_updateGanttview) + m_ganttview->drawChanges(getProject()); + setTaskActionsEnabled(widget, true); + m_updateGanttview = false; + } + else if (widget == m_pertview) + { + //kdDebug()<<k_funcinfo<<"draw pertview"<<endl; + m_pertview->draw(); + } + else if (widget == m_resourceview) + { + //kdDebug()<<k_funcinfo<<"draw resourceview"<<endl; + if (m_updateResourceview) + m_resourceview->draw(getPart()->getProject()); + m_updateResourceview = false; + } + else if (widget == m_accountsview) + { + //kdDebug()<<k_funcinfo<<"draw accountsview"<<endl; + if (m_updateAccountsview) + m_accountsview->draw(); + m_updateAccountsview = false; + } +/* else if (widget == m_reportview) + { + mainWindow()->toolBar("report")->show(); + m_reportview->enableNavigationBtn(); + }*/ + QApplication::restoreOverrideCursor(); +} + +void View::slotRenameNode(Node *node, const QString& name) { + //kdDebug()<<k_funcinfo<<name<<endl; + if (node) { + NodeModifyNameCmd *cmd = new NodeModifyNameCmd(getPart(), *node, name, i18n("Modify Name")); + getPart()->addCommand(cmd); + } +} + +void View::slotPopupMenu(const QString& menuname, const QPoint & pos) +{ + QPopupMenu* menu = this->popupMenu(menuname); + if (menu) + menu->exec(pos); +} + +bool View::setContext(Context &context) { + //kdDebug()<<k_funcinfo<<endl; + m_currentEstimateType = context.currentEstimateType; + getProject().setCurrentSchedule(context.currentSchedule); + actionViewExpected->setChecked(context.actionViewExpected); + actionViewOptimistic->setChecked(context.actionViewOptimistic); + actionViewPessimistic->setChecked(context.actionViewPessimistic); + + m_ganttview->setContext(context.ganttview, getProject()); + // hmmm, can't decide if these should be here or actions moved to ganttview + actionViewGanttResources->setChecked(context.ganttview.showResources); + actionViewGanttTaskName->setChecked(context.ganttview.showTaskName); + actionViewGanttTaskLinks->setChecked(context.ganttview.showTaskLinks); + actionViewGanttProgress->setChecked(context.ganttview.showProgress); + actionViewGanttFloat->setChecked(context.ganttview.showPositiveFloat); + actionViewGanttCriticalTasks->setChecked(context.ganttview.showCriticalTasks); + actionViewGanttCriticalPath->setChecked(context.ganttview.showCriticalPath); + + m_pertview->setContext(context.pertview); + m_resourceview->setContext(context.resourceview); + m_accountsview->setContext(context.accountsview); +// m_reportview->setContext(context.reportview); + + if (context.currentView == "ganttview") { + m_ganttview->setShowExpected(actionViewExpected->isChecked()); + m_ganttview->setShowOptimistic(actionViewOptimistic->isChecked()); + m_ganttview->setShowPessimistic(actionViewPessimistic->isChecked()); + slotViewGantt(); + } else if (context.currentView == "pertview") { + slotViewPert(); + } else if (context.currentView == "resourceview") { + slotViewResources(); + } else if (context.currentView == "accountsview") { + slotViewAccounts(); + } else if (context.currentView == "reportview") { + //slotViewReport(); + } else { + slotViewGantt(); + } + slotUpdate(false); + return true; +} + +void View::getContext(Context &context) const { + //kdDebug()<<k_funcinfo<<endl; + context.currentEstimateType = m_currentEstimateType; + if (getProject().currentSchedule()) + context.currentSchedule = getProject().currentSchedule()->id(); + context.actionViewExpected = actionViewExpected->isChecked(); + context.actionViewOptimistic = actionViewOptimistic->isChecked(); + context.actionViewPessimistic = actionViewPessimistic->isChecked(); + + if (m_tab->visibleWidget() == m_ganttview) { + context.currentView = "ganttview"; + } else if (m_tab->visibleWidget() == m_pertview) { + context.currentView = "pertview"; + } else if (m_tab->visibleWidget() == m_resourceview) { + context.currentView = "resourceview"; + } else if (m_tab->visibleWidget() == m_accountsview) { + context.currentView = "accountsview"; +/* } else if (m_tab->visibleWidget() == m_reportview) { + context.currentView = "reportview";*/ + } + m_ganttview->getContext(context.ganttview); + m_pertview->getContext(context.pertview); + m_resourceview->getContext(context.resourceview); + m_accountsview->getContext(context.accountsview); +// m_reportview->getContext(context.reportview); +} + +void View::setBaselineMode(bool /*on*/) { + //kdDebug()<<k_funcinfo<<endl; +/* m_baselineMode = on; + + m_ganttview->setReadWriteMode(!on); + + actionCut->setEnabled(!on); + actionCopy->setEnabled(!on); + actionPaste->setEnabled(!on); + + actionDeleteTask->setEnabled(!on); + actionIndentTask->setEnabled(!on); + actionUnindentTask->setEnabled(!on); + actionMoveTaskUp->setEnabled(!on); + actionMoveTaskDown->setEnabled(!on); + + actionAddTask->setEnabled(!on); + actionAddSubtask->setEnabled(!on); + actionAddMilestone->setEnabled(!on); + + actionEditStandardWorktime->setEnabled(!on); + actionEditCalendar->setEnabled(!on); + actionEditResources->setEnabled(!on); + actionCalculate->setEnabled(!on); + + actionEditResource->setEnabled(!on);*/ +} + +// called when widget w is about to be shown +void View::setTaskActionsEnabled(QWidget *w, bool on) { + Node *n = 0; + if (w == m_ganttview) { + n = m_ganttview->currentNode(); + }// else pert, etc when implemented + + actionAddTask->setEnabled(on); + actionAddMilestone->setEnabled(on); + // only enabled when we have a task selected + bool o = (on && n); + actionAddSubtask->setEnabled(o); + actionDeleteTask->setEnabled(o); + actionMoveTaskUp->setEnabled(o && getProject().canMoveTaskUp(n)); + actionMoveTaskDown->setEnabled(o && getProject().canMoveTaskDown(n)); + actionIndentTask->setEnabled(o && getProject().canIndentTask(n)); + actionUnindentTask->setEnabled(o && getProject().canUnindentTask(n)); +} + +void View::setTaskActionsEnabled(bool on) { + setTaskActionsEnabled(m_ganttview, on); //FIXME if more than ganttview can do this +} + +void View::setScheduleActionsEnabled() { + actionViewExpected->setEnabled(getProject().findSchedule(Schedule::Expected)); + actionViewOptimistic->setEnabled(getProject().findSchedule(Schedule::Optimistic)); + actionViewPessimistic->setEnabled(getProject().findSchedule(Schedule::Pessimistic)); + if (getProject().notScheduled()) { + m_estlabel->setText(i18n("Not scheduled")); + return; + } + Schedule *ns = getProject().currentSchedule(); + if (ns->type() == Schedule::Expected) { + actionViewExpected->setChecked(true); + m_estlabel->setText(i18n("Expected")); + } else if (ns->type() == Schedule::Optimistic) { + actionViewOptimistic->setChecked(true); + m_estlabel->setText(i18n("Optimistic")); + } else if (ns->type() == Schedule::Pessimistic) { + actionViewPessimistic->setChecked(true); + m_estlabel->setText(i18n("Pessimistic")); + } +} + + +#ifndef NDEBUG +void View::slotPrintDebug() { + kdDebug()<<"-------- Debug printout: Node list" <<endl; +/* Node *curr = m_ganttview->currentNode(); + if (curr) { + curr->printDebug(true,""); + } else*/ + getPart()->getProject().printDebug(true, ""); +} +void View::slotPrintSelectedDebug() { + Node *curr = m_ganttview->currentNode(); + if (curr) { + kdDebug()<<"-------- Debug printout: Selected node" <<endl; + curr->printDebug(true,""); + } else + slotPrintDebug(); +} +void View::slotPrintCalendarDebug() { + kdDebug()<<"-------- Debug printout: Node list" <<endl; +/* Node *curr = m_ganttview->currentNode(); + if (curr) { + curr->printDebug(true,""); + } else*/ + getPart()->getProject().printCalendarDebug(""); +} +void View::slotPrintTestDebug() { + const QStringList &lst = getPart()->xmlLoader().log(); + + for ( QStringList::ConstIterator it = lst.constBegin(); it != lst.constEnd(); ++it ) { + kdDebug()<<*it<<endl; + } +// kdDebug()<<"------------Test 1---------------------"<<endl; +// { +// DateTime d1(QDate(2006,1,2), QTime(8,0,0)); +// DateTime d2 = d1.addSecs(3600); +// Duration d = d2 - d1; +// bool b = d==Duration(0,0,0,3600); +// kdDebug()<<"1: Success="<<b<<" "<<d2.toString()<<"-"<<d1.toString()<<"="<<d.toString()<<endl; +// d = d1 - d2; +// b = d==Duration(0,0,0,3600); +// kdDebug()<<"2: Success="<<b<<" "<<d1.toString()<<"-"<<d2.toString()<<"="<<d.toString()<<endl; +// d2 = d2.addDays(-2); +// d = d1 - d2; +// b = d==Duration(2,0,0)-Duration(0,0,0,3600); +// kdDebug()<<"3: Success="<<b<<" "<<d1.toString()<<"-"<<d2.toString()<<"="<<d.toString()<<endl; +// d = d2 - d1; +// b = d==Duration(2,0,0)-Duration(0,0,0,3600); +// kdDebug()<<"4: Success="<<b<<" "<<d2.toString()<<"-"<<d1.toString()<<"="<<d.toString()<<endl; +// kdDebug()<<endl; +// b = (d2 + d)==d1; +// kdDebug()<<"5: Success="<<b<<" "<<d2<<"+"<<d.toString()<<"="<<d1<<endl; +// b = (d1 - d)==d2; +// kdDebug()<<"6: Success="<<b<<" "<<d1<<"-"<<d.toString()<<"="<<d2<<endl; +// } // end test 1 +// kdDebug()<<endl; +// kdDebug()<<"------------Test 2 Single calendar-----------------"<<endl; +// { +// Calendar *t = new Calendar("Test 2"); +// QDate wdate(2006,1,2); +// DateTime before = DateTime(wdate.addDays(-1)); +// DateTime after = DateTime(wdate.addDays(1)); +// QTime t1(8,0,0); +// QTime t2(10,0,0); +// DateTime wdt1(wdate, t1); +// DateTime wdt2(wdate, t2); +// CalendarDay *day = new CalendarDay(QDate(2006,1,2), Map::Working); +// day->addInterval(QPair<QTime, QTime>(t1, t2)); +// if (!t->addDay(day)) { +// kdDebug()<<"Failed to add day"<<endl; +// delete day; +// delete t; +// return; +// } +// kdDebug()<<"Added date="<<day->date().toString()<<" "<<day->startOfDay().toString()<<" - "<<day->endOfDay()<<endl; +// kdDebug()<<"Found date="<<day->date().toString()<<" "<<day->startOfDay().toString()<<" - "<<day->endOfDay()<<endl; +// +// CalendarDay *d = t->findDay(wdate); +// bool b = (day == d); +// kdDebug()<<"1: Success="<<b<<" Find same day"<<endl; +// +// DateTime dt = t->firstAvailableAfter(after, after.addDays(10)); +// b = !dt.isValid(); +// kdDebug()<<"2: Success="<<b<<" firstAvailableAfter("<<after<<"): ="<<dt<<endl; +// +// dt = t->firstAvailableBefore(before, before.addDays(-10)); +// b = !dt.isValid(); +// kdDebug()<<"3: Success="<<b<<" firstAvailableBefore("<<before.toString()<<"): ="<<dt<<endl; +// +// dt = t->firstAvailableAfter(before, after); +// b = dt == wdt1; +// kdDebug()<<"4: Success="<<b<<" firstAvailableAfter("<<before<<"): ="<<dt<<endl; +// +// dt = t->firstAvailableBefore(after, before); +// b = dt == wdt2; +// kdDebug()<<"5: Success="<<b<<" firstAvailableBefore("<<after<<"): ="<<dt<<endl; +// +// b = t->hasInterval(before, after); +// kdDebug()<<"6: Success="<<b<<" hasInterval("<<before<<", "<<after<<")"<<endl; +// +// b = !t->hasInterval(after, after.addDays(1)); +// kdDebug()<<"7: Success="<<b<<" !hasInterval("<<after<<", "<<after.addDays(1)<<")"<<endl; +// +// b = !t->hasInterval(before, before.addDays(-1)); +// kdDebug()<<"8: Success="<<b<<" !hasInterval("<<before<<", "<<before.addDays(-1)<<")"<<endl; +// +// Duration e1(0, 2, 0); // 2 hours +// Duration e2 = t->effort(before, after); +// b = e1==e2; +// kdDebug()<<"9: Success="<<b<<" effort"<<e1.toString()<<" = "<<e2.toString()<<endl; +// +// delete t; +// }// end test 2 +// +// kdDebug()<<endl; +// kdDebug()<<"------------Test 3 Parent calendar-----------------"<<endl; +// { +// Calendar *t = new Calendar("Test 3"); +// Calendar *p = new Calendar("Test 3 parent"); +// t->setParent(p); +// QDate wdate(2006,1,2); +// DateTime before = DateTime(wdate.addDays(-1)); +// DateTime after = DateTime(wdate.addDays(1)); +// QTime t1(8,0,0); +// QTime t2(10,0,0); +// DateTime wdt1(wdate, t1); +// DateTime wdt2(wdate, t2); +// CalendarDay *day = new CalendarDay(QDate(2006,1,2), Map::Working); +// day->addInterval(QPair<QTime, QTime>(t1, t2)); +// if (!p->addDay(day)) { +// kdDebug()<<"Failed to add day"<<endl; +// delete day; +// delete t; +// return; +// } +// kdDebug()<<"Added date="<<day->date().toString()<<" "<<day->startOfDay().toString()<<" - "<<day->endOfDay().toString()<<endl; +// kdDebug()<<"Found date="<<day->date().toString()<<" "<<day->startOfDay().toString()<<" - "<<day->endOfDay().toString()<<endl; +// +// CalendarDay *d = p->findDay(wdate); +// bool b = (day == d); +// kdDebug()<<"1: Success="<<b<<" Find same day"<<endl; +// +// DateTime dt = t->firstAvailableAfter(after, after.addDays(10)); +// b = !dt.isValid(); +// kdDebug()<<"2: Success="<<b<<" firstAvailableAfter("<<after.toString()<<"): ="<<!b<<endl; +// +// dt = t->firstAvailableBefore(before, before.addDays(-10)); +// b = !dt.isValid(); +// kdDebug()<<"3: Success="<<b<<" firstAvailableBefore("<<before.toString()<<"): ="<<!b<<endl; +// +// dt = t->firstAvailableAfter(before, after); +// b = dt == wdt1; +// kdDebug()<<"4: Success="<<b<<" firstAvailableAfter("<<before.toString()<<"): ="<<dt.toString()<<endl; +// +// dt = t->firstAvailableBefore(after, before); +// b = dt == wdt2; +// kdDebug()<<"5: Success="<<b<<" firstAvailableBefore("<<after.toString()<<"): ="<<dt.toString()<<endl; +// +// b = t->hasInterval(before, after); +// kdDebug()<<"6: Success="<<b<<" hasInterval("<<before.toString()<<", "<<after<<")"<<endl; +// +// b = !t->hasInterval(after, after.addDays(1)); +// kdDebug()<<"7: Success="<<b<<" !hasInterval("<<after.toString()<<", "<<after.addDays(1)<<")"<<endl; +// +// b = !t->hasInterval(before, before.addDays(-1)); +// kdDebug()<<"8: Success="<<b<<" !hasInterval("<<before.toString()<<", "<<before.addDays(-1)<<")"<<endl; +// Duration e1(0, 2, 0); // 2 hours +// Duration e2 = t->effort(before, after); +// b = e1==e2; +// kdDebug()<<"9: Success="<<b<<" effort "<<e1.toString()<<"=="<<e2.toString()<<endl; +// +// delete t; +// delete p; +// }// end test 3 +// kdDebug()<<endl; +// kdDebug()<<"------------Test 4 Parent calendar/weekdays-------------"<<endl; +// { +// QTime t1(8,0,0); +// QTime t2(10,0,0); +// Calendar *p = new Calendar("Test 4 parent"); +// CalendarDay *wd1 = p->weekday(0); // monday +// if (wd1 == 0) { +// kdDebug()<<"Failed to get weekday"<<endl; +// } +// wd1->setState(Map::NonWorking); +// +// CalendarDay *wd2 = p->weekday(2); // wednesday +// if (wd2 == 0) { +// kdDebug()<<"Failed to get weekday"<<endl; +// } +// wd2->addInterval(QPair<QTime, QTime>(t1, t2)); +// wd2->setState(Map::Working); +// +// Calendar *t = new Calendar("Test 4"); +// t->setParent(p); +// QDate wdate(2006,1,2); // monday jan 2 +// DateTime before = DateTime(wdate.addDays(-4)); //Thursday dec 29 +// DateTime after = DateTime(wdate.addDays(4)); // Friday jan 6 +// DateTime wdt1(wdate, t1); +// DateTime wdt2(QDate(2006, 1, 4), t2); // Wednesday +// CalendarDay *day = new CalendarDay(QDate(2006,1,2), Map::Working); +// day->addInterval(QPair<QTime, QTime>(t1, t2)); +// if (!p->addDay(day)) { +// kdDebug()<<"Failed to add day"<<endl; +// delete day; +// delete t; +// return; +// } +// kdDebug()<<"Added date="<<day->date().toString()<<" "<<day->startOfDay().toString()<<" - "<<day->endOfDay().toString()<<endl; +// kdDebug()<<"Found date="<<day->date().toString()<<" "<<day->startOfDay().toString()<<" - "<<day->endOfDay().toString()<<endl; +// +// CalendarDay *d = p->findDay(wdate); +// bool b = (day == d); +// kdDebug()<<"1: Success="<<b<<" Find same day"<<endl; +// +// DateTime dt = t->firstAvailableAfter(after, after.addDays(10)); +// b = (dt.isValid() && dt == DateTime(QDate(2006,1,11), t1)); +// kdDebug()<<"2: Success="<<b<<" firstAvailableAfter("<<after<<"): ="<<dt<<endl; +// +// dt = t->firstAvailableBefore(before, before.addDays(-10)); +// b = (dt.isValid() && dt == DateTime(QDate(2005, 12, 28), t2)); +// kdDebug()<<"3: Success="<<b<<" firstAvailableBefore("<<before.toString()<<"): ="<<dt<<endl; +// +// dt = t->firstAvailableAfter(before, after); +// b = dt == wdt1; // We find the day jan 2 +// kdDebug()<<"4: Success="<<b<<" firstAvailableAfter("<<before.toString()<<"): ="<<dt.toString()<<endl; +// +// dt = t->firstAvailableBefore(after, before); +// b = dt == wdt2; // We find the weekday (wednesday) +// kdDebug()<<"5: Success="<<b<<" firstAvailableBefore("<<after.toString()<<"): ="<<dt.toString()<<endl; +// +// b = t->hasInterval(before, after); +// kdDebug()<<"6: Success="<<b<<" hasInterval("<<before.toString()<<", "<<after<<")"<<endl; +// +// b = !t->hasInterval(after, after.addDays(1)); +// kdDebug()<<"7: Success="<<b<<" !hasInterval("<<after.toString()<<", "<<after.addDays(1)<<")"<<endl; +// +// b = !t->hasInterval(before, before.addDays(-1)); +// kdDebug()<<"8: Success="<<b<<" !hasInterval("<<before.toString()<<", "<<before.addDays(-1)<<")"<<endl; +// Duration e1(0, 4, 0); // 2 hours +// Duration e2 = t->effort(before, after); +// b = e1==e2; +// kdDebug()<<"9: Success="<<b<<" effort "<<e1.toString()<<"="<<e2.toString()<<endl; +// +// QPair<DateTime, DateTime> r = t->firstInterval(before, after); +// b = r.first == wdt1; // We find the monday jan 2 +// kdDebug()<<"10: Success="<<b<<" firstInterval("<<before<<"): ="<<r.first<<", "<<r.second<<endl; +// r = t->firstInterval(r.second, after); +// b = r.first == DateTime(QDate(2006, 1, 4),t1); // We find the wednesday jan 4 +// kdDebug()<<"11: Success="<<b<<" firstInterval("<<r.second<<"): ="<<r.first<<", "<<r.second<<endl; +// +// delete t; +// delete p; +// }// end test 4 +} +#endif + +} //KPlato namespace + +#include "kptview.moc" |