From ccceabd36ed168eefd785fb4fb720a577482fec1 Mon Sep 17 00:00:00 2001 From: tpearson Date: Wed, 17 Feb 2010 01:06:58 +0000 Subject: Added KDE3 version of knemo git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/applications/knemo@1091560 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- src/knemod/interfacetooltip.cpp | 204 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 204 insertions(+) create mode 100644 src/knemod/interfacetooltip.cpp (limited to 'src/knemod/interfacetooltip.cpp') diff --git a/src/knemod/interfacetooltip.cpp b/src/knemod/interfacetooltip.cpp new file mode 100644 index 0000000..77d6505 --- /dev/null +++ b/src/knemod/interfacetooltip.cpp @@ -0,0 +1,204 @@ +/* This file is part of KNemo + Copyright (C) 2004 Percy Leonhardt + + KNemo 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. + + KNemo 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 +#include + +#include +#include +#include + +#include "data.h" +#include "interface.h" +#include "interfacetooltip.h" + +InterfaceToolTip::InterfaceToolTip( Interface* interface, + QWidget* parent ) + : QToolTip( parent ), + mInterface( interface ) +{ + setupToolTipArray(); +} + +InterfaceToolTip::~InterfaceToolTip() +{ +} + +void InterfaceToolTip::maybeTip( const QPoint& ) +{ + QRect rect( parentWidget()->rect() ); + if ( !rect.isValid() ) + return; + + QString tooltip; + setupText( tooltip ); + tip( rect, tooltip ); +} + +void InterfaceToolTip::setupText( QString& text ) +{ + int toolTipContent = mInterface->getGeneralData().toolTipContent; + InterfaceData& data = mInterface->getData(); + + text += ""; + if ( ( toolTipContent & ALIAS ) && + mInterface->getSettings().alias != QString::null ) + text += ""; + if ( toolTipContent & INTERFACE ) + text += ""; + if ( data.available ) + { + if ( toolTipContent & STATUS ) + text += ""; + if ( toolTipContent & UPTIME ) + { + int upsecs = mInterface->getStartTime().secsTo( QDateTime::currentDateTime() ); + int updays = upsecs / 86400; // don't use QDateTime::daysTo() because + // we only want complete days + + QString uptime; + if ( updays == 1 ) + uptime = "1 day, "; + else if ( updays > 1 ) + uptime = QString( "%1 days, " ).arg( updays ); + + upsecs -= 86400 * updays; // we only want the seconds of today + int hrs = upsecs / 3600; + int mins = ( upsecs - hrs * 3600 ) / 60; + int secs = upsecs - hrs * 3600 - mins * 60; + QString time; + time.sprintf( "%02d:%02d:%02d", hrs, mins, secs ); + uptime += time; + text += ""; + } + } + else if ( data.existing ) + { + if ( toolTipContent & STATUS ) + text += ""; + } + else + { + if ( toolTipContent & STATUS ) + text += ""; + } + + if ( data.available ) + { + if ( toolTipContent & IP_ADDRESS ) + text += ""; + if ( toolTipContent & SUBNET_MASK ) + text += ""; + if ( mInterface->getType() == Interface::ETHERNET ) + { + if ( toolTipContent & BCAST_ADDRESS ) + text += ""; + if ( toolTipContent & GATEWAY ) + text += ""; + if ( toolTipContent & HW_ADDRESS ) + text += ""; + } + if ( mInterface->getType() == Interface::PPP ) + { + if ( toolTipContent & PTP_ADDRESS ) + text += ""; + } + if ( toolTipContent & RX_PACKETS ) + text += ""; + if ( toolTipContent & TX_PACKETS ) + text += ""; + if ( toolTipContent & RX_BYTES ) + text += ""; + if ( toolTipContent & TX_BYTES ) + text += ""; + if ( toolTipContent & DOWNLOAD_SPEED ) + { + unsigned long bytesPerSecond = data.incomingBytes / mInterface->getGeneralData().pollInterval; + text += ""; + } + if ( toolTipContent & UPLOAD_SPEED ) + { + unsigned long bytesPerSecond = data.outgoingBytes / mInterface->getGeneralData().pollInterval; + text += ""; + } + } + + if ( data.available && data.wirelessDevice ) + { + WirelessData& wdata = mInterface->getWirelessData(); + if ( toolTipContent & ESSID ) + text += ""; + if ( toolTipContent & MODE ) + text += ""; + if ( toolTipContent & FREQUENCY ) + text += ""; + if ( toolTipContent & BIT_RATE ) + text += ""; + if ( toolTipContent & ACCESS_POINT ) + text += ""; + if ( toolTipContent & LINK_QUALITY ) + text += ""; + if ( toolTipContent & NICK_NAME ) + text += ""; + if ( toolTipContent & ENCRYPTION ) + { + if ( wdata.encryption == true ) + { + text += ""; + } + else + { + text += ""; + } + } + } + text += "
" + mInterface->getSettings().alias + "
" + mToolTips[0].first + "" + mInterface->getName() + "
" + mToolTips[2].first + "" + i18n( "Connection established." ) + "
" + mToolTips[3].first + "" + uptime + "
" + mToolTips[2].first + "" + i18n( "Not connected." ) + "
" + mToolTips[2].first + "" + i18n( "Not existing." ) + "
" + mToolTips[4].first + "" + data.ipAddress + "
" + mToolTips[5].first + "" + data.subnetMask + "
" + mToolTips[18].first + "" + data.broadcastAddress + "
" + mToolTips[19].first + "" + data.defaultGateway + "
" + mToolTips[6].first + "" + data.hwAddress + "
" + mToolTips[7].first + "" + data.ptpAddress + "
" + mToolTips[8].first + "" + QString::number( data.rxPackets ) + "
" + mToolTips[9].first + "" + QString::number( data.txPackets ) + "
" + mToolTips[10].first + "" + data.rxString + "
" + mToolTips[11].first + "" + data.txString + "
" + mToolTips[20].first + "" + KIO::convertSize( bytesPerSecond ) + i18n( "/s" ) + "
" + mToolTips[21].first + "" + KIO::convertSize( bytesPerSecond ) + i18n( "/s" ) + "
" + mToolTips[12].first + "" + wdata.essid + "
" + mToolTips[13].first + "" + wdata.mode + "
" + mToolTips[14].first + "" + wdata.frequency + "
" + mToolTips[15].first + "" + wdata.bitRate + "
" + mToolTips[16].first + "" + wdata.accessPoint + "
" + mToolTips[17].first + "" + wdata.linkQuality + "
" + mToolTips[22].first + "" + wdata.nickName + "
" + mToolTips[23].first + "" + i18n( "active" ) + "
" + mToolTips[23].first + "" + i18n( "off" ) + "
"; +} + +void InterfaceToolTip::setupToolTipArray() +{ + // Cannot make this data static as the i18n macro doesn't seem + // to work when called to early i.e. before setting the catalogue. + mToolTips[0] = QPair( i18n( "Interface" ), INTERFACE ); + mToolTips[1] = QPair( i18n( "Alias" ), ALIAS ); + mToolTips[2] = QPair( i18n( "Status" ), STATUS ); + mToolTips[3] = QPair( i18n( "Uptime" ), UPTIME ); + mToolTips[4] = QPair( i18n( "IP-Address" ), IP_ADDRESS ); + mToolTips[5] = QPair( i18n( "Subnet Mask" ), SUBNET_MASK ); + mToolTips[6] = QPair( i18n( "HW-Address" ), HW_ADDRESS ); + mToolTips[7] = QPair( i18n( "PtP-Address" ), PTP_ADDRESS ); + mToolTips[8] = QPair( i18n( "Packets Received" ), RX_PACKETS ); + mToolTips[9] = QPair( i18n( "Packets Sent" ), TX_PACKETS ); + mToolTips[10] = QPair( i18n( "Bytes Received" ), RX_BYTES ); + mToolTips[11] = QPair( i18n( "Bytes Sent" ), TX_BYTES ); + mToolTips[12] = QPair( i18n( "ESSID" ), ESSID ); + mToolTips[13] = QPair( i18n( "Mode" ), MODE ); + mToolTips[14] = QPair( i18n( "Frequency" ), FREQUENCY ); + mToolTips[15] = QPair( i18n( "Bit Rate" ), BIT_RATE ); + mToolTips[16] = QPair( i18n( "Access Point" ), ACCESS_POINT ); + mToolTips[17] = QPair( i18n( "Link Quality" ), LINK_QUALITY ); + mToolTips[18] = QPair( i18n( "Broadcast Address" ), BCAST_ADDRESS ); + mToolTips[19] = QPair( i18n( "Default Gateway" ), LINK_QUALITY ); + mToolTips[20] = QPair( i18n( "Download Speed" ), DOWNLOAD_SPEED ); + mToolTips[21] = QPair( i18n( "Upload Speed" ), UPLOAD_SPEED ); + mToolTips[22] = QPair( i18n( "Nickname" ), NICK_NAME ); + mToolTips[23] = QPair( i18n( "Encryption" ), ENCRYPTION ); + mToolTips[24] = QPair(); +} + -- cgit v1.2.3