From 07177b1aa8b5c6979fe06874da903a9d17debb65 Mon Sep 17 00:00:00 2001 From: harlekin Date: Mon, 11 Mar 2002 15:05:28 +0000 Subject: some new features like clickable appointments, but not connected to datebook yet --- (limited to 'core/pim') diff --git a/core/pim/today/TODO b/core/pim/today/TODO index 5876e2b..a3b01d2 100644 --- a/core/pim/today/TODO +++ b/core/pim/today/TODO @@ -1,13 +1,14 @@ TODO for today: -* start the app on "resume" +* start the app on "resume" (partly done) -* show alarm icons on alarm events +* show alarm icons on alarm events (partly done) * add am/pm mode instead of 24 h, take system default -* fix 23 pm bug (done??) - * qcop integration for updating events? -* sort todos by pri. \ No newline at end of file +* sort todos by pri. + +* make Opiezilla a clickable label wich is allway on the far right side of +the screen , klick will open credits ,) \ No newline at end of file diff --git a/core/pim/today/changelog b/core/pim/today/changelog index 7111154..333326d 100644 --- a/core/pim/today/changelog +++ b/core/pim/today/changelog @@ -1,3 +1,7 @@ + +* Appointments are now clickable (connection to datebook still missing) +* autostart support (opie only) + 0.2.7 * check if todolist.xml was changed before parsing it diff --git a/core/pim/today/today.cpp b/core/pim/today/today.cpp index d715fc1..69bcb68 100644 --- a/core/pim/today/today.cpp +++ b/core/pim/today/today.cpp @@ -39,12 +39,14 @@ #include #include #include +#include //#include //#include #include + int MAX_LINES_TASK; int MAX_CHAR_CLIP; int MAX_LINES_MEET; @@ -53,6 +55,8 @@ int SHOW_NOTES; // show only later dates int ONLY_LATER; int AUTOSTART; + +int NEW_START=1; /* * Constructs a Example which is a child of 'parent', with the * name 'name' and widget flags set to 'f' @@ -69,7 +73,6 @@ Today::Today( QWidget* parent, const char* name, WFlags fl ) draw(); } - void Today::autoStart() { Config cfg("today"); cfg.setGroup("Autostart"); @@ -203,7 +206,10 @@ void Today::startConfig() { */ void Today::getDates() { QDate date = QDate::currentDate(); - QTime time = QTime::currentTime(); + QWidget* AllDateBookEvents = new QWidget( ); + QVBoxLayout* layoutDates = new QVBoxLayout(AllDateBookEvents); + //QTime time = QTime::currentTime(); + QValueList list = db->getEffectiveEvents(date, date); Config config( "qpe" ); @@ -221,68 +227,25 @@ void Today::getDates() { count++; if ( count <= MAX_LINES_MEET ) { - //cout << time.toString() << endl; - //cout << TimeString::dateString((*it).event().end()) << endl; - - // decide if to get all day or only later appointments - if (!ONLY_LATER) { - msg += "" + (*it).description() + ""; - if ( (*it).event().hasAlarm() ) { - msg += " [with alarm]"; - } - // include location or not - if (SHOW_LOCATION == 1) { - msg += "
" + (*it).location(); - msg += ""; - } - - if ( (TimeString::timeString(QTime((*it).event().start().time()) ) == "00:00") && (TimeString::timeString(QTime((*it).event().end().time()) ) == "23:59") ) { - msg += "
All day"; - } else { - // start time of event - msg += "
" + TimeString::timeString(QTime((*it).event().start().time()) ) - // end time of event - + " - " + TimeString::timeString(QTime((*it).event().end().time()) ); - } - msg += "
"; - // include possible note or not - if (SHOW_NOTES == 1) { - msg += " note:" +((*it).notes()).mid(0, MAX_CHAR_CLIP) + "
"; - } - } else if ((time.toString() <= TimeString::dateString((*it).event().end())) ) { - msg += "" + (*it).description() + ""; - if ( (*it).event().hasAlarm() ) { - msg += " [with alarm]"; - } - // include location or not - if (SHOW_LOCATION == 1) { - msg+= "
" + (*it).location(); - msg += ""; - } - - if ( (TimeString::timeString(QTime((*it).event().start().time()) ) == "00:00") && (TimeString::timeString(QTime((*it).event().end().time()) ) == "23:59") ) { - msg += "
All day"; - } else { - // start time of event - msg += "
" + TimeString::timeString(QTime((*it).event().start().time()) ) - // end time of event - + " - " + TimeString::timeString(QTime((*it).event().end().time()) ); - } - msg += "
"; - // include possible note or not - if (SHOW_NOTES == 1) { - msg += " note:" +((*it).notes()).mid(0, MAX_CHAR_CLIP) + "
"; - } - } + + + DateBookEvent *l=new DateBookEvent(*it, AllDateBookEvents); + layoutDates->addWidget(l); + connect (l, SIGNAL(editEvent(const Event &)), + this, SIGNAL(editEvent(const Event &))); } - } - if (msg.isEmpty()) { - msg = tr("No more appointments today"); - } - DatesField->setText(msg); + + } + layoutDates->addItem(new QSpacerItem(1,1, QSizePolicy::Minimum, QSizePolicy::Expanding)); + sv1->addChild(AllDateBookEvents); + + //if (msg.isEmpty()) { + // msg = tr("No more appointments today"); + //} + //DatesField->setText(msg); } } - + /* * Parse in the todolist.xml */ @@ -371,9 +334,10 @@ void Today::getMail() { void Today::getTodo() { // if the todolist.xml file was not modified in between, do not parse it. - if (!checkIfModified()) { + if (!checkIfModified() && !NEW_START) { return; } + NEW_START=0; QString output; QString tmpout; @@ -441,3 +405,74 @@ void Today::startMail() { Today::~Today() { // no need to delete child widgets, Qt does it all for us } + + +DateBookEvent::DateBookEvent(const EffectiveEvent &ev, + QWidget* parent = 0, + const char* name = 0, + WFlags fl = 0) : + ClickableLabel(parent,name,fl), event(ev) { + + QString msg; + QTime time = QTime::currentTime(); + + if (!ONLY_LATER) { + msg += "" + (ev).description() + ""; + if ( (ev).event().hasAlarm() ) { + msg += " [with alarm]"; + } + // include location or not + if (SHOW_LOCATION == 1) { + msg += "
" + (ev).location(); + msg += ""; + } + + if ( (TimeString::timeString(QTime((ev).event().start().time()) ) == "00:00") && (TimeString::timeString(QTime((ev).event().end().time()) ) == "23:59") ) { + msg += "
All day"; + } else { + // start time of event + msg += "
" + TimeString::timeString(QTime((ev).event().start().time()) ) + // end time of event + + " - " + TimeString::timeString(QTime((ev).event().end().time()) ); + } + msg += "
"; + // include possible note or not + if (SHOW_NOTES == 1) { + msg += " note:" +((ev).notes()).mid(0, MAX_CHAR_CLIP) + "
"; + } + } else if ((time.toString() <= TimeString::dateString((ev).event().end())) ) { + msg += "" + (ev).description() + ""; + if ( (ev).event().hasAlarm() ) { + msg += " [with alarm]"; + } + // include location or not + if (SHOW_LOCATION == 1) { + msg+= "
" + (ev).location(); + msg += ""; + } + + if ( (TimeString::timeString(QTime((ev).event().start().time()) ) == "00:00") && (TimeString::timeString(QTime((ev).event().end().time()) ) == "23:59") ) { + msg += "
All day"; + } else { + // start time of event + msg += "
" + TimeString::timeString(QTime((ev).event().start().time()) ) + // end time of event + + " - " + TimeString::timeString(QTime((ev).event().end().time()) ); + } + // include possible note or not + if (SHOW_NOTES == 1) { + msg += "
note:" +((ev).notes()).mid(0, MAX_CHAR_CLIP) + "
"; + } + } + + setText(msg); + connect(this, SIGNAL(clicked()), this, SLOT(editMe())); + setAlignment( int( QLabel::WordBreak | QLabel::AlignLeft ) ); +} + +void DateBookEvent::editMe() { + emit editEvent(event.event()); +} + + + diff --git a/core/pim/today/today.h b/core/pim/today/today.h index b3b7d01..0a0837c 100644 --- a/core/pim/today/today.h +++ b/core/pim/today/today.h @@ -20,17 +20,21 @@ #ifndef TODAY_H #define TODAY_H -#include "todaybase.h" #include +#include #include #include + #include "TodoItem.h" #include "todayconfig.h" +#include "todaybase.h" +#include "clickablelabel.h" + +class QVBoxLayout; -class Today : public TodayBase -{ +class Today : public TodayBase { Q_OBJECT public: @@ -61,5 +65,20 @@ class Today : public TodayBase int SHOW_LOCATION; int SHOW_NOTES; }; + +class DateBookEvent: public ClickableLabel { + Q_OBJECT +public: + DateBookEvent(const EffectiveEvent &ev, + QWidget* parent = 0, const char* name = 0, + WFlags fl = 0); +signals: + void editEvent(const Event &e); +private slots: + void editMe(); +private: + const EffectiveEvent event; +}; + #endif // TODAY_H diff --git a/core/pim/today/today.pro b/core/pim/today/today.pro index 7d56e71..454b3ff 100644 --- a/core/pim/today/today.pro +++ b/core/pim/today/today.pro @@ -1,8 +1,9 @@ TEMPLATE = app #CONFIG = qt warn_on debug CONFIG = qt warn_on release -HEADERS = today.h TodoItem.h minidom.h todaybase.h todayconfig.h -SOURCES = main.cpp today.cpp todaybase.cpp todayconfig.cpp minidom.c TodoItem.cpp +HEADERS = today.h TodoItem.h minidom.h todaybase.h todayconfig.h clickablelabel.h +SOURCES = main.cpp today.cpp todaybase.cpp todayconfig.cpp minidom.c TodoItem.cpp clickablelabel.cpp + INCLUDEPATH += $(OPIEDIR)/include DEPENDPATH += $(OPIEDIR)/include LIBS += -lqpe diff --git a/core/pim/today/todaybase.cpp b/core/pim/today/todaybase.cpp index 5c1dc24..552e2eb 100644 --- a/core/pim/today/todaybase.cpp +++ b/core/pim/today/todaybase.cpp @@ -51,6 +51,7 @@ TodayBase::TodayBase( QWidget* parent, const char* name, WFlags fl ) pal.setColor(QPalette::Active, QColorGroup::Button, col); this->setPalette(pal); + QWidget *d = QApplication::desktop(); int w=d->width(); int h=d->height(); @@ -95,7 +96,8 @@ TodayBase::TodayBase( QWidget* parent, const char* name, WFlags fl ) Frame4->setFrameStyle( QFrame::NoFrame ); Frame4->setGeometry (QRect( 0, 0, this->width() , this->height()) ); - QScrollView* sv1 = new QScrollView( Frame4 ); + // QScrollView* sv1 = new QScrollView( Frame4 ); + sv1 = new QScrollView( Frame4 ); sv1->setResizePolicy(QScrollView::AutoOneFit); sv1->setHScrollBarMode( QScrollView::AlwaysOff ); // need to find a better way!!! @@ -109,13 +111,15 @@ TodayBase::TodayBase( QWidget* parent, const char* name, WFlags fl ) DatesButton->setPixmap( datebook ); DatesButton->setFlat( TRUE ); - DatesField = new QLabel( sv1->viewport(), "DatesField" ); - sv1->addChild(DatesField); - DatesField->setText( tr( "No appointments today" ) ); - DatesField->setAlignment( int( QLabel::AlignTop | QLabel::AlignLeft ) ); + //DatesField = new QLabel( sv1->viewport(), "DatesField" ); + //DatesField = new QVBox(sv1->viewport()); + //QWidget *dummy = new QWidget(sv1->viewport()); + //sv1->addChild(DatesField); + //DatesField->setText( tr( "No appointments today" ) ); + // DatesField->setAlignment( int( QLabel::AlignTop | QLabel::AlignLeft ) ); - // --- mail section --- + // --- mail section ---) MailFrame = new QFrame( this ,"MailFrame" ); MailFrame->setBackgroundOrigin( QScrollView::ParentOrigin ); MailFrame->setGeometry (QRect( 0, 0, this->width() , 15) ); diff --git a/core/pim/today/todaybase.h b/core/pim/today/todaybase.h index 13fbb8d..8840125 100644 --- a/core/pim/today/todaybase.h +++ b/core/pim/today/todaybase.h @@ -14,7 +14,7 @@ #include #include -class QVBoxLayout; +class QVBox; class QHBoxLayout; class QGridLayout; class QFrame; @@ -32,10 +32,12 @@ public: //QScrollView* Frame4; QFrame* Frame4; QPushButton* DatesButton; - QLabel* DatesField; + //QLabel* DatesField; QLabel* Frame; QFrame* MailFrame; QLabel* TextLabel1; + QScrollView* sv1; + QVBox* DatesField; QFrame* Frame15; QLabel* TodoField; QLabel* MailField; diff --git a/core/pim/today/todayconfig.h b/core/pim/today/todayconfig.h index 020097d..4739b5a 100644 --- a/core/pim/today/todayconfig.h +++ b/core/pim/today/todayconfig.h @@ -11,7 +11,7 @@ #include #include -class QVBoxLayout; +//class QVBoxLayout; class QHBoxLayout; class QGridLayout; class QCheckBox; -- cgit v0.9.0.2