summaryrefslogtreecommitdiff
authorharlekin <harlekin>2002-02-16 19:59:21 (UTC)
committer harlekin <harlekin>2002-02-16 19:59:21 (UTC)
commit4e6ec847f469a3669be864db69dee0d8b0e4a93b (patch) (side-by-side diff)
treedb92798a54f2eca93aa71fcf4d9aab3d116f0c5e
parentbe1704ffdb21c6d304ba36bfd5ef1f5db622baea (diff)
downloadopie-4e6ec847f469a3669be864db69dee0d8b0e4a93b.zip
opie-4e6ec847f469a3669be864db69dee0d8b0e4a93b.tar.gz
opie-4e6ec847f469a3669be864db69dee0d8b0e4a93b.tar.bz2
new features: auto update and opiemail support
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--core/pim/today/changelog8
-rw-r--r--core/pim/today/opie-today.control4
-rw-r--r--core/pim/today/today.cpp46
-rw-r--r--core/pim/today/today.h4
-rw-r--r--core/pim/today/todaybase.cpp40
-rw-r--r--core/pim/today/todaybase.h4
6 files changed, 87 insertions, 19 deletions
diff --git a/core/pim/today/changelog b/core/pim/today/changelog
index 96a4163..dd4cfc1 100644
--- a/core/pim/today/changelog
+++ b/core/pim/today/changelog
@@ -1,16 +1,24 @@
+0.2.4
+
+* added support for email
+* autoupdates after 1 min
+* QCopEnvelope instead of system()
+* starting to use qvbox in gui
+
+
0.2.3
* the 4 am release
* several bugfixes
0.2.2
* started working on calling other apps
* and finished it
0.2.1
* images no more inline
* config dialog
diff --git a/core/pim/today/opie-today.control b/core/pim/today/opie-today.control
index 515632b..3362a54 100644
--- a/core/pim/today/opie-today.control
+++ b/core/pim/today/opie-today.control
@@ -1,10 +1,10 @@
-Files: bin/today apps/Applications/today.desktop pics/today_icon.png pics/today/today_logo.png pics/today/config.png
+Files: bin/today apps/Applications/today.desktop pics/today_icon.png pics/today/today_logo.png pics/today/config.png pics/today/mail.png
Priority: optional
Section: opie/applications
Maintainer: Maximilian Reiß <max.reiss@gmx.de>
Architecture: arm
-Version: 0.2.3
+Version: 0.2.4
Depends: opie-base ($QPE_VERSION)
License: GPL
Description: today screen
A short overview over current appointments and tasks.
diff --git a/core/pim/today/today.cpp b/core/pim/today/today.cpp
index 00a8842..eb8b50c 100644
--- a/core/pim/today/today.cpp
+++ b/core/pim/today/today.cpp
@@ -22,65 +22,75 @@
#include "TodoItem.h"
#include <qpe/datebookdb.h>
#include <qpe/timestring.h>
#include <qpe/config.h>
#include <qpe/qcopenvelope_qws.h>
#include <qpe/qprocess.h>
#include <qdir.h>
#include <qfile.h>
#include <qdatetime.h>
#include <qtextstream.h>
#include <qcheckbox.h>
#include <qspinbox.h>
#include <qpushbutton.h>
#include <qlabel.h>
+#include <qtimer.h>
//#include <iostream.h>
//#include <unistd.h>
#include <stdlib.h>
int MAX_LINES_TASK;
int MAX_CHAR_CLIP;
int MAX_LINES_MEET;
int SHOW_LOCATION;
int SHOW_NOTES;
// show only later dates
int ONLY_LATER = 1;
/*
* Constructs a Example which is a child of 'parent', with the
* name 'name' and widget flags set to 'f'
*/
Today::Today( QWidget* parent, const char* name, WFlags fl )
: TodayBase( parent, name, fl )
{
QObject::connect( (QObject*)PushButton1, SIGNAL( clicked() ), this, SLOT(startConfig() ) );
QObject::connect( (QObject*)TodoButton, SIGNAL( clicked() ), this, SLOT(startTodo() ) );
QObject::connect( (QObject*)DatesButton, SIGNAL( clicked() ), this, SLOT(startDatebook() ) );
+ QObject::connect( (QObject*)DatesButton, SIGNAL( clicked() ), this, SLOT(startMail() ) );
QDate date = QDate::currentDate();
QString time = (date.toString());
TextLabel1->setText(time);
db = new DateBookDB;
+ draw();
+}
+
+
+void Today::draw()
+{
init();
getDates();
+ getMail();
getTodo();
-}
+ QTimer::singleShot( 60*1000, this, SLOT(draw()) );
+}
void Today::init()
{
// read config
Config cfg("today");
cfg.setGroup("BaseConfig");
// how many lines should be showed in the task section
MAX_LINES_TASK = cfg.readNumEntry("maxlinestask",5);
// after how many chars should the be cut off on tasks and notes
MAX_CHAR_CLIP = cfg.readNumEntry("maxcharclip",30);
// how many lines should be showed in the datebook section
MAX_LINES_MEET = cfg.readNumEntry("maxlinesmeet",5);
// If location is to be showed too, 1 to activate it.
SHOW_LOCATION = cfg.readNumEntry("showlocation",1);
// if notes should be shown
@@ -113,36 +123,33 @@ void Today::startConfig()
conf->exec();
int maxlinestask = conf->SpinBox2->value();
int maxmeet = conf->SpinBox1->value();
int location = conf->CheckBox1->isChecked();
int notes = conf->CheckBox2->isChecked();
int maxcharclip = conf->SpinBox7->value();
cfg.writeEntry("maxlinestask",maxlinestask);
cfg.writeEntry("maxcharclip", maxcharclip);
cfg.writeEntry("maxlinesmeet",maxmeet);
cfg.writeEntry("showlocation",location);
cfg.writeEntry("shownotes", notes);
// sync it to "disk"
cfg.write();
- init();
- getDates();
- getTodo();
- //cout << location << endl;
+ draw();
}
/*
* Get all events that are in the datebook xml file for today
*/
void Today::getDates()
{
QDate date = QDate::currentDate();
QTime time = QTime::currentTime();
QValueList<EffectiveEvent> list = db->getEffectiveEvents(date, date);
Config config( "qpe" );
// if 24 h format
// bool ampm = config.readBoolEntry( "AMPM", TRUE );
@@ -249,32 +256,48 @@ QList<TodoItem> Today::loadTodo(const char *filename)
}
if(description)
{
tmp = new TodoItem(description, completed, priority);
loadtodolist.append(tmp);
}
i++;
}
}
minidom_free(todo);
return loadtodolist;
}
+void Today::getMail()
+{
+ Config cfg("opiemail");
+ cfg.setGroup("today");
+
+ // how many lines should be showed in the task section
+ int NEW_MAILS = cfg.readNumEntry("newmails",0);
+ int OUTGOING = cfg.readNumEntry("outgoing",0);
+
+ QString output = tr("<b>%1</b> new mails, <b>%2</b> outgoing").arg(NEW_MAILS).arg(OUTGOING);
+
+
+ MailField->setText(output);
+}
+
+
/*
* Get the todos
*
*/
void Today::getTodo()
{
QString output;
QString tmpout;
int count = 0;
QDir dir;
QString homedir = dir.homeDirPath ();
// see if todolist.xml does exist.
QFile f(homedir +"/Applications/todolist/todolist.xml");
if ( f.exists() )
{
@@ -295,40 +318,49 @@ void Today::getTodo()
}
if (count > 0)
{
output = QString("There are <b> %1</b> active tasks: <br>").arg(count);
output += tmpout;
}
else
{
output = ("No active tasks");
}
TodoField->setText(output);
}
/*
- * lanches datebook
+ * launches datebook
*/
void Today::startDatebook()
{
QCopEnvelope e("QPE/System", "execute(QString)");
e << QString("datebook");
}
/*
- * lanches todolist
+ * launches todolist
*/
void Today::startTodo()
{
QCopEnvelope e("QPE/System", "execute(QString)");
e << QString("todolist");
}
/*
+ * launch opiemail
+ */
+void Today::startMail()
+{
+ QCopEnvelope e("QPE/System", "execute(QString)");
+ e << QString("opiemail");
+}
+
+/*
* Destroys the object and frees any allocated resources
*/
Today::~Today()
{
// no need to delete child widgets, Qt does it all for us
}
diff --git a/core/pim/today/today.h b/core/pim/today/today.h
index 50a10f1..6b8c0bf 100644
--- a/core/pim/today/today.h
+++ b/core/pim/today/today.h
@@ -28,34 +28,36 @@
#include <qlist.h>
#include "TodoItem.h"
#include "todayconfig.h"
class Today : public TodayBase
{
Q_OBJECT
public:
Today( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
~Today();
private slots:
void startConfig();
void startTodo();
void startDatebook();
-
+ void startMail();
+ void draw();
private:
void init();
void getDates();
void getTodo();
+ void getMail();
QList<TodoItem> loadTodo(const char *filename);
private:
DateBookDB *db;
todayconfig *conf;
//Config cfg;
int MAX_LINES_TASK;
int MAX_CHAR_CLIP;
int MAX_LINES_MEET;
int SHOW_LOCATION;
int SHOW_NOTES;
};
#endif // TODAY_H
diff --git a/core/pim/today/todaybase.cpp b/core/pim/today/todaybase.cpp
index b60c915..9331ee3 100644
--- a/core/pim/today/todaybase.cpp
+++ b/core/pim/today/todaybase.cpp
@@ -33,56 +33,59 @@
/*
* Constructs a TodayBase which is a child of 'parent', with the
* name 'name' and widget flags set to 'f'
*/
TodayBase::TodayBase( QWidget* parent, const char* name, WFlags fl )
: QWidget( parent, name, fl )
{
// logo
QPixmap logo = Resource::loadPixmap( "today/today_logo");
// datebook
QPixmap datebook = Resource::loadPixmap("DateBook");
// todo
QPixmap todo = Resource::loadPixmap( "TodoList" );
// config icon
QPixmap config = Resource::loadPixmap( "today/config" );
+ // mail icon
+ QPixmap mail = Resource::loadPixmap( "today/mail" );
- if ( !name )
- setName( "TodayBase" );
- resize( 223, 307 );
+
+ //if ( !name )
+ // setName( "TodayBase" );
+ //resize( 223, 307 );
QVBoxLayout * layout = new QVBoxLayout(this);
Frame4 = new QFrame( this, "Frame4" );
Frame4->setFrameShape( QScrollView::StyledPanel );
Frame4->setFrameShadow( QScrollView::Sunken );
Frame4->setBackgroundOrigin( QScrollView::ParentOrigin );
// hehe, qt is ...
getridoffuckingstrippeldlinesbutton = new QPushButton (Frame4, "asdfsad" );
getridoffuckingstrippeldlinesbutton->setGeometry( QRect( -5, 10, 0, 0 ) );
DatesButton = new QPushButton (Frame4, "DatesButton" );
- DatesButton->setGeometry( QRect( 2, 10, 36, 32 ) );
+ DatesButton->setGeometry( QRect( 2, 4, 36, 32 ) );
DatesButton->setBackgroundOrigin( QPushButton::WidgetOrigin );
DatesButton->setPixmap( datebook );
DatesButton->setFlat( TRUE );
DatesField = new QLabel( Frame4, "DatesField" );
- DatesField->setGeometry( QRect( 40, 10, 203, 120 ) );
+ DatesField->setGeometry( QRect( 40, 4, 203, 120 ) );
DatesField->setText( tr( "No appointments today" ) );
DatesField->setAlignment( int( QLabel::AlignTop | QLabel::AlignLeft ) );
// today logo
Frame = new QLabel( this, "Frame" );
QPalette pal;
QColorGroup cg;
cg.setColor( QColorGroup::Text, white );
cg.setBrush( QColorGroup::Background, QBrush( QColor( 238, 238, 230), logo ) );
pal.setActive( cg );
Frame->setPalette( pal );
Frame->setFrameShape( QFrame::StyledPanel );
Frame->setFrameShadow( QFrame::Raised );
Frame->setLineWidth( 0 );
Frame->setMaximumHeight(50);
@@ -96,44 +99,65 @@ TodayBase::TodayBase( QWidget* parent, const char* name, WFlags fl )
TextLabel1->setFont( TextLabel1_font );
TextLabel1->setBackgroundOrigin( QLabel::ParentOrigin );
TextLabel1->setTextFormat( QLabel::AutoText );
// todo
Frame15 = new QFrame( this, "Frame15" );
Frame15->setFrameShape( QFrame::StyledPanel );
Frame15->setFrameShadow( QFrame::Sunken );
TodoButton = new QPushButton (Frame15, "TodoButton" );
TodoButton->setGeometry( QRect( 2, 4, 36, 32 ) );
TodoButton->setBackgroundOrigin( QPushButton::WidgetOrigin );
TodoButton->setPixmap( todo );
TodoButton->setFlat( TRUE );
TodoField = new QLabel( Frame15, "TodoField" );
- TodoField->setGeometry( QRect( 40, 10, 196, 120 ) );
+ TodoField->setGeometry( QRect( 40, 4, 196, 120 ) );
TodoField->setFrameShadow( QLabel::Plain );
TodoField->setText( tr( "No current todos" ) );
TodoField->setAlignment( int( QLabel::AlignTop | QLabel::AlignLeft ) );
PushButton1 = new QPushButton (Frame15, "PushButton1" );
PushButton1->setGeometry( QRect( 216, 68, 25, 21 ) );
PushButton1->setBackgroundOrigin( QPushButton::WidgetOrigin );
PushButton1->setPixmap( config );
PushButton1->setAutoDefault( TRUE );
PushButton1->setFlat( TRUE );
+ // mail
+ MailFrame = new QFrame( this, "MailFrame" );
+ MailFrame->setFrameShape( QScrollView::StyledPanel );
+ MailFrame->setFrameShadow( QScrollView::Sunken );
+ MailFrame->setBackgroundOrigin( QScrollView::ParentOrigin );
+
+ MailButton = new QPushButton (MailFrame, "MailButton" );
+ MailButton->setGeometry( QRect( 2, 10, 36, 19 ) );
+ MailButton->setBackgroundOrigin( QPushButton::WidgetOrigin );
+ MailButton->setPixmap( mail );
+ MailButton->setFlat( TRUE );
+
+ MailField = new QLabel( MailFrame, "DatesField" );
+ MailField->setGeometry( QRect( 40, 10, 203, 120 ) );
+ MailField->setText( tr( "Opiemail not installed" ) );
+ MailField->setAlignment( int( QLabel::AlignTop | QLabel::AlignLeft ) );
+ MailField->setMaximumHeight(15);
+ MailField->setMinimumHeight(10);
+
layout->addWidget(Frame);
layout->addWidget(Frame4);
+ layout->addWidget(MailFrame);
layout->addWidget(Frame15);
- layout->setStretchFactor(Frame4,3);
- layout->setStretchFactor(Frame15,2);
+ layout->setStretchFactor(Frame4,4);
+ layout->setStretchFactor(MailFrame,1);
+ layout->setStretchFactor(Frame15,3);
}
/*
* Destroys the object and frees any allocated resources
*/
TodayBase::~TodayBase()
{
// no need to delete child widgets, Qt does it all for us
}
diff --git a/core/pim/today/todaybase.h b/core/pim/today/todaybase.h
index 69c6363..15f021a 100644
--- a/core/pim/today/todaybase.h
+++ b/core/pim/today/todaybase.h
@@ -19,29 +19,31 @@ class QGridLayout;
class QFrame;
class QLabel;
class QPushButton;
class TodayBase : public QWidget
{
Q_OBJECT
public:
TodayBase( QWidget* parent = 0, const char* name = 0, WFlags fl = 0 );
~TodayBase();
QFrame* Frame4;
QPushButton* DatesButton;
QLabel* DatesField;
QLabel* Frame;
- //QFrame* Frame;
+ QFrame* MailFrame;
QLabel* TextLabel1;
QFrame* Frame15;
QLabel* TodoField;
+ QLabel* MailField;
QPushButton* PushButton1;
QPushButton* TodoButton;
+ QPushButton* MailButton;
QPushButton* getridoffuckingstrippeldlinesbutton;
protected:
};
#endif // TODAYBASE_H