summaryrefslogtreecommitdiff
Side-by-side diff
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--core/applets/clockapplet/clock.cpp46
-rw-r--r--core/applets/clockapplet/clock.h2
2 files changed, 42 insertions, 6 deletions
diff --git a/core/applets/clockapplet/clock.cpp b/core/applets/clockapplet/clock.cpp
index 7d396e7..d7d326d 100644
--- a/core/applets/clockapplet/clock.cpp
+++ b/core/applets/clockapplet/clock.cpp
@@ -1,8 +1,9 @@
/**********************************************************************
** Copyright (C) 2000 Trolltech AS. All rights reserved.
+** Copyright (C) 2002 Trolltech AS. All rights reserved.
**
** This file is part of Qtopia Environment.
**
** This file may be distributed and/or modified under the terms of the
** GNU General Public License version 2 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL included in the
@@ -14,21 +15,27 @@
** See http://www.trolltech.com/gpl/ for GPL licensing information.
**
** Contact info@trolltech.com if any conditions of this licensing are
** not clear to you.
**
**********************************************************************/
+// merged in the StyleFix. Applets should raise Popup!
+// by zecke@handhelds.org 6th of may 2004
#include "clock.h"
/* OPIE */
#include <opie2/odebug.h>
#include <opie2/otaskbarapplet.h>
+
#include <qpe/qpeapplication.h>
#include <qpe/qcopenvelope_qws.h>
#include <qpe/config.h>
+#include <qpe/resource.h>
+
+#include <qpopupmenu.h>
using namespace Opie::Core;
using namespace Opie::Ui;
LauncherClock::LauncherClock( QWidget *parent ) : QLabel( parent )
{
@@ -54,17 +61,46 @@ void LauncherClock::readConfig() {
config.setGroup( "Time" );
ampmFormat = config.readBoolEntry( "AMPM", TRUE );
config.setGroup( "Date" );
format = config.readNumEntry("ClockApplet",0);
}
-void LauncherClock::mouseReleaseEvent( QMouseEvent * )
+void LauncherClock::mousePressEvent( QMouseEvent * )
{
- QCString setTimeApp;
- setTimeApp="systemtime";
- QCopEnvelope e("QPE/Application/"+setTimeApp, "raise()");
+ QPopupMenu *menu = new QPopupMenu(this);
+ menu->insertItem(tr("Set time..."), 0);
+ menu->insertSeparator();
+ menu->insertItem(tr("Clock.."), 1);
+
+
+ Config config( "Clock" );
+ config.setGroup( "Daily Alarm" );
+ bool alarmOn = config.readBoolEntry("Enabled", FALSE);
+ menu->insertItem(Resource::loadIconSet(alarmOn?"clockapplet/smallalarm":"clockapplet/smallalarm_off" ),
+ tr("Alarm..."), 2);
+
+
+ /* FIXME use OTaskBarApplet ### */
+ QPoint curPos = mapToGlobal( QPoint(0,0) );
+ QSize sh = menu->sizeHint();
+ switch (menu->exec( curPos-QPoint((sh.width()-width())/2,sh.height()) )) {
+ case 0:
+ Global::execute( "systemtime" );
+ break;
+ case 1: {
+ QCopEnvelope e("QPE/Application/clock", "showClock()" );
+ }
+ break;
+ case 2: {
+ QCopEnvelope e("QPE/Application/clock", "editDailyAlarm()" );
+ }
+ break;
+ default:
+ break;
+ }
+ delete menu;
}
void LauncherClock::timerEvent( QTimerEvent *e )
{
if ( !e || e->timerId() == timerId ) {
@@ -110,13 +146,13 @@ void LauncherClock::changeTime( void )
setText( d+s );
} else {
setText( s );
}
}
-void LauncherClock::slotClockChanged( bool pm )
+void LauncherClock::slotClockChanged( bool )
{
readConfig();
updateTime();
}
diff --git a/core/applets/clockapplet/clock.h b/core/applets/clockapplet/clock.h
index 996fb56..43639bb 100644
--- a/core/applets/clockapplet/clock.h
+++ b/core/applets/clockapplet/clock.h
@@ -33,13 +33,13 @@ public:
protected slots:
void updateTime( void );
void slotClockChanged( bool pm );
protected:
- void mouseReleaseEvent( QMouseEvent * );
+ void mousePressEvent( QMouseEvent * );
void timerEvent( QTimerEvent * );
void changeTime( void );
void readConfig();
bool ampmFormat;
int timerId;
int format;