From 145abc15d57fb29701a12e8a14dcb9c1fd72e9be Mon Sep 17 00:00:00 2001 From: Michele Calgaro Date: Mon, 7 Dec 2020 22:58:44 +0900 Subject: Renaming of files in preparation for code style tools. Signed-off-by: Michele Calgaro --- kicker/menuext/tom/Makefile.am | 4 +- kicker/menuext/tom/README | 2 +- kicker/menuext/tom/tom.cc | 855 ----------------------------------------- kicker/menuext/tom/tom.cpp | 855 +++++++++++++++++++++++++++++++++++++++++ 4 files changed, 858 insertions(+), 858 deletions(-) delete mode 100644 kicker/menuext/tom/tom.cc create mode 100644 kicker/menuext/tom/tom.cpp (limited to 'kicker/menuext') diff --git a/kicker/menuext/tom/Makefile.am b/kicker/menuext/tom/Makefile.am index 0f9f7c081..16a46a9dc 100644 --- a/kicker/menuext/tom/Makefile.am +++ b/kicker/menuext/tom/Makefile.am @@ -2,7 +2,7 @@ INCLUDES = -I$(srcdir)/../../libkicker -I$(srcdir)/../../ui -I$(srcdir)/../../co kde_module_LTLIBRARIES = kickermenu_tom.la -kickermenu_tom_la_SOURCES = tom.cc +kickermenu_tom_la_SOURCES = tom.cpp kickermenu_tom_la_LDFLAGS = $(all_libraries) -module -avoid-version kickermenu_tom_la_LIBADD = $(LIB_TDEUI) #$(top_builddir)/kicker/ui/libkicker_ui.la @@ -16,4 +16,4 @@ tomdata_DATA = destinations tomdatadir = $(kde_datadir)/kicker/tom messages: - $(XGETTEXT) *.cc -o $(podir)/libkickermenu_tom.pot + $(XGETTEXT) *.cpp -o $(podir)/libkickermenu_tom.pot diff --git a/kicker/menuext/tom/README b/kicker/menuext/tom/README index 926ae0e81..7fe6eb332 100644 --- a/kicker/menuext/tom/README +++ b/kicker/menuext/tom/README @@ -60,6 +60,6 @@ What should be the default task entry format be: c) App Name (Task Name) <-- silly option =) Should "Run A Command..." be replaced by an inline combobox? Pros: It's more obvious and will work even if kdesktop is gone. The widget - is already written (in tom.cc) + is already written (in tom.cpp) Cons: It makes it stand out too much over other entries, takes up more room and isn't as powerful as the full minicli diff --git a/kicker/menuext/tom/tom.cc b/kicker/menuext/tom/tom.cc deleted file mode 100644 index 0fa85a1e3..000000000 --- a/kicker/menuext/tom/tom.cc +++ /dev/null @@ -1,855 +0,0 @@ -/* This file is part of the KDE project - Copyright (C) 2003 Aaron J. Seigo - - This program is free software; you can redistribute it and/or - modify it under the terms of the GNU General Public - License version 2 as published by the Free Software Foundation. - - This program 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 - General Public License for more details. - - You should have received a copy of the GNU General Public License - along with this program; see the file COPYING. If not, write to - the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, - Boston, MA 02110-1301, USA. -*/ - -#include -using namespace std; - -#include -#include -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include - -#include "menuinfo.h" -#include "service_mnu.h" -#include "kicker.h" -#include "tom.h" - -const int configureMenuID = 1000; -const int contextMenuTitleID = 10000; -const int destMenuTitleID = 10001; - -extern "C" -{ - KDE_EXPORT void* init_kickermenu_tom() - { - TDEGlobal::locale()->insertCatalogue("libkickermenu_tom"); - return new TOMFactory; - } -}; - -TOMFactory::TOMFactory(TQObject *parent, const char *name) -: KLibFactory(parent, name) -{ -} - -TQObject* TOMFactory::createObject(TQObject *parent, const char *name, const char*, const TQStringList&) -{ - return new TOM((TQWidget*)parent, name); -} - -#include -/* - * TODO: switch the backgroundmode when translucency turns on/off - * TODO: catch font changes too? - */ -class runMenuWidget : public TQWidget, public QMenuItem -{ - public: - runMenuWidget(TDEPopupMenu* parent, int index) - : TQWidget (parent), - m_menu(parent), - m_index(index) - { - setFocusPolicy(StrongFocus); - - TQHBoxLayout* runLayout = new TQHBoxLayout(this); - textRect = fontMetrics().boundingRect(i18n("Run:")); - runLayout->setSpacing(KDialog::spacingHint()); - runLayout->addSpacing((KDialog::spacingHint() * 3) + TDEIcon::SizeMedium + textRect.width()); - icon = DesktopIcon("system-run", TDEIcon::SizeMedium); - /*TQLabel* l1 = new TQLabel(this); - TQPixmap foo = DesktopIcon("system-run", TDEIcon::SizeMedium); - cout << "foo is: " << foo.width() << " by " << foo.height() << endl; - l1->setPixmap(foo); - runLayout->addWidget(l1);*/ - /*TQLabel* l2 = new TQLabel(i18n("&Run: "), this); - l2->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); - l2->setBuddy(this); - runLayout->addWidget(l2);*/ - m_runEdit = new KHistoryCombo(this); - m_runEdit->setSizePolicy(TQSizePolicy::Expanding, TQSizePolicy::Preferred); - runLayout->addWidget(m_runEdit, 10); - runLayout->addSpacing(KDialog::spacingHint()); - - TQSettings settings; - if (settings.readEntry("/TDEStyle/Settings/MenuTransparencyEngine", "Disabled") != "Disabled") - { - setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); - //l1->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); - //l2->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); - m_runEdit->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); - } - else - { - /*setBackgroundMode(Qt::NoBackground, Qt::NoBackground); - l1->setBackgroundMode(Qt::NoBackground, Qt::NoBackground); - l2->setBackgroundMode(Qt::NoBackground, Qt::NoBackground); - m_runEdit->setBackgroundMode(Qt::NoBackground, Qt::NoBackground);*/ - //l1->setAutoMask(true); - //l1->setBackgroundMode(Qt::NoBackground, Qt::NoBackground); - //l2->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); - //m_runEdit->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); - } - - setMinimumHeight(TDEIcon::SizeMedium + 2); - } - ~runMenuWidget() {} - - - void paintEvent(TQPaintEvent * /*e*/) - { - TQPainter p(this); - TQRect r(rect()); - // ew, nasty hack. may result in coredumps due to horrid C-style cast??? - kapp->style().drawControl(TQStyle::CE_PopupMenuItem, &p, m_menu, r, palette().active(), TQStyle::Style_Enabled, - TQStyleOption(static_cast(this), 0, TDEIcon::SizeMedium )); - p.drawPixmap(KDialog::spacingHint(), 1, icon); - p.drawText((KDialog::spacingHint() * 2) + TDEIcon::SizeMedium, textRect.height() + ((height() - textRect.height()) / 2), i18n("Run:")); - } - - void focusInEvent (TQFocusEvent* e) - { - if (!e || e->gotFocus()) - { - m_menu->setActiveItem(m_index); - m_runEdit->setFocus(); - } - } - - void enterEvent(TQEvent*) - { - focusInEvent(0); - } - - private: - TDEPopupMenu* m_menu; - KHistoryCombo* m_runEdit; - TQPixmap icon; - TQRect textRect; - int m_index; -}; - -TOM::TOM(TQWidget *parent, const char *name) - : KPanelMenu(parent, name), - m_maxIndex(0) -{ - disableAutoClear(); - m_submenus.setAutoDelete(true); - setCaption(i18n("Task-Oriented Menu")); - - // KMenu legacy: support some menu config options - TDEConfig* config = TDEGlobal::config(); - config->setGroup("menus"); - m_detailedTaskEntries = config->readBoolEntry("DetailedMenuEntries", false); - if (m_detailedTaskEntries) - { - m_detailedNamesFirst = config->readBoolEntry("DetailedEntriesNamesFirst", false); - } - - m_isImmutable = Kicker::kicker()->isImmutable() || config->groupIsImmutable("TOM"); - config->setGroup("TOM"); - m_largerFont = font(); - m_largerFont = config->readFontEntry("Font", &m_largerFont); -} - -TOM::~TOM() -{ - slotClear(); -} - -void TOM::initializeRecentApps(TQPopupMenu* menu) -{ - /* - * TODO: make this real - * add a KDE-wide "commands run" registry - */ - - if (!m_isImmutable) - { - menu->insertSeparator(); - menu->insertItem(i18n("Configure This Menu"), configureMenuID); - } -} - -void TOM::initializeRecentDocs() -{ - m_recentDocsMenu->clear(); - m_recentDocsMenu->insertItem(SmallIconSet("history_clear"), i18n("Clear History"), - this, TQT_SLOT(clearRecentDocHistory())); - m_recentDocsMenu->insertSeparator(); - - m_recentDocURLs = TDERecentDocument::recentDocuments(); - - if (m_recentDocURLs.isEmpty()) - { - setItemEnabled(m_recentDocsMenu->insertItem(i18n("No Entries")), false); - return; - } - - int id = 0; - for (TQStringList::ConstIterator it = m_recentDocURLs.begin(); - it != m_recentDocURLs.end(); - ++it) - { - /* - * TODO: make the number of visible items configurable? - */ - - KDesktopFile f(*it, true /* read only */); - m_recentDocsMenu->insertItem(DesktopIcon(f.readIcon(), TDEIcon::SizeMedium), - f.readName().replace('&', "&&"), id); - ++id; - } -} - -int TOM::appendTaskGroup(TDEConfig& config, bool inSubMenu) -{ - if (!config.hasGroup("General")) - { - return 0; - } - - config.setGroup("General"); - - if (config.readBoolEntry("Hidden", false)) - { - return 0; - } - - TQString name = config.readEntry("Name", i18n("Unknown")); - TQString icon = config.readEntry("Icon"); - int numTasks = config.readNumEntry("NumTasks", 0); - - if (numTasks < 1) - { - return 0; - } - - TDEPopupMenu* taskGroup; - if( inSubMenu ) - { - taskGroup = new TDEPopupMenu(this); - - if (icon != TQString::null) - { - insertItem(DesktopIcon(icon, TDEIcon::SizeMedium), name, taskGroup); - } - else - { - insertItem(name, taskGroup); - } - } - else - { - taskGroup = this; - } - - int foundTasks = 0; - for (int i = 0; i < numTasks; ++i) - { - TQString groupName = TQString("Task%1").arg(i); - - if (config.hasGroup(groupName)) - { - config.setGroup(groupName); - - if (config.readBoolEntry("Hidden", false)) - { - continue; - } - - TQString name = config.readEntry("Name"); - // in case the name contains an ampersand, double 'em up - name.replace("&", "&&"); - TQString desktopfile = config.readPathEntry("DesktopFile"); - KService::Ptr pService = KService::serviceByDesktopPath(desktopfile); - - if (!pService) - { - pService = KService::serviceByDesktopName(desktopfile); - - if (!pService) - { - continue; - } - } - - TQString execName = pService->name(); - TQString icon = pService->icon(); - - if (m_detailedTaskEntries && !execName.isEmpty()) - { - TQString tmp = i18n("%1 (%2)"); - - if (m_detailedNamesFirst) - { - name = tmp.arg(execName).arg(name); - } - else - { - name = tmp.arg(name).arg(execName); - } - } - - ++m_maxIndex; - if (icon.isEmpty()) - { - taskGroup->insertItem(name, m_maxIndex); - } - else - { - - TQIconSet iconset = BarIconSet(icon, 22); - if (iconset.isNull()) - taskGroup->insertItem(name, m_maxIndex); - else - taskGroup->insertItem(iconset, name, m_maxIndex); - - } - - m_tasks.insert(m_maxIndex, pService); - ++foundTasks; - } - } - - // if we end up with an empty task group, get rid of the menu - if (foundTasks == 0) - { - if (inSubMenu) - { - delete taskGroup; - } - - return 0; - } - - connect(taskGroup, TQT_SIGNAL(activated(int)), this, TQT_SLOT(runTask(int))); - // so we have an actual task group menu with tasks, let's add it - - if (inSubMenu) - { - TQObject::connect(taskGroup, TQT_SIGNAL(aboutToShowContextMenu(TDEPopupMenu*, int, TQPopupMenu*)), - this, TQT_SLOT(contextualizeRMBmenu(TDEPopupMenu*, int, TQPopupMenu*))); - - m_submenus.append(taskGroup); - - taskGroup->setFont(m_largerFont); - taskGroup->setKeyboardShortcutsEnabled(true); - - if (!m_isImmutable && !config.isImmutable()) - { - taskGroup->insertSeparator(); - taskGroup->insertItem("Modify These Tasks", configureMenuID); - TQPopupMenu* rmbMenu = taskGroup->contextMenu(); - rmbMenu->setFont(m_largerFont); - TDEPopupTitle* title = new TDEPopupTitle(); - title->setText(i18n("%1 Menu Editor").arg(name)); - rmbMenu->insertItem(title, contextMenuTitleID); - rmbMenu->insertItem(i18n("Add This Task to Panel")); - rmbMenu->insertItem(i18n("Modify This Task...")); - rmbMenu->insertItem(i18n("Remove This Task..."), this, TQT_SLOT(removeTask())); - rmbMenu->insertItem(i18n("Insert New Task...")); - } - } - - return foundTasks; -} -/* - * TODO: track configuration file changes. -void TOM::configChanged() -{ - KPanelMenu::configChanged(); - setInitialized(false); - initialize(); -} -*/ -void TOM::initialize() -{ - if (initialized()) - { - return; - } - - setInitialized(true); - m_submenus.clear(); - m_tasks.clear(); - clear(); - - /* hack to make items larger. should use something better? - m_largerFont = font(); - if (m_largerFont.pointSize() < 18) - { - m_largerFont.setPointSize(18); - } - setFont(m_largerFont);*/ - - - /*if (!loadSidePixmap()) - { - m_sidePixmap = m_sideTilePixmap = TQPixmap(); - } - else - { - connect(kapp, TQT_SIGNAL(tdedisplayPaletteChanged()), TQT_SLOT(paletteChanged())); - }*/ - - // TASKS - insertTitle(i18n("Tasks"), contextMenuTitleID); - - TQStringList dirs = TDEGlobal::dirs()->findDirs("data", "kicker/tom/"); - TQStringList::ConstIterator dIt = dirs.begin(); - TQStringList::ConstIterator dEnd = dirs.end(); - - for (; dIt != dEnd; ++dIt ) - { - TQDir dir(*dIt); - - TQStringList entries = dir.entryList("*rc", TQDir::Files); - TQStringList::ConstIterator eIt = entries.begin(); - TQStringList::ConstIterator eEnd = entries.end(); - - for (; eIt != eEnd; ++eIt ) - { - TDEConfig config(*dIt + *eIt); - appendTaskGroup(config); - } - } - - PanelServiceMenu* moreApps = new PanelServiceMenu(TQString::null, TQString::null, this, "More Applications"); - moreApps->setFont(m_largerFont); - insertItem(DesktopIcon("misc", TDEIcon::SizeMedium), i18n("More Applications"), moreApps); - m_submenus.append(moreApps); - - if (!m_isImmutable) - { - insertSeparator(); - // TODO: connect to taskgroup edits - insertItem("Modify The Above Tasks"); - } - - // DESTINATIONS - insertTitle(i18n("Destinations"), destMenuTitleID); - int numDests = 0; - TQString destinationsConfig = locate("appdata", "tom/destinations"); - - if (!destinationsConfig.isEmpty() && TQFile::exists(destinationsConfig)) - { - TDEConfig config(destinationsConfig); - numDests = appendTaskGroup(config, false); - } - - if (numDests == 0) - { - removeItem(destMenuTitleID); - } - else if (kapp->authorize("run_command")) - { - insertItem(DesktopIcon("system-run", TDEIcon::SizeMedium), i18n("Run Command..."), this, TQT_SLOT(runCommand())); - } - - // RECENTLY USED ITEMS - insertTitle(i18n("Recently Used Items"), contextMenuTitleID); - - m_recentDocsMenu = new TDEPopupMenu(this, "recentDocs"); - m_recentDocsMenu->setFont(m_largerFont); - connect(m_recentDocsMenu, TQT_SIGNAL(aboutToShow()), this, TQT_SLOT(initializeRecentDocs())); - connect(m_recentDocsMenu, TQT_SIGNAL(activated(int)), this, TQT_SLOT(openRecentDocument(int))); - insertItem(DesktopIcon("text-x-generic", TDEIcon::SizeMedium), i18n("Recent Documents"), m_recentDocsMenu); - m_submenus.append(m_recentDocsMenu); - - TDEPopupMenu* recentApps = new TDEPopupMenu(this, "recentApps"); - recentApps->setFont(m_largerFont); - recentApps->setKeyboardShortcutsEnabled(true); - initializeRecentApps(recentApps); - insertItem(i18n("Recent Applications"), recentApps); - m_submenus.append(recentApps); - - // SPECIAL ITEMS - insertTitle(i18n("Special Items"), contextMenuTitleID); - - // if we have no destinations, put the run command here - if (numDests == 0 && kapp->authorize("run_command")) - { - insertItem(DesktopIcon("system-run", TDEIcon::SizeMedium), i18n("Run Command..."), this, TQT_SLOT(runCommand())); - } - - - TDEConfig* config = TDEGlobal::config(); - TQStringList menu_ext = config->readListEntry("Extensions"); - if (!menu_ext.isEmpty()) - { - bool needSeparator = false; - for (TQStringList::ConstIterator it = menu_ext.begin(); it != menu_ext.end(); ++it) - { - MenuInfo info(*it); - if (!info.isValid()) - { - continue; - } - - KPanelMenu *menu = info.load(); - if (menu) - { - ++m_maxIndex; - insertItem(DesktopIcon(info.icon(), TDEIcon::SizeMedium), info.name(), menu, m_maxIndex); - m_submenus.append(menu); - needSeparator = true; - } - } - - if (needSeparator) - { - insertSeparator(); - } - } - - - TQString username; - struct passwd *userInfo = getpwuid(getuid()); - if (userInfo) - { - username = TQString::fromLocal8Bit(userInfo->pw_gecos); - if (username.find(',') != -1) - { - // Remove everything from and including first comma - username.truncate(username.find(',')); - } - - if (username.isEmpty()) - { - username = TQString::fromLocal8Bit(userInfo->pw_name); - } - } - - insertItem(DesktopIcon("system-log-out", TDEIcon::SizeMedium), - i18n("Logout %1").arg(username), this, TQT_SLOT(logout())); -} - -void TOM::reload() -{ - setInitialized(false); - initialize(); -} - -void TOM::contextualizeRMBmenu(TDEPopupMenu* menu, int menuItem, TQPopupMenu* ctxMenu) -{ - if (menuItem == configureMenuID) - { - menu->hideContextMenu(); - return; - } - - ctxMenu->removeItem(contextMenuTitleID); - TQString text = menu->text(menuItem); - int parens = text.find('(') - 1; - if (parens > 0) - { - text = text.left(parens); - } - TDEPopupTitle* title = new TDEPopupTitle(); - title->setText(i18n("The \"%2\" Task").arg(text)); - ctxMenu->insertItem(title, contextMenuTitleID, 0); -} - -void TOM::slotClear() -{ - KPanelMenu::slotClear(); - m_submenus.clear(); - m_tasks.clear(); -} - -void TOM::slotExec(int /* id */) -{ - // Reimplemented because we have to -} - -void TOM::removeTask() -{ - // TODO: write this change out to the appropriate config file - TQString task = TDEPopupMenu::contextMenuFocus()->text(TDEPopupMenu::contextMenuFocusItem()); - if (KMessageBox::warningContinueCancel(this, - i18n("Are you sure you want to remove the %1 task?

" - "Tip: You can restore the task after it has been removed by selecting the "Modify These Tasks" entry").arg(task), - i18n("Remove Task?"),KStdGuiItem::del()) == KMessageBox::Continue) - { - m_tasks.remove(TDEPopupMenu::contextMenuFocusItem()); - TDEPopupMenu::contextMenuFocus()->removeItem(TDEPopupMenu::contextMenuFocusItem()); - } -} - -// TODO: should we have a side graphic like the TDE Menu? personally, i don't -// think it helps usability. it's nice for branding, but that's it. perhaps a -// top image, or something blended with the actual menu background? deffinitely -// a job for a graphic artist. -/* - * if this goes in, it should be shared w/the kmenu - * -bool TOM::loadSidePixmap() -{ - TDEConfig *config = TDEGlobal::config(); - TQColor color = palette().active().highlight(); - TQImage image; - - config->setGroup("WM"); - TQColor activeTitle = config->readColorEntry("activeBackground", &color); - TQColor inactiveTitle = config->readColorEntry("inactiveBackground", &color); - - config->setGroup("KMenu"); - if (!config->readBoolEntry("Usem_sidePixmap", true)) - return false; - - // figure out which color is most suitable for recoloring to - int h1, s1, v1, h2, s2, v2, h3, s3, v3; - activeTitle.hsv(&h1, &s1, &v1); - inactiveTitle.hsv(&h2, &s2, &v2); - palette().active().background().hsv(&h3, &s3, &v3); - - if ( (abs(h1-h3)+abs(s1-s3)+abs(v1-v3) < abs(h2-h3)+abs(s2-s3)+abs(v2-v3)) && - ((abs(h1-h3)+abs(s1-s3)+abs(v1-v3) < 32) || (s1 < 32)) && (s2 > s1)) - color = inactiveTitle; - else - color = activeTitle; - - // limit max/min brightness - int r, g, b; - color.rgb(&r, &g, &b); - int gray = tqGray(r, g, b); - if (gray > 180) { - r = (r - (gray - 180) < 0 ? 0 : r - (gray - 180)); - g = (g - (gray - 180) < 0 ? 0 : g - (gray - 180)); - b = (b - (gray - 180) < 0 ? 0 : b - (gray - 180)); - } else if (gray < 76) { - r = (r + (76 - gray) > 255 ? 255 : r + (76 - gray)); - g = (g + (76 - gray) > 255 ? 255 : g + (76 - gray)); - b = (b + (76 - gray) > 255 ? 255 : b + (76 - gray)); - } - color.setRgb(r, g, b); - - TQString sideName = config->readEntry("SideName", "kside.png"); - TQString sideTileName = config->readEntry("SideTileName", "kside_tile.png"); - - image.load(locate("data", "kicker/pics/" + sideName)); - - if (image.isNull()) - { - return false; - } - - TDEIconEffect::colorize(image, color, 1.0); - m_sidePixmap.convertFromImage(image); - - image.load(locate("data", "kicker/pics/" + sideTileName)); - - if (image.isNull()) - { - return false; - } - - TDEIconEffect::colorize(image, color, 1.0); - m_sideTilePixmap.convertFromImage(image); - - if (m_sidePixmap.width() != m_sideTilePixmap.width()) - { - return false; - } - - // pretile the pixmap to a height of at least 100 pixels - if (m_sideTilePixmap.height() < 100) - { - int tiles = (int)(100 / m_sideTilePixmap.height()) + 1; - TQPixmap preTiledPixmap(m_sideTilePixmap.width(), m_sideTilePixmap.height() * tiles); - TQPainter p(&preTiledPixmap); - p.drawTiledPixmap(preTiledPixmap.rect(), m_sideTilePixmap); - m_sideTilePixmap = preTiledPixmap; - } - - return true; -} - -void TOM::paletteChanged() -{ - if (!loadSidePixmap()) - m_sidePixmap = m_sideTilePixmap = TQPixmap(); -} - -void TOM::setMinimumSize(const TQSize & s) -{ - KPanelMenu::setMinimumSize(s.width() + m_sidePixmap.width(), s.height()); -} - -void TOM::setMaximumSize(const TQSize & s) -{ - KPanelMenu::setMaximumSize(s.width() + m_sidePixmap.width(), s.height()); -} - -void TOM::setMinimumSize(int w, int h) -{ - KPanelMenu::setMinimumSize(w + m_sidePixmap.width(), h); -} - -void TOM::setMaximumSize(int w, int h) -{ - KPanelMenu::setMaximumSize(w + m_sidePixmap.width(), h); -} - -TQRect TOM::sideImageRect() -{ - return TQStyle::visualRect( TQRect( frameWidth(), frameWidth(), m_sidePixmap.width(), - height() - 2*frameWidth() ), this ); -} - -void TOM::resizeEvent(TQResizeEvent * e) -{ - setFrameRect( TQStyle::visualRect( TQRect( m_sidePixmap.width(), 0, - width() - m_sidePixmap.width(), height() ), this ) ); -} - -void TOM::paintEvent(TQPaintEvent * e) -{ - if (m_sidePixmap.isNull()) { - KPanelMenu::paintEvent(e); - return; - } - - TQPainter p(this); - - style().tqdrawPrimitive( TQStyle::PE_PanelPopup, &p, - TQRect( 0, 0, width(), height() ), - colorGroup(), TQStyle::Style_Default, - TQStyleOption( frameWidth(), 0 ) ); - - TQRect r = sideImageRect(); - r.setBottom( r.bottom() - m_sidePixmap.height() ); - p.drawTiledPixmap( r, m_sideTilePixmap ); - - r = sideImageRect(); - r.setTop( r.bottom() - m_sidePixmap.height() ); - p.drawPixmap( r, m_sidePixmap ); - - drawContents( &p ); -} - -TQMouseEvent TOM::translateMouseEvent( TQMouseEvent* e ) -{ - TQRect side = sideImageRect(); - - if ( !side.contains( e->pos() ) ) - return *e; - - TQPoint newpos( e->pos() ); - TQApplication::reverseLayout() ? - newpos.setX( newpos.x() - side.width() ) : - newpos.setX( newpos.x() + side.width() ); - TQPoint newglobal( e->globalPos() ); - TQApplication::reverseLayout() ? - newglobal.setX( newpos.x() - side.width() ) : - newglobal.setX( newpos.x() + side.width() ); - - return TQMouseEvent( e->type(), newpos, newglobal, e->button(), e->state() ); -} - -void TOM::mousePressEvent(TQMouseEvent * e) -{ - TQMouseEvent newEvent = translateMouseEvent(e); - KPanelMenu::mousePressEvent( &newEvent ); -} - -void TOM::mouseReleaseEvent(TQMouseEvent *e) -{ - TQMouseEvent newEvent = translateMouseEvent(e); - KPanelMenu::mouseReleaseEvent( &newEvent ); -} - -void TOM::mouseMoveEvent(TQMouseEvent *e) -{ - TQMouseEvent newEvent = translateMouseEvent(e); - KPanelMenu::mouseMoveEvent( &newEvent ); -}*/ - -extern int kicker_screen_number; - -void TOM::runCommand() -{ - TQByteArray data; - TQCString appname( "kdesktop" ); - if ( kicker_screen_number ) - appname.sprintf("kdesktop-screen-%d", kicker_screen_number); - - kapp->updateRemoteUserTimestamp( appname ); - kapp->dcopClient()->send( appname, "KDesktopIface", - "popupExecuteCommand()", data ); -} - -void TOM::runTask(int id) -{ - if (!m_tasks.contains(id)) return; - - kapp->propagateSessionManager(); - TDEApplication::startServiceByDesktopPath(m_tasks[id]->desktopEntryPath(), - TQStringList(), 0, 0, 0, "", true); -} - -void TOM::clearRecentDocHistory() -{ - TDERecentDocument::clear(); -} - -void TOM::openRecentDocument(int id) -{ - if (id >= 0) - { - kapp->propagateSessionManager(); - KURL u; - u.setPath(m_recentDocURLs[id]); - KDEDesktopMimeType::run(u, true); - } -} - -void TOM::logout() -{ - kapp->requestShutDown(); -} - -#include "tom.moc" diff --git a/kicker/menuext/tom/tom.cpp b/kicker/menuext/tom/tom.cpp new file mode 100644 index 000000000..0fa85a1e3 --- /dev/null +++ b/kicker/menuext/tom/tom.cpp @@ -0,0 +1,855 @@ +/* This file is part of the KDE project + Copyright (C) 2003 Aaron J. Seigo + + This program is free software; you can redistribute it and/or + modify it under the terms of the GNU General Public + License version 2 as published by the Free Software Foundation. + + This program 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 + General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program; see the file COPYING. If not, write to + the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, + Boston, MA 02110-1301, USA. +*/ + +#include +using namespace std; + +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "menuinfo.h" +#include "service_mnu.h" +#include "kicker.h" +#include "tom.h" + +const int configureMenuID = 1000; +const int contextMenuTitleID = 10000; +const int destMenuTitleID = 10001; + +extern "C" +{ + KDE_EXPORT void* init_kickermenu_tom() + { + TDEGlobal::locale()->insertCatalogue("libkickermenu_tom"); + return new TOMFactory; + } +}; + +TOMFactory::TOMFactory(TQObject *parent, const char *name) +: KLibFactory(parent, name) +{ +} + +TQObject* TOMFactory::createObject(TQObject *parent, const char *name, const char*, const TQStringList&) +{ + return new TOM((TQWidget*)parent, name); +} + +#include +/* + * TODO: switch the backgroundmode when translucency turns on/off + * TODO: catch font changes too? + */ +class runMenuWidget : public TQWidget, public QMenuItem +{ + public: + runMenuWidget(TDEPopupMenu* parent, int index) + : TQWidget (parent), + m_menu(parent), + m_index(index) + { + setFocusPolicy(StrongFocus); + + TQHBoxLayout* runLayout = new TQHBoxLayout(this); + textRect = fontMetrics().boundingRect(i18n("Run:")); + runLayout->setSpacing(KDialog::spacingHint()); + runLayout->addSpacing((KDialog::spacingHint() * 3) + TDEIcon::SizeMedium + textRect.width()); + icon = DesktopIcon("system-run", TDEIcon::SizeMedium); + /*TQLabel* l1 = new TQLabel(this); + TQPixmap foo = DesktopIcon("system-run", TDEIcon::SizeMedium); + cout << "foo is: " << foo.width() << " by " << foo.height() << endl; + l1->setPixmap(foo); + runLayout->addWidget(l1);*/ + /*TQLabel* l2 = new TQLabel(i18n("&Run: "), this); + l2->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); + l2->setBuddy(this); + runLayout->addWidget(l2);*/ + m_runEdit = new KHistoryCombo(this); + m_runEdit->setSizePolicy(TQSizePolicy::Expanding, TQSizePolicy::Preferred); + runLayout->addWidget(m_runEdit, 10); + runLayout->addSpacing(KDialog::spacingHint()); + + TQSettings settings; + if (settings.readEntry("/TDEStyle/Settings/MenuTransparencyEngine", "Disabled") != "Disabled") + { + setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); + //l1->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); + //l2->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); + m_runEdit->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); + } + else + { + /*setBackgroundMode(Qt::NoBackground, Qt::NoBackground); + l1->setBackgroundMode(Qt::NoBackground, Qt::NoBackground); + l2->setBackgroundMode(Qt::NoBackground, Qt::NoBackground); + m_runEdit->setBackgroundMode(Qt::NoBackground, Qt::NoBackground);*/ + //l1->setAutoMask(true); + //l1->setBackgroundMode(Qt::NoBackground, Qt::NoBackground); + //l2->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); + //m_runEdit->setBackgroundMode(Qt::X11ParentRelative, Qt::X11ParentRelative); + } + + setMinimumHeight(TDEIcon::SizeMedium + 2); + } + ~runMenuWidget() {} + + + void paintEvent(TQPaintEvent * /*e*/) + { + TQPainter p(this); + TQRect r(rect()); + // ew, nasty hack. may result in coredumps due to horrid C-style cast??? + kapp->style().drawControl(TQStyle::CE_PopupMenuItem, &p, m_menu, r, palette().active(), TQStyle::Style_Enabled, + TQStyleOption(static_cast(this), 0, TDEIcon::SizeMedium )); + p.drawPixmap(KDialog::spacingHint(), 1, icon); + p.drawText((KDialog::spacingHint() * 2) + TDEIcon::SizeMedium, textRect.height() + ((height() - textRect.height()) / 2), i18n("Run:")); + } + + void focusInEvent (TQFocusEvent* e) + { + if (!e || e->gotFocus()) + { + m_menu->setActiveItem(m_index); + m_runEdit->setFocus(); + } + } + + void enterEvent(TQEvent*) + { + focusInEvent(0); + } + + private: + TDEPopupMenu* m_menu; + KHistoryCombo* m_runEdit; + TQPixmap icon; + TQRect textRect; + int m_index; +}; + +TOM::TOM(TQWidget *parent, const char *name) + : KPanelMenu(parent, name), + m_maxIndex(0) +{ + disableAutoClear(); + m_submenus.setAutoDelete(true); + setCaption(i18n("Task-Oriented Menu")); + + // KMenu legacy: support some menu config options + TDEConfig* config = TDEGlobal::config(); + config->setGroup("menus"); + m_detailedTaskEntries = config->readBoolEntry("DetailedMenuEntries", false); + if (m_detailedTaskEntries) + { + m_detailedNamesFirst = config->readBoolEntry("DetailedEntriesNamesFirst", false); + } + + m_isImmutable = Kicker::kicker()->isImmutable() || config->groupIsImmutable("TOM"); + config->setGroup("TOM"); + m_largerFont = font(); + m_largerFont = config->readFontEntry("Font", &m_largerFont); +} + +TOM::~TOM() +{ + slotClear(); +} + +void TOM::initializeRecentApps(TQPopupMenu* menu) +{ + /* + * TODO: make this real + * add a KDE-wide "commands run" registry + */ + + if (!m_isImmutable) + { + menu->insertSeparator(); + menu->insertItem(i18n("Configure This Menu"), configureMenuID); + } +} + +void TOM::initializeRecentDocs() +{ + m_recentDocsMenu->clear(); + m_recentDocsMenu->insertItem(SmallIconSet("history_clear"), i18n("Clear History"), + this, TQT_SLOT(clearRecentDocHistory())); + m_recentDocsMenu->insertSeparator(); + + m_recentDocURLs = TDERecentDocument::recentDocuments(); + + if (m_recentDocURLs.isEmpty()) + { + setItemEnabled(m_recentDocsMenu->insertItem(i18n("No Entries")), false); + return; + } + + int id = 0; + for (TQStringList::ConstIterator it = m_recentDocURLs.begin(); + it != m_recentDocURLs.end(); + ++it) + { + /* + * TODO: make the number of visible items configurable? + */ + + KDesktopFile f(*it, true /* read only */); + m_recentDocsMenu->insertItem(DesktopIcon(f.readIcon(), TDEIcon::SizeMedium), + f.readName().replace('&', "&&"), id); + ++id; + } +} + +int TOM::appendTaskGroup(TDEConfig& config, bool inSubMenu) +{ + if (!config.hasGroup("General")) + { + return 0; + } + + config.setGroup("General"); + + if (config.readBoolEntry("Hidden", false)) + { + return 0; + } + + TQString name = config.readEntry("Name", i18n("Unknown")); + TQString icon = config.readEntry("Icon"); + int numTasks = config.readNumEntry("NumTasks", 0); + + if (numTasks < 1) + { + return 0; + } + + TDEPopupMenu* taskGroup; + if( inSubMenu ) + { + taskGroup = new TDEPopupMenu(this); + + if (icon != TQString::null) + { + insertItem(DesktopIcon(icon, TDEIcon::SizeMedium), name, taskGroup); + } + else + { + insertItem(name, taskGroup); + } + } + else + { + taskGroup = this; + } + + int foundTasks = 0; + for (int i = 0; i < numTasks; ++i) + { + TQString groupName = TQString("Task%1").arg(i); + + if (config.hasGroup(groupName)) + { + config.setGroup(groupName); + + if (config.readBoolEntry("Hidden", false)) + { + continue; + } + + TQString name = config.readEntry("Name"); + // in case the name contains an ampersand, double 'em up + name.replace("&", "&&"); + TQString desktopfile = config.readPathEntry("DesktopFile"); + KService::Ptr pService = KService::serviceByDesktopPath(desktopfile); + + if (!pService) + { + pService = KService::serviceByDesktopName(desktopfile); + + if (!pService) + { + continue; + } + } + + TQString execName = pService->name(); + TQString icon = pService->icon(); + + if (m_detailedTaskEntries && !execName.isEmpty()) + { + TQString tmp = i18n("%1 (%2)"); + + if (m_detailedNamesFirst) + { + name = tmp.arg(execName).arg(name); + } + else + { + name = tmp.arg(name).arg(execName); + } + } + + ++m_maxIndex; + if (icon.isEmpty()) + { + taskGroup->insertItem(name, m_maxIndex); + } + else + { + + TQIconSet iconset = BarIconSet(icon, 22); + if (iconset.isNull()) + taskGroup->insertItem(name, m_maxIndex); + else + taskGroup->insertItem(iconset, name, m_maxIndex); + + } + + m_tasks.insert(m_maxIndex, pService); + ++foundTasks; + } + } + + // if we end up with an empty task group, get rid of the menu + if (foundTasks == 0) + { + if (inSubMenu) + { + delete taskGroup; + } + + return 0; + } + + connect(taskGroup, TQT_SIGNAL(activated(int)), this, TQT_SLOT(runTask(int))); + // so we have an actual task group menu with tasks, let's add it + + if (inSubMenu) + { + TQObject::connect(taskGroup, TQT_SIGNAL(aboutToShowContextMenu(TDEPopupMenu*, int, TQPopupMenu*)), + this, TQT_SLOT(contextualizeRMBmenu(TDEPopupMenu*, int, TQPopupMenu*))); + + m_submenus.append(taskGroup); + + taskGroup->setFont(m_largerFont); + taskGroup->setKeyboardShortcutsEnabled(true); + + if (!m_isImmutable && !config.isImmutable()) + { + taskGroup->insertSeparator(); + taskGroup->insertItem("Modify These Tasks", configureMenuID); + TQPopupMenu* rmbMenu = taskGroup->contextMenu(); + rmbMenu->setFont(m_largerFont); + TDEPopupTitle* title = new TDEPopupTitle(); + title->setText(i18n("%1 Menu Editor").arg(name)); + rmbMenu->insertItem(title, contextMenuTitleID); + rmbMenu->insertItem(i18n("Add This Task to Panel")); + rmbMenu->insertItem(i18n("Modify This Task...")); + rmbMenu->insertItem(i18n("Remove This Task..."), this, TQT_SLOT(removeTask())); + rmbMenu->insertItem(i18n("Insert New Task...")); + } + } + + return foundTasks; +} +/* + * TODO: track configuration file changes. +void TOM::configChanged() +{ + KPanelMenu::configChanged(); + setInitialized(false); + initialize(); +} +*/ +void TOM::initialize() +{ + if (initialized()) + { + return; + } + + setInitialized(true); + m_submenus.clear(); + m_tasks.clear(); + clear(); + + /* hack to make items larger. should use something better? + m_largerFont = font(); + if (m_largerFont.pointSize() < 18) + { + m_largerFont.setPointSize(18); + } + setFont(m_largerFont);*/ + + + /*if (!loadSidePixmap()) + { + m_sidePixmap = m_sideTilePixmap = TQPixmap(); + } + else + { + connect(kapp, TQT_SIGNAL(tdedisplayPaletteChanged()), TQT_SLOT(paletteChanged())); + }*/ + + // TASKS + insertTitle(i18n("Tasks"), contextMenuTitleID); + + TQStringList dirs = TDEGlobal::dirs()->findDirs("data", "kicker/tom/"); + TQStringList::ConstIterator dIt = dirs.begin(); + TQStringList::ConstIterator dEnd = dirs.end(); + + for (; dIt != dEnd; ++dIt ) + { + TQDir dir(*dIt); + + TQStringList entries = dir.entryList("*rc", TQDir::Files); + TQStringList::ConstIterator eIt = entries.begin(); + TQStringList::ConstIterator eEnd = entries.end(); + + for (; eIt != eEnd; ++eIt ) + { + TDEConfig config(*dIt + *eIt); + appendTaskGroup(config); + } + } + + PanelServiceMenu* moreApps = new PanelServiceMenu(TQString::null, TQString::null, this, "More Applications"); + moreApps->setFont(m_largerFont); + insertItem(DesktopIcon("misc", TDEIcon::SizeMedium), i18n("More Applications"), moreApps); + m_submenus.append(moreApps); + + if (!m_isImmutable) + { + insertSeparator(); + // TODO: connect to taskgroup edits + insertItem("Modify The Above Tasks"); + } + + // DESTINATIONS + insertTitle(i18n("Destinations"), destMenuTitleID); + int numDests = 0; + TQString destinationsConfig = locate("appdata", "tom/destinations"); + + if (!destinationsConfig.isEmpty() && TQFile::exists(destinationsConfig)) + { + TDEConfig config(destinationsConfig); + numDests = appendTaskGroup(config, false); + } + + if (numDests == 0) + { + removeItem(destMenuTitleID); + } + else if (kapp->authorize("run_command")) + { + insertItem(DesktopIcon("system-run", TDEIcon::SizeMedium), i18n("Run Command..."), this, TQT_SLOT(runCommand())); + } + + // RECENTLY USED ITEMS + insertTitle(i18n("Recently Used Items"), contextMenuTitleID); + + m_recentDocsMenu = new TDEPopupMenu(this, "recentDocs"); + m_recentDocsMenu->setFont(m_largerFont); + connect(m_recentDocsMenu, TQT_SIGNAL(aboutToShow()), this, TQT_SLOT(initializeRecentDocs())); + connect(m_recentDocsMenu, TQT_SIGNAL(activated(int)), this, TQT_SLOT(openRecentDocument(int))); + insertItem(DesktopIcon("text-x-generic", TDEIcon::SizeMedium), i18n("Recent Documents"), m_recentDocsMenu); + m_submenus.append(m_recentDocsMenu); + + TDEPopupMenu* recentApps = new TDEPopupMenu(this, "recentApps"); + recentApps->setFont(m_largerFont); + recentApps->setKeyboardShortcutsEnabled(true); + initializeRecentApps(recentApps); + insertItem(i18n("Recent Applications"), recentApps); + m_submenus.append(recentApps); + + // SPECIAL ITEMS + insertTitle(i18n("Special Items"), contextMenuTitleID); + + // if we have no destinations, put the run command here + if (numDests == 0 && kapp->authorize("run_command")) + { + insertItem(DesktopIcon("system-run", TDEIcon::SizeMedium), i18n("Run Command..."), this, TQT_SLOT(runCommand())); + } + + + TDEConfig* config = TDEGlobal::config(); + TQStringList menu_ext = config->readListEntry("Extensions"); + if (!menu_ext.isEmpty()) + { + bool needSeparator = false; + for (TQStringList::ConstIterator it = menu_ext.begin(); it != menu_ext.end(); ++it) + { + MenuInfo info(*it); + if (!info.isValid()) + { + continue; + } + + KPanelMenu *menu = info.load(); + if (menu) + { + ++m_maxIndex; + insertItem(DesktopIcon(info.icon(), TDEIcon::SizeMedium), info.name(), menu, m_maxIndex); + m_submenus.append(menu); + needSeparator = true; + } + } + + if (needSeparator) + { + insertSeparator(); + } + } + + + TQString username; + struct passwd *userInfo = getpwuid(getuid()); + if (userInfo) + { + username = TQString::fromLocal8Bit(userInfo->pw_gecos); + if (username.find(',') != -1) + { + // Remove everything from and including first comma + username.truncate(username.find(',')); + } + + if (username.isEmpty()) + { + username = TQString::fromLocal8Bit(userInfo->pw_name); + } + } + + insertItem(DesktopIcon("system-log-out", TDEIcon::SizeMedium), + i18n("Logout %1").arg(username), this, TQT_SLOT(logout())); +} + +void TOM::reload() +{ + setInitialized(false); + initialize(); +} + +void TOM::contextualizeRMBmenu(TDEPopupMenu* menu, int menuItem, TQPopupMenu* ctxMenu) +{ + if (menuItem == configureMenuID) + { + menu->hideContextMenu(); + return; + } + + ctxMenu->removeItem(contextMenuTitleID); + TQString text = menu->text(menuItem); + int parens = text.find('(') - 1; + if (parens > 0) + { + text = text.left(parens); + } + TDEPopupTitle* title = new TDEPopupTitle(); + title->setText(i18n("The \"%2\" Task").arg(text)); + ctxMenu->insertItem(title, contextMenuTitleID, 0); +} + +void TOM::slotClear() +{ + KPanelMenu::slotClear(); + m_submenus.clear(); + m_tasks.clear(); +} + +void TOM::slotExec(int /* id */) +{ + // Reimplemented because we have to +} + +void TOM::removeTask() +{ + // TODO: write this change out to the appropriate config file + TQString task = TDEPopupMenu::contextMenuFocus()->text(TDEPopupMenu::contextMenuFocusItem()); + if (KMessageBox::warningContinueCancel(this, + i18n("Are you sure you want to remove the %1 task?

" + "Tip: You can restore the task after it has been removed by selecting the "Modify These Tasks" entry").arg(task), + i18n("Remove Task?"),KStdGuiItem::del()) == KMessageBox::Continue) + { + m_tasks.remove(TDEPopupMenu::contextMenuFocusItem()); + TDEPopupMenu::contextMenuFocus()->removeItem(TDEPopupMenu::contextMenuFocusItem()); + } +} + +// TODO: should we have a side graphic like the TDE Menu? personally, i don't +// think it helps usability. it's nice for branding, but that's it. perhaps a +// top image, or something blended with the actual menu background? deffinitely +// a job for a graphic artist. +/* + * if this goes in, it should be shared w/the kmenu + * +bool TOM::loadSidePixmap() +{ + TDEConfig *config = TDEGlobal::config(); + TQColor color = palette().active().highlight(); + TQImage image; + + config->setGroup("WM"); + TQColor activeTitle = config->readColorEntry("activeBackground", &color); + TQColor inactiveTitle = config->readColorEntry("inactiveBackground", &color); + + config->setGroup("KMenu"); + if (!config->readBoolEntry("Usem_sidePixmap", true)) + return false; + + // figure out which color is most suitable for recoloring to + int h1, s1, v1, h2, s2, v2, h3, s3, v3; + activeTitle.hsv(&h1, &s1, &v1); + inactiveTitle.hsv(&h2, &s2, &v2); + palette().active().background().hsv(&h3, &s3, &v3); + + if ( (abs(h1-h3)+abs(s1-s3)+abs(v1-v3) < abs(h2-h3)+abs(s2-s3)+abs(v2-v3)) && + ((abs(h1-h3)+abs(s1-s3)+abs(v1-v3) < 32) || (s1 < 32)) && (s2 > s1)) + color = inactiveTitle; + else + color = activeTitle; + + // limit max/min brightness + int r, g, b; + color.rgb(&r, &g, &b); + int gray = tqGray(r, g, b); + if (gray > 180) { + r = (r - (gray - 180) < 0 ? 0 : r - (gray - 180)); + g = (g - (gray - 180) < 0 ? 0 : g - (gray - 180)); + b = (b - (gray - 180) < 0 ? 0 : b - (gray - 180)); + } else if (gray < 76) { + r = (r + (76 - gray) > 255 ? 255 : r + (76 - gray)); + g = (g + (76 - gray) > 255 ? 255 : g + (76 - gray)); + b = (b + (76 - gray) > 255 ? 255 : b + (76 - gray)); + } + color.setRgb(r, g, b); + + TQString sideName = config->readEntry("SideName", "kside.png"); + TQString sideTileName = config->readEntry("SideTileName", "kside_tile.png"); + + image.load(locate("data", "kicker/pics/" + sideName)); + + if (image.isNull()) + { + return false; + } + + TDEIconEffect::colorize(image, color, 1.0); + m_sidePixmap.convertFromImage(image); + + image.load(locate("data", "kicker/pics/" + sideTileName)); + + if (image.isNull()) + { + return false; + } + + TDEIconEffect::colorize(image, color, 1.0); + m_sideTilePixmap.convertFromImage(image); + + if (m_sidePixmap.width() != m_sideTilePixmap.width()) + { + return false; + } + + // pretile the pixmap to a height of at least 100 pixels + if (m_sideTilePixmap.height() < 100) + { + int tiles = (int)(100 / m_sideTilePixmap.height()) + 1; + TQPixmap preTiledPixmap(m_sideTilePixmap.width(), m_sideTilePixmap.height() * tiles); + TQPainter p(&preTiledPixmap); + p.drawTiledPixmap(preTiledPixmap.rect(), m_sideTilePixmap); + m_sideTilePixmap = preTiledPixmap; + } + + return true; +} + +void TOM::paletteChanged() +{ + if (!loadSidePixmap()) + m_sidePixmap = m_sideTilePixmap = TQPixmap(); +} + +void TOM::setMinimumSize(const TQSize & s) +{ + KPanelMenu::setMinimumSize(s.width() + m_sidePixmap.width(), s.height()); +} + +void TOM::setMaximumSize(const TQSize & s) +{ + KPanelMenu::setMaximumSize(s.width() + m_sidePixmap.width(), s.height()); +} + +void TOM::setMinimumSize(int w, int h) +{ + KPanelMenu::setMinimumSize(w + m_sidePixmap.width(), h); +} + +void TOM::setMaximumSize(int w, int h) +{ + KPanelMenu::setMaximumSize(w + m_sidePixmap.width(), h); +} + +TQRect TOM::sideImageRect() +{ + return TQStyle::visualRect( TQRect( frameWidth(), frameWidth(), m_sidePixmap.width(), + height() - 2*frameWidth() ), this ); +} + +void TOM::resizeEvent(TQResizeEvent * e) +{ + setFrameRect( TQStyle::visualRect( TQRect( m_sidePixmap.width(), 0, + width() - m_sidePixmap.width(), height() ), this ) ); +} + +void TOM::paintEvent(TQPaintEvent * e) +{ + if (m_sidePixmap.isNull()) { + KPanelMenu::paintEvent(e); + return; + } + + TQPainter p(this); + + style().tqdrawPrimitive( TQStyle::PE_PanelPopup, &p, + TQRect( 0, 0, width(), height() ), + colorGroup(), TQStyle::Style_Default, + TQStyleOption( frameWidth(), 0 ) ); + + TQRect r = sideImageRect(); + r.setBottom( r.bottom() - m_sidePixmap.height() ); + p.drawTiledPixmap( r, m_sideTilePixmap ); + + r = sideImageRect(); + r.setTop( r.bottom() - m_sidePixmap.height() ); + p.drawPixmap( r, m_sidePixmap ); + + drawContents( &p ); +} + +TQMouseEvent TOM::translateMouseEvent( TQMouseEvent* e ) +{ + TQRect side = sideImageRect(); + + if ( !side.contains( e->pos() ) ) + return *e; + + TQPoint newpos( e->pos() ); + TQApplication::reverseLayout() ? + newpos.setX( newpos.x() - side.width() ) : + newpos.setX( newpos.x() + side.width() ); + TQPoint newglobal( e->globalPos() ); + TQApplication::reverseLayout() ? + newglobal.setX( newpos.x() - side.width() ) : + newglobal.setX( newpos.x() + side.width() ); + + return TQMouseEvent( e->type(), newpos, newglobal, e->button(), e->state() ); +} + +void TOM::mousePressEvent(TQMouseEvent * e) +{ + TQMouseEvent newEvent = translateMouseEvent(e); + KPanelMenu::mousePressEvent( &newEvent ); +} + +void TOM::mouseReleaseEvent(TQMouseEvent *e) +{ + TQMouseEvent newEvent = translateMouseEvent(e); + KPanelMenu::mouseReleaseEvent( &newEvent ); +} + +void TOM::mouseMoveEvent(TQMouseEvent *e) +{ + TQMouseEvent newEvent = translateMouseEvent(e); + KPanelMenu::mouseMoveEvent( &newEvent ); +}*/ + +extern int kicker_screen_number; + +void TOM::runCommand() +{ + TQByteArray data; + TQCString appname( "kdesktop" ); + if ( kicker_screen_number ) + appname.sprintf("kdesktop-screen-%d", kicker_screen_number); + + kapp->updateRemoteUserTimestamp( appname ); + kapp->dcopClient()->send( appname, "KDesktopIface", + "popupExecuteCommand()", data ); +} + +void TOM::runTask(int id) +{ + if (!m_tasks.contains(id)) return; + + kapp->propagateSessionManager(); + TDEApplication::startServiceByDesktopPath(m_tasks[id]->desktopEntryPath(), + TQStringList(), 0, 0, 0, "", true); +} + +void TOM::clearRecentDocHistory() +{ + TDERecentDocument::clear(); +} + +void TOM::openRecentDocument(int id) +{ + if (id >= 0) + { + kapp->propagateSessionManager(); + KURL u; + u.setPath(m_recentDocURLs[id]); + KDEDesktopMimeType::run(u, true); + } +} + +void TOM::logout() +{ + kapp->requestShutDown(); +} + +#include "tom.moc" -- cgit v1.2.3