summaryrefslogtreecommitdiff
authorsandman <sandman>2002-06-26 00:43:45 (UTC)
committer sandman <sandman>2002-06-26 00:43:45 (UTC)
commitd31131a054c7ab5d42034d040dae5b72a3338085 (patch) (side-by-side diff)
tree8e4796072b772450ee0f41a23dd570482363a65a
parentb970aebbdfc7e6f811c9b75ee62ad9370f74ace0 (diff)
downloadopie-d31131a054c7ab5d42034d040dae5b72a3338085.zip
opie-d31131a054c7ab5d42034d040dae5b72a3338085.tar.gz
opie-d31131a054c7ab5d42034d040dae5b72a3338085.tar.bz2
Added FIFO history entries for the last 5 cut/copy operations.
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--core/applets/clipboardapplet/clipboard.cpp86
-rw-r--r--core/applets/clipboardapplet/clipboard.h10
2 files changed, 79 insertions, 17 deletions
diff --git a/core/applets/clipboardapplet/clipboard.cpp b/core/applets/clipboardapplet/clipboard.cpp
index 203e23e..181f4bf 100644
--- a/core/applets/clipboardapplet/clipboard.cpp
+++ b/core/applets/clipboardapplet/clipboard.cpp
@@ -20,17 +20,18 @@
#include "clipboard.h"
#include <qpe/resource.h>
#include <qpainter.h>
#include <qpopupmenu.h>
#include <qwindowsystem_qws.h>
-#include <qmessagebox.h>
+#include <qapplication.h>
+#include <qclipboard.h>
#include <qtimer.h>
//===========================================================================
/* XPM */
static const char * paste_xpm[] = {
"14 16 64 1",
" c None",
@@ -114,64 +115,119 @@ static const char * paste_xpm[] = {
" ...$mljnn0qd.",
" 4.......,"};
ClipboardApplet::ClipboardApplet( QWidget *parent, const char *name ) : QWidget( parent, name )
{
setFixedWidth ( 14 );
setFixedHeight ( 18 );
- clipboardPixmap = QPixmap ( paste_xpm );
- menu = 0;
+ m_clipboardPixmap = QPixmap ( paste_xpm );
+
+ QTimer *timer = new QTimer ( this );
+
+ connect ( QApplication::clipboard ( ), SIGNAL( dataChanged ( )), this, SLOT( newData ( )));
+ connect ( timer, SIGNAL( timeout ( )), this, SLOT( newData ( )));
+
+ timer-> start ( 1000 );
+
+ m_menu = 0;
+ m_dirty = true;
+ m_lasttext = QString::null;
}
ClipboardApplet::~ClipboardApplet ( )
{
}
void ClipboardApplet::mousePressEvent ( QMouseEvent *)
{
- if ( !menu ) {
- menu = new QPopupMenu ( this );
- menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "cut" )), tr( "Cut" ), 0 );
- menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "copy" )), tr( "Copy" ), 1 );
- menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "paste" )), tr( "Paste" ), 2 );
- connect ( menu, SIGNAL( activated ( int )), this, SLOT( action ( int )));
+ if ( m_dirty ) {
+ delete m_menu;
+
+ m_menu = new QPopupMenu ( this );
+ m_menu-> setCheckable ( true );
+
+ if ( m_history. count ( )) {
+ for ( unsigned int i = 0; i < m_history. count ( ); i++ ) {
+ QString str = m_history [i];
+
+ if ( str. length ( ) > 20 )
+ str = str. left ( 20 ) + "...";
+
+ m_menu-> insertItem ( QString ( "%1: %2" ). arg ( i + 1 ). arg ( str ), i );
+ m_menu-> setItemChecked ( i, false );
+ }
+ m_menu-> setItemChecked ( m_history. count ( ) - 1, true );
+ m_menu-> insertSeparator ( );
+ }
+ m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "cut" )), tr( "Cut" ), 100 );
+ m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "copy" )), tr( "Copy" ), 101 );
+ m_menu-> insertItem ( QIconSet ( Resource::loadPixmap ( "paste" )), tr( "Paste" ), 102 );
+
+ connect ( m_menu, SIGNAL( activated ( int )), this, SLOT( action ( int )));
+
+ m_dirty = false;
}
QPoint p = mapToGlobal ( QPoint ( 0, 0 ));
- QSize s = menu-> sizeHint ( );
+ QSize s = m_menu-> sizeHint ( );
- menu-> popup ( QPoint ( p. x ( ) + ( width ( ) / 2 ) - ( s. width ( ) / 2 ), p. y ( ) - s. height ( )));
+ m_menu-> popup ( QPoint ( p. x ( ) + ( width ( ) / 2 ) - ( s. width ( ) / 2 ), p. y ( ) - s. height ( )));
}
void ClipboardApplet::action(int id)
{
ushort unicode=0;
int scan=0;
switch ( id ) {
- case 0:
+ case 100:
unicode='X'-'@';
scan=Key_X; // Cut
break;
- case 1:
+ case 101:
unicode='C'-'@';
scan=Key_C; // Copy
break;
- case 2:
+ case 102:
unicode='V'-'@';
scan=Key_V; // Paste
break;
+
+ default:
+ if (( id >= 0 ) && ( uint( id ) < m_history. count ( ))) {
+ QApplication::clipboard ( )-> setText ( m_history [id] );
+
+ for ( uint i = 0; i < m_history. count ( ); i++ )
+ m_menu-> setItemChecked ( i, i == uint( id ));
+
+ unicode = 'V' - '@';
+ scan = Key_V;
+ }
+ break;
}
if ( scan ) {
qwsServer-> sendKeyEvent ( unicode, scan, ControlButton, true, false );
qwsServer-> sendKeyEvent ( unicode, scan, ControlButton, true, false );
}
}
void ClipboardApplet::paintEvent ( QPaintEvent* )
{
QPainter p ( this );
- p. drawPixmap ( 0, 1, clipboardPixmap );
+ p. drawPixmap ( 0, 1, m_clipboardPixmap );
}
+void ClipboardApplet::newData ( )
+{
+ QCString type = "plain";
+ QString txt = QApplication::clipboard ( )-> text ( type );
+
+ if ( !txt. isEmpty ( ) && !m_history. contains ( txt )) {
+ m_history. append ( txt );
+
+ if ( m_history. count ( ) > 5 )
+ m_history. remove ( m_history. begin ( ));
+ m_dirty = true;
+ }
+}
diff --git a/core/applets/clipboardapplet/clipboard.h b/core/applets/clipboardapplet/clipboard.h
index 9dd59ed..84743d9 100644
--- a/core/applets/clipboardapplet/clipboard.h
+++ b/core/applets/clipboardapplet/clipboard.h
@@ -17,31 +17,37 @@
** not clear to you.
**
**********************************************************************/
#ifndef __CLIPBOARD_APPLET_H__
#define __CLIPBOARD_APPLET_H__
#include <qwidget.h>
#include <qpixmap.h>
+#include <qstringlist.h>
class ClipboardApplet : public QWidget
{
Q_OBJECT
public:
ClipboardApplet( QWidget *parent = 0, const char *name=0 );
~ClipboardApplet();
protected:
void mousePressEvent( QMouseEvent *);
void paintEvent( QPaintEvent* );
private slots:
void action(int);
+ void newData ( );
private:
- QPopupMenu* menu;
- QPixmap clipboardPixmap;
+ QPopupMenu * m_menu;
+ QStringList m_history;
+ bool m_dirty;
+ QString m_lasttext;
+
+ QPixmap m_clipboardPixmap;
};
#endif // __CLIPBOARD_APPLET_H__