Merge remote-tracking branch 'origin/KDE/4.7'

Conflicts:
	experimental/libkactivities
This commit is contained in:
David Faure 2011-12-20 11:16:18 +01:00
commit 3f743186cf
43 changed files with 499 additions and 277 deletions

View File

@ -151,6 +151,7 @@ set(plasma_LIB_SRCS
private/storage.cpp private/storage.cpp
private/storagethread.cpp private/storagethread.cpp
private/style.cpp private/style.cpp
private/themedwidgetinterface.cpp
private/trustedonlyauthorization.cpp private/trustedonlyauthorization.cpp
private/tooltip.cpp private/tooltip.cpp
private/wallpaperrenderthread.cpp private/wallpaperrenderthread.cpp
@ -461,8 +462,6 @@ install(FILES
install(FILES data/knewstuff/plasmoids.knsrc DESTINATION ${CONFIG_INSTALL_DIR}) install(FILES data/knewstuff/plasmoids.knsrc DESTINATION ${CONFIG_INSTALL_DIR})
install(FILES data/kconfig_updates/plasma_popupapplet_fix_groups.upd DESTINATION ${KCONF_UPDATE_INSTALL_DIR})
install(PROGRAMS data/kconfig_updates/plasma_popupapplet_fix_groups.pl DESTINATION ${KCONF_UPDATE_INSTALL_DIR})
install(FILES data/operations/dataengineservice.operations DESTINATION ${DATA_INSTALL_DIR}/plasma/services) install(FILES data/operations/dataengineservice.operations DESTINATION ${DATA_INSTALL_DIR}/plasma/services)
install(FILES data/operations/plasmoidservice.operations DESTINATION ${DATA_INSTALL_DIR}/plasma/services) install(FILES data/operations/plasmoidservice.operations DESTINATION ${DATA_INSTALL_DIR}/plasma/services)
install(FILES data/operations/storage.operations DESTINATION ${DATA_INSTALL_DIR}/plasma/services) install(FILES data/operations/storage.operations DESTINATION ${DATA_INSTALL_DIR}/plasma/services)

View File

@ -58,22 +58,19 @@ AbstractToolBox::~AbstractToolBox()
AbstractToolBox *AbstractToolBox::load(const QString &name, const QVariantList &args, Plasma::Containment *containment) AbstractToolBox *AbstractToolBox::load(const QString &name, const QVariantList &args, Plasma::Containment *containment)
{ {
const QString constraint = QString("[X-KDE-PluginInfo-Name] == '%1'").arg(name); const QString constraint = name.isEmpty() ? QString() : QString("[X-KDE-PluginInfo-Name] == '%1'").arg(name);
KService::List offers = KServiceTypeTrader::self()->query("Plasma/ToolBox", constraint); KService::List offers = KServiceTypeTrader::self()->query("Plasma/ToolBox", constraint);
if (!offers.isEmpty()) { if (!offers.isEmpty()) {
KService::Ptr offer = offers.first(); KService::Ptr offer = offers.first();
KPluginLoader plugin(*offer); KPluginLoader plugin(*offer);
if (Plasma::isPluginVersionCompatible(plugin.pluginVersion())) {
if (!Plasma::isPluginVersionCompatible(plugin.pluginVersion())) { return offer->createInstance<AbstractToolBox>(containment, args);
return 0;
} }
return offer->createInstance<AbstractToolBox>(containment, args);
} else {
return 0;
} }
return 0;
} }
KPluginInfo::List AbstractToolBox::listToolBoxInfo(const QString KPluginInfo::List AbstractToolBox::listToolBoxInfo(const QString

View File

@ -1567,6 +1567,8 @@ void Applet::setGlobalShortcut(const KShortcut &shortcut)
foreach (QWidget *w, widgets) { foreach (QWidget *w, widgets) {
w->addAction(d->activationAction); w->addAction(d->activationAction);
} }
} else if (d->activationAction->globalShortcut() == shortcut) {
return;
} }
//kDebug() << "before" << shortcut.primary() << d->activationAction->globalShortcut().primary(); //kDebug() << "before" << shortcut.primary() << d->activationAction->globalShortcut().primary();
@ -1900,6 +1902,11 @@ void Applet::showConfigurationInterface()
KConfigSkeleton *configLoader = d->configLoader ? d->configLoader : new KConfigSkeleton(0); KConfigSkeleton *configLoader = d->configLoader ? d->configLoader : new KConfigSkeleton(0);
dialog = new AppletConfigDialog(0, d->configDialogId(), configLoader); dialog = new AppletConfigDialog(0, d->configDialogId(), configLoader);
if (!d->configLoader) {
// delete the temporary when this dialog is done
configLoader->setParent(dialog);
}
dialog->setWindowTitle(d->configWindowTitle()); dialog->setWindowTitle(d->configWindowTitle());
dialog->setAttribute(Qt::WA_DeleteOnClose, true); dialog->setAttribute(Qt::WA_DeleteOnClose, true);
bool hasPages = false; bool hasPages = false;
@ -1916,6 +1923,7 @@ void Applet::showConfigurationInterface()
#ifndef PLASMA_NO_KUTILS #ifndef PLASMA_NO_KUTILS
KCModuleProxy *module = new KCModuleProxy(kcm); KCModuleProxy *module = new KCModuleProxy(kcm);
if (module->realModule()) { if (module->realModule()) {
connect(module, SIGNAL(changed(bool)), dialog, SLOT(settingsModified(bool)));
dialog->addPage(module, module->moduleInfo().moduleName(), module->moduleInfo().icon()); dialog->addPage(module, module->moduleInfo().moduleName(), module->moduleInfo().icon());
hasPages = true; hasPages = true;
} else { } else {
@ -2016,14 +2024,15 @@ KConfigDialog *AppletPrivate::generateGenericConfigDialog()
{ {
KConfigSkeleton *nullManager = new KConfigSkeleton(0); KConfigSkeleton *nullManager = new KConfigSkeleton(0);
KConfigDialog *dialog = new AppletConfigDialog(0, configDialogId(), nullManager); KConfigDialog *dialog = new AppletConfigDialog(0, configDialogId(), nullManager);
nullManager->setParent(dialog);
dialog->setFaceType(KPageDialog::Auto); dialog->setFaceType(KPageDialog::Auto);
dialog->setWindowTitle(configWindowTitle()); dialog->setWindowTitle(configWindowTitle());
dialog->setAttribute(Qt::WA_DeleteOnClose, true); dialog->setAttribute(Qt::WA_DeleteOnClose, true);
q->createConfigurationInterface(dialog); q->createConfigurationInterface(dialog);
dialog->showButton(KDialog::Default, false); dialog->showButton(KDialog::Default, false);
dialog->showButton(KDialog::Help, false);
QObject::connect(dialog, SIGNAL(applyClicked()), q, SLOT(configDialogFinished())); QObject::connect(dialog, SIGNAL(applyClicked()), q, SLOT(configDialogFinished()));
QObject::connect(dialog, SIGNAL(okClicked()), q, SLOT(configDialogFinished())); QObject::connect(dialog, SIGNAL(okClicked()), q, SLOT(configDialogFinished()));
QObject::connect(dialog, SIGNAL(finished()), nullManager, SLOT(deleteLater()));
return dialog; return dialog;
} }
@ -2045,11 +2054,11 @@ void AppletPrivate::addGlobalShortcutsPage(KConfigDialog *dialog)
if (!shortcutEditor) { if (!shortcutEditor) {
shortcutEditor = new KKeySequenceWidget(page); shortcutEditor = new KKeySequenceWidget(page);
QObject::connect(shortcutEditor, SIGNAL(destroyed(QObject*)), q, SLOT(clearShortcutEditorPtr())); QObject::connect(shortcutEditor.data(), SIGNAL(keySequenceChanged(QKeySequence)), dialog, SLOT(settingsModified()));
} }
shortcutEditor->setKeySequence(q->globalShortcut().primary()); shortcutEditor.data()->setKeySequence(q->globalShortcut().primary());
layout->addWidget(shortcutEditor); layout->addWidget(shortcutEditor.data());
layout->addStretch(); layout->addStretch();
dialog->addPage(page, i18n("Keyboard Shortcut"), "preferences-desktop-keyboard"); dialog->addPage(page, i18n("Keyboard Shortcut"), "preferences-desktop-keyboard");
@ -2064,7 +2073,9 @@ void AppletPrivate::addPublishPage(KConfigDialog *dialog)
QWidget *page = new QWidget; QWidget *page = new QWidget;
publishUI.setupUi(page); publishUI.setupUi(page);
publishUI.publishCheckbox->setChecked(q->isPublished()); publishUI.publishCheckbox->setChecked(q->isPublished());
QObject::connect(publishUI.publishCheckbox, SIGNAL(clicked(bool)), dialog, SLOT(settingsModified()));
publishUI.allUsersCheckbox->setEnabled(q->isPublished()); publishUI.allUsersCheckbox->setEnabled(q->isPublished());
QObject::connect(publishUI.allUsersCheckbox, SIGNAL(clicked(bool)), dialog, SLOT(settingsModified()));
QString resourceName = QString resourceName =
i18nc("%1 is the name of a plasmoid, %2 the name of the machine that plasmoid is published on", i18nc("%1 is the name of a plasmoid, %2 the name of the machine that plasmoid is published on",
@ -2090,15 +2101,10 @@ void AppletPrivate::publishCheckboxStateChanged(int state)
} }
} }
void AppletPrivate::clearShortcutEditorPtr()
{
shortcutEditor = 0;
}
void AppletPrivate::configDialogFinished() void AppletPrivate::configDialogFinished()
{ {
if (shortcutEditor) { if (shortcutEditor) {
QKeySequence sequence = shortcutEditor->keySequence(); QKeySequence sequence = shortcutEditor.data()->keySequence();
if (sequence != q->globalShortcut().primary()) { if (sequence != q->globalShortcut().primary()) {
q->setGlobalShortcut(KShortcut(sequence)); q->setGlobalShortcut(KShortcut(sequence));
emit q->configNeedsSaving(); emit q->configNeedsSaving();
@ -2172,11 +2178,6 @@ void AppletPrivate::updateShortcuts()
void AppletPrivate::propagateConfigChanged() void AppletPrivate::propagateConfigChanged()
{ {
if (script && configLoader) {
configLoader->readConfig();
script->configChanged();
}
if (isContainment) { if (isContainment) {
Containment *c = qobject_cast<Containment *>(q); Containment *c = qobject_cast<Containment *>(q);
if (c) { if (c) {
@ -2189,6 +2190,12 @@ void AppletPrivate::propagateConfigChanged()
void Applet::configChanged() void Applet::configChanged()
{ {
if (d->script) {
if (d->configLoader) {
d->configLoader->readConfig();
}
d->script->configChanged();
}
} }
void Applet::createConfigurationInterface(KConfigDialog *parent) void Applet::createConfigurationInterface(KConfigDialog *parent)
@ -2515,7 +2522,7 @@ QSizeF Applet::sizeHint(Qt::SizeHint which, const QSizeF &constraint) const
} }
} else if (d->aspectRatioMode == Plasma::ConstrainedSquare) { } else if (d->aspectRatioMode == Plasma::ConstrainedSquare) {
//enforce a size not wider than tall //enforce a size not wider than tall
if (ff == Horizontal && (which == Qt::MaximumSize || size().height() <= KIconLoader::SizeLarge)) { if (ff == Horizontal) {
hint.setWidth(size().height()); hint.setWidth(size().height());
//enforce a size not taller than wide //enforce a size not taller than wide
} else if (ff == Vertical && (which == Qt::MaximumSize || size().width() <= KIconLoader::SizeLarge)) { } else if (ff == Vertical && (which == Qt::MaximumSize || size().width() <= KIconLoader::SizeLarge)) {
@ -2657,7 +2664,6 @@ AppletPrivate::AppletPrivate(KService::Ptr service, const KPluginInfo *info, int
configLoader(0), configLoader(0),
actions(AppletPrivate::defaultActions(applet)), actions(AppletPrivate::defaultActions(applet)),
activationAction(0), activationAction(0),
shortcutEditor(0),
itemStatus(UnknownStatus), itemStatus(UnknownStatus),
preferredSizePolicy(QSizePolicy::Ignored, QSizePolicy::Ignored), preferredSizePolicy(QSizePolicy::Ignored, QSizePolicy::Ignored),
modificationsTimer(0), modificationsTimer(0),

View File

@ -1118,7 +1118,6 @@ class PLASMA_EXPORT Applet : public QGraphicsWidget
Q_PRIVATE_SLOT(d, void selectItemToDestroy()) Q_PRIVATE_SLOT(d, void selectItemToDestroy())
Q_PRIVATE_SLOT(d, void updateRect(const QRectF& rect)) Q_PRIVATE_SLOT(d, void updateRect(const QRectF& rect))
Q_PRIVATE_SLOT(d, void destroyMessageOverlay()) Q_PRIVATE_SLOT(d, void destroyMessageOverlay())
Q_PRIVATE_SLOT(d, void clearShortcutEditorPtr())
Q_PRIVATE_SLOT(d, void configDialogFinished()) Q_PRIVATE_SLOT(d, void configDialogFinished())
Q_PRIVATE_SLOT(d, void updateShortcuts()) Q_PRIVATE_SLOT(d, void updateShortcuts())
Q_PRIVATE_SLOT(d, void publishCheckboxStateChanged(int state)) Q_PRIVATE_SLOT(d, void publishCheckboxStateChanged(int state))

View File

@ -160,7 +160,7 @@ void Containment::init()
setCacheMode(NoCache); setCacheMode(NoCache);
setFlag(QGraphicsItem::ItemIsMovable, false); setFlag(QGraphicsItem::ItemIsMovable, false);
setFlag(QGraphicsItem::ItemClipsChildrenToShape, false); setFlag(QGraphicsItem::ItemClipsChildrenToShape, true);
setAcceptDrops(true); setAcceptDrops(true);
setAcceptsHoverEvents(true); setAcceptsHoverEvents(true);

View File

@ -113,7 +113,7 @@ void Corona::saveLayout(const QString &configName) const
if (configName.isEmpty() || configName == d->configName) { if (configName.isEmpty() || configName == d->configName) {
c = config(); c = config();
} else { } else {
c = KSharedConfig::openConfig(configName); c = KSharedConfig::openConfig(configName, KConfig::SimpleConfig);
} }
d->saveLayout(c); d->saveLayout(c);
@ -337,7 +337,7 @@ void Corona::clearContainments()
KSharedConfigPtr Corona::config() const KSharedConfigPtr Corona::config() const
{ {
if (!d->config) { if (!d->config) {
d->config = KSharedConfig::openConfig(d->configName); d->config = KSharedConfig::openConfig(d->configName, KConfig::SimpleConfig);
} }
return d->config; return d->config;
@ -482,7 +482,7 @@ QPoint Corona::popupPosition(const QGraphicsItem *item, const QSize &s, Qt::Alig
} }
} }
kDebug() << actualItem; //kDebug() << actualItem;
if (actualItem) { if (actualItem) {
v = viewFor(actualItem); v = viewFor(actualItem);
@ -618,6 +618,7 @@ QPoint Corona::popupPosition(const QGraphicsItem *item, const QSize &s, Qt::Alig
} }
pos.rx() = qMax(0, pos.x()); pos.rx() = qMax(0, pos.x());
pos.ry() = qMax(0, pos.y());
return pos; return pos;
} }

View File

@ -1,9 +0,0 @@
#!/usr/bin/perl
while(<>) {
if ($_ =~ m/^\[.*\[Configuration\]\[PopupApplet\]$/) {
print "# DELETEGROUP $_";
$_ =~ s/\[Configuration\]\[PopupApplet\]$/[PopupApplet]/;
}
print $_;
}

View File

@ -1,12 +0,0 @@
# Fix groups of the form ...[Configuration][PopupApplet] into ...[PopupApplet]
Id=PlasmaPopupAppletFixGroups1
File=plasma-appletsrc
Script=plasma_popupapplet_fix_groups.pl,perl
#
Id=PlasmaPopupAppletFixGroups2
File=plasmarc
Script=plasma_popupapplet_fix_groups.pl,perl
#
Id=PlasmaPopupAppletFixGroups3
File=plasmoidviewer-appletsrc
Script=plasma_popupapplet_fix_groups.pl,perl

View File

@ -39,6 +39,7 @@ Description[pt]=Um protocolo para os serviços do Plasma
Description[pt_BR]=Protocolo para os serviços do Plasma Description[pt_BR]=Protocolo para os serviços do Plasma
Description[ro]=Un protocol pentru servicii Plasma Description[ro]=Un protocol pentru servicii Plasma
Description[ru]=Протокол для служб Plasma Description[ru]=Протокол для служб Plasma
Description[se]=Protokolla Plasma-bálvalusaid várás
Description[sk]=Protokol pre Plasma služby Description[sk]=Protokol pre Plasma služby
Description[sr]=Протокол за плазма сервисе Description[sr]=Протокол за плазма сервисе
Description[sr@ijekavian]=Протокол за плазма сервисе Description[sr@ijekavian]=Протокол за плазма сервисе

View File

@ -38,6 +38,7 @@ Comment[pt]=Serviço do Plasma
Comment[pt_BR]=Serviço do Plasma Comment[pt_BR]=Serviço do Plasma
Comment[ro]=Servicu Plasma Comment[ro]=Servicu Plasma
Comment[ru]=Служба Plasma Comment[ru]=Служба Plasma
Comment[se]=Plasma-bálvalus
Comment[si]= Comment[si]=
Comment[sk]=Služba Plasma Comment[sk]=Služba Plasma
Comment[sr]=Плазма сервис Comment[sr]=Плазма сервис

View File

@ -490,8 +490,27 @@ void Dialog::mouseMoveEvent(QMouseEvent *event)
break; break;
} }
if ((newWidth >= minimumSize().width()) && (newHeight >= minimumSize().height())) { QRect newGeom(position, QSize(newWidth, newHeight));
setGeometry(QRect(position, QSize(newWidth, newHeight)));
// now sanity check the resize results again min constraints, if any
if (d->leftResizeMin > -1 && newGeom.left() > d->leftResizeMin) {
newGeom.setLeft(d->leftResizeMin);
}
if (d->topResizeMin > -1 && newGeom.top() > d->topResizeMin) {
newGeom.setTop(d->topResizeMin);
}
if (d->rightResizeMin > -1 && newGeom.right() < d->rightResizeMin) {
newGeom.setRight(d->rightResizeMin);
}
if (d->bottomResizeMin > -1 && newGeom.bottom() < d->bottomResizeMin) {
newGeom.setBottom(d->bottomResizeMin);
}
if ((newGeom.width() >= minimumSize().width()) && (newGeom.height() >= minimumSize().height())) {
setGeometry(newGeom);
} }
} }
@ -518,9 +537,9 @@ void Dialog::mousePressEvent(QMouseEvent *event)
void Dialog::mouseReleaseEvent(QMouseEvent *event) void Dialog::mouseReleaseEvent(QMouseEvent *event)
{ {
if (d->resizeStartCorner != Dialog::NoCorner) { if (d->resizeStartCorner != Dialog::NoCorner) {
emit dialogResized();
d->resizeStartCorner = Dialog::NoCorner; d->resizeStartCorner = Dialog::NoCorner;
unsetCursor(); unsetCursor();
emit dialogResized();
} }
QWidget::mouseReleaseEvent(event); QWidget::mouseReleaseEvent(event);
@ -535,12 +554,6 @@ void Dialog::keyPressEvent(QKeyEvent *event)
bool Dialog::event(QEvent *event) bool Dialog::event(QEvent *event)
{ {
if (event->type() == QEvent::Paint) {
QPainter p(this);
p.setCompositionMode(QPainter::CompositionMode_Source);
p.fillRect(rect(), Qt::transparent);
}
return QWidget::event(event); return QWidget::event(event);
} }
@ -751,13 +764,45 @@ Dialog::ResizeCorners Dialog::resizeCorners() const
return d->resizeCorners; return d->resizeCorners;
} }
bool Dialog::isUserResizing() const
{
return d->resizeStartCorner > NoCorner;
}
void Dialog::setMinimumResizeLimits(int left, int top, int right, int bottom)
{
d->leftResizeMin = left;
d->topResizeMin = top;
d->rightResizeMin = right;
d->bottomResizeMin = bottom;
}
void Dialog::getMinimumResizeLimits(int *left, int *top, int *right, int *bottom)
{
if (left) {
*left = d->leftResizeMin;
}
if (top) {
*top = d->topResizeMin;
}
if (right) {
*right = d->rightResizeMin;
}
if (bottom) {
*bottom = d->bottomResizeMin;
}
}
void Dialog::animatedHide(Plasma::Direction direction) void Dialog::animatedHide(Plasma::Direction direction)
{ {
if (!isVisible()) { if (!isVisible()) {
return; return;
} }
if (!KWindowSystem::compositingActive()) { if (!Plasma::Theme::defaultTheme()->windowTranslucencyEnabled()) {
hide(); hide();
return; return;
} }
@ -786,7 +831,7 @@ void Dialog::animatedHide(Plasma::Direction direction)
void Dialog::animatedShow(Plasma::Direction direction) void Dialog::animatedShow(Plasma::Direction direction)
{ {
if (!KWindowSystem::compositingActive()) { if (!Plasma::Theme::defaultTheme()->windowTranslucencyEnabled()) {
show(); show();
return; return;
} }
@ -810,7 +855,7 @@ void Dialog::animatedShow(Plasma::Direction direction)
break; break;
} }
if (KWindowSystem::compositingActive()) { if (Plasma::Theme::defaultTheme()->windowTranslucencyEnabled()) {
Plasma::WindowEffects::slideWindow(this, location); Plasma::WindowEffects::slideWindow(this, location);
} }

View File

@ -97,6 +97,31 @@ class PLASMA_EXPORT Dialog : public QWidget
*/ */
ResizeCorners resizeCorners() const; ResizeCorners resizeCorners() const;
/**
* @return true if currently being resized by the user
*/
bool isUserResizing() const;
/**
* Sets the minimum values that each of four sides of the rect may expand to or from
*
* @param left the screen coordinate that the left may not go beyond; -1 for no limit
* @param top the screen coordinate that the top may not go beyond; -1 for no limit
* @param right the screen coordinate that the right may not go beyond; -1 for no limit
* @param bottom the screen coordinate that the bottom may not go beyond; -1 for no limit
*/
void setMinimumResizeLimits(int left, int top, int right, int bottom);
/**
* Retrives the minimum resize limits for the dialog
*
* @param left the screen coordinate that the left may not go beyond; -1 for no limit
* @param top the screen coordinate that the top may not go beyond; -1 for no limit
* @param right the screen coordinate that the right may not go beyond; -1 for no limit
* @param bottom the screen coordinate that the bottom may not go beyond; -1 for no limit
*/
void getMinimumResizeLimits(int *left, int *top, int *right, int *bottom);
/** /**
* Causes an animated hide; requires compositing to work, otherwise * Causes an animated hide; requires compositing to work, otherwise
* the dialog will simply hide. * the dialog will simply hide.

View File

@ -509,7 +509,8 @@ bool Package::installPackage(const QString &package,
if (mimetype->is("application/zip")) { if (mimetype->is("application/zip")) {
archive = new KZip(package); archive = new KZip(package);
} else if (mimetype->is("application/x-compressed-tar") || } else if (mimetype->is("application/x-compressed-tar") ||
mimetype->is("application/x-tar")|| mimetype->is("application/x-bzip-compressed-tar")) { mimetype->is("application/x-tar")|| mimetype->is("application/x-bzip-compressed-tar") ||
mimetype->is("application/x-xz") || mimetype->is("application/x-lzma")) {
archive = new KTar(package); archive = new KTar(package);
} else { } else {
kWarning() << "Could not open package file, unsupported archive format:" << package << mimetype->name(); kWarning() << "Could not open package file, unsupported archive format:" << package << mimetype->name();

View File

@ -94,7 +94,9 @@ void PackageMetadata::write(const QString &filename) const
config.writeEntry("Icon", d->icon); config.writeEntry("Icon", d->icon);
config.writeEntry("Comment", d->description); config.writeEntry("Comment", d->description);
config.writeEntry("Keywords", d->keywords); config.writeEntry("Keywords", d->keywords);
config.deleteEntry("X-KDE-Keywords");
config.writeEntry("X-KDE-ServiceTypes", d->serviceType); config.writeEntry("X-KDE-ServiceTypes", d->serviceType);
config.deleteEntry("ServiceTypes");
config.writeEntry("X-KDE-PluginInfo-Name", d->pluginName); config.writeEntry("X-KDE-PluginInfo-Name", d->pluginName);
config.writeEntry("X-KDE-PluginInfo-Author", d->author); config.writeEntry("X-KDE-PluginInfo-Author", d->author);
config.writeEntry("X-KDE-PluginInfo-Email", d->email); config.writeEntry("X-KDE-PluginInfo-Email", d->email);
@ -120,8 +122,27 @@ void PackageMetadata::read(const QString &filename)
d->name = config.readEntry("Name", d->name); d->name = config.readEntry("Name", d->name);
d->icon = config.readEntry("Icon", d->icon); d->icon = config.readEntry("Icon", d->icon);
d->description = config.readEntry("Comment", d->description); d->description = config.readEntry("Comment", d->description);
d->keywords = config.readEntry("Keywords", d->keywords); bool hasKeywords = config.hasKey("Keywords");
d->serviceType = config.readEntry("X-KDE-ServiceTypes", d->serviceType); bool hasXKdeKeywords = config.hasKey("X-KDE-Keywords");
if (hasKeywords && hasXKdeKeywords) {
d->keywords = config.readEntry("Keywords", d->keywords);
d->keywords.append(config.readEntry("X-KDE-Keywords", d->keywords));
} else if (hasKeywords) {
d->keywords = config.readEntry("Keywords", d->keywords);
} else if (hasXKdeKeywords) {
d->keywords = config.readEntry("X-KDE-Keywords", d->keywords);
}
bool hasServiceTypes = config.hasKey("ServiceTypes");
bool hasXKdeServiceTypes = config.hasKey("X-KDE-ServiceTypes");
if (hasServiceTypes && hasXKdeServiceTypes) {
d->serviceType = config.readEntry("ServiceTypes", d->serviceType);
d->serviceType.append(',');
d->serviceType.append(config.readEntry("X-KDE-ServiceTypes", d->serviceType));
} else if (hasServiceTypes) {
d->serviceType = config.readEntry("ServiceTypes", d->serviceType);
} else if (hasXKdeServiceTypes) {
d->serviceType = config.readEntry("X-KDE-ServiceTypes", d->serviceType);
}
d->pluginName = config.readEntry("X-KDE-PluginInfo-Name", d->pluginName); d->pluginName = config.readEntry("X-KDE-PluginInfo-Name", d->pluginName);
d->author = config.readEntry("X-KDE-PluginInfo-Author", d->author); d->author = config.readEntry("X-KDE-PluginInfo-Author", d->author);
d->email = config.readEntry("X-KDE-PluginInfo-Email", d->email); d->email = config.readEntry("X-KDE-PluginInfo-Email", d->email);

View File

@ -614,7 +614,7 @@ PackageMetadata PackageStructure::metadata()
if (mimetype->is("application/zip")) { if (mimetype->is("application/zip")) {
archive = new KZip(d->path); archive = new KZip(d->path);
} else if (mimetype->is("application/x-compressed-tar") || } else if (mimetype->is("application/x-compressed-tar") || mimetype->is("application/x-gzip") ||
mimetype->is("application/x-tar")|| mimetype->is("application/x-bzip-compressed-tar")) { mimetype->is("application/x-tar")|| mimetype->is("application/x-bzip-compressed-tar")) {
archive = new KTar(d->path); archive = new KTar(d->path);
} else { } else {

View File

@ -446,7 +446,6 @@ QSizeF PopupApplet::sizeHint(Qt::SizeHint which, const QSizeF & constraint) cons
case Horizontal: { case Horizontal: {
const int size = IconSize(KIconLoader::Panel); const int size = IconSize(KIconLoader::Panel);
return QSizeF(size, size); return QSizeF(size, size);
break;
} }
default: default:
break; break;
@ -601,6 +600,9 @@ void PopupApplet::timerEvent(QTimerEvent *event)
d->autohideTimer->stop(); d->autohideTimer->stop();
} }
} }
} else if (event->timerId() == d->showDialogTimer.timerId()) {
d->showDialogTimer.stop();
d->showDialog();
} else { } else {
Applet::timerEvent(event); Applet::timerEvent(event);
} }
@ -608,6 +610,7 @@ void PopupApplet::timerEvent(QTimerEvent *event)
void PopupApplet::hidePopup() void PopupApplet::hidePopup()
{ {
d->showDialogTimer.stop();
d->delayedShowTimer.stop(); d->delayedShowTimer.stop();
Dialog *dialog = d->dialogPtr.data(); Dialog *dialog = d->dialogPtr.data();
@ -749,24 +752,34 @@ void PopupAppletPrivate::internalTogglePopup(bool fromActivatedSignal)
} }
ToolTipManager::self()->hide(q); ToolTipManager::self()->hide(q);
updateDialogPosition(); showDialogTimer.start(0, q);
}
}
KWindowSystem::setOnAllDesktops(dialog->winId(), true); void PopupAppletPrivate::showDialog()
KWindowSystem::setState(dialog->winId(), NET::SkipTaskbar | NET::SkipPager); {
Plasma::Dialog *dialog = dialogPtr.data();
if (!dialog) {
return;
}
if (icon) { updateDialogPosition();
dialog->setAspectRatioMode(savedAspectRatio);
}
if (q->location() != Floating) { KWindowSystem::setOnAllDesktops(dialog->winId(), true);
dialog->animatedShow(locationToDirection(q->location())); KWindowSystem::setState(dialog->winId(), NET::SkipTaskbar | NET::SkipPager);
} else {
dialog->show();
}
if (!(dialog->windowFlags() & Qt::X11BypassWindowManagerHint)) { if (icon) {
KWindowSystem::activateWindow(dialog->winId()); dialog->setAspectRatioMode(savedAspectRatio);
} }
if (q->location() != Floating) {
dialog->animatedShow(locationToDirection(q->location()));
} else {
dialog->show();
}
if (!(dialog->windowFlags() & Qt::X11BypassWindowManagerHint)) {
KWindowSystem::activateWindow(dialog->winId());
} }
} }
@ -800,7 +813,7 @@ void PopupAppletPrivate::dialogSizeChanged()
sizeGroup.writeEntry("DialogHeight", dialog->height()); sizeGroup.writeEntry("DialogHeight", dialog->height());
sizeGroup.writeEntry("DialogWidth", dialog->width()); sizeGroup.writeEntry("DialogWidth", dialog->width());
updateDialogPosition(); updateDialogPosition(!dialog->isUserResizing());
emit q->configNeedsSaving(); emit q->configNeedsSaving();
emit q->appletTransformedByUser(); emit q->appletTransformedByUser();
@ -890,7 +903,7 @@ void PopupAppletPrivate::restoreDialogSize()
} }
} }
void PopupAppletPrivate::updateDialogPosition() void PopupAppletPrivate::updateDialogPosition(bool move)
{ {
Plasma::Dialog *dialog = dialogPtr.data(); Plasma::Dialog *dialog = dialogPtr.data();
if (!dialog) { if (!dialog) {
@ -907,85 +920,57 @@ void PopupAppletPrivate::updateDialogPosition()
return; return;
} }
QSize s = dialog->size(); const QPoint appletPos = view->mapToGlobal(view->mapFromScene(q->scenePos()));
QPoint pos = view->mapFromScene(q->scenePos());
QPoint dialogPos;
if (!q->containment() || view == q->containment()->view()) { if (!q->containment() || view == q->containment()->view()) {
pos = corona->popupPosition(q, s, popupAlignment); kDebug() << "requesting with" << q->scenePos();
dialogPos = corona->popupPosition(q, dialog->size(), popupAlignment);
} else { } else {
pos = corona->popupPosition(q->parentItem(), s, popupAlignment); kDebug() << "requesting with" << q->parentItem();
dialogPos = corona->popupPosition(q->parentItem(), dialog->size(), popupAlignment);
} }
kDebug() << "dialog position is" << dialogPos <<" with location" << q->location() << "<<<<<<<<<<<<<<<<<<<<<<<<";
bool reverse = false; bool reverse = false;
if (q->formFactor() == Plasma::Vertical) { if (q->formFactor() == Plasma::Vertical) {
if (view->mapToGlobal(view->mapFromScene(q->scenePos())).y() + q->size().height()/2 < pos.y() + dialog->size().width()/2) { reverse = (appletPos.y() + (q->size().height() / 2)) < (dialogPos.y() + (dialog->size().height() / 2));
reverse = true; dialog->setMinimumResizeLimits(-1, appletPos.y(), -1, appletPos.y() + q->size().height());
}
} else { } else {
if (view->mapToGlobal(view->mapFromScene(q->scenePos())).x() + q->size().width()/2 < pos.x() + dialog->size().width()/2) { reverse = (appletPos.x() + (q->size().width() / 2)) < (dialogPos.x() + (dialog->size().width() / 2));
reverse = true; dialog->setMinimumResizeLimits(appletPos.x(), -1, appletPos.x() + q->size().width(), -1);
}
} }
Dialog::ResizeCorners resizeCorners = Dialog::NoCorner;
switch (q->location()) { switch (q->location()) {
case BottomEdge: case BottomEdge:
if (pos.x() >= q->pos().x()) { resizeCorners = Dialog::NorthEast | Dialog::NorthWest;
dialog->setResizeHandleCorners(Dialog::NorthEast); popupPlacement = reverse ? TopPosedLeftAlignedPopup : TopPosedRightAlignedPopup;
} else {
dialog->setResizeHandleCorners(Dialog::NorthWest);
}
if (reverse) {
popupPlacement = Plasma::TopPosedLeftAlignedPopup;
} else {
popupPlacement = Plasma::TopPosedRightAlignedPopup;
}
break; break;
case TopEdge: case TopEdge:
if (pos.x() >= q->pos().x()) { resizeCorners = Dialog::SouthEast | Dialog::SouthWest;
dialog->setResizeHandleCorners(Dialog::SouthEast); popupPlacement = reverse ? Plasma::BottomPosedLeftAlignedPopup : Plasma::BottomPosedRightAlignedPopup;
} else {
dialog->setResizeHandleCorners(Dialog::SouthWest);
}
if (reverse) {
popupPlacement = Plasma::BottomPosedLeftAlignedPopup;
} else {
popupPlacement = Plasma::BottomPosedRightAlignedPopup;
}
break; break;
case LeftEdge: case LeftEdge:
if (pos.y() >= q->pos().y()) { resizeCorners = Dialog::SouthEast | Dialog::NorthEast;
dialog->setResizeHandleCorners(Dialog::SouthEast); popupPlacement = reverse ? RightPosedTopAlignedPopup : RightPosedBottomAlignedPopup;
} else {
dialog->setResizeHandleCorners(Dialog::NorthEast);
}
if (reverse) {
popupPlacement = Plasma::RightPosedTopAlignedPopup;
} else {
popupPlacement = Plasma::RightPosedBottomAlignedPopup;
}
break; break;
case RightEdge: case RightEdge:
if (pos.y() >= q->pos().y()) { resizeCorners = Dialog::SouthWest | Dialog::NorthWest;
dialog->setResizeHandleCorners(Dialog::SouthWest); popupPlacement = reverse ? LeftPosedTopAlignedPopup : LeftPosedBottomAlignedPopup;
} else {
dialog->setResizeHandleCorners(Dialog::NorthWest);
}
if (reverse) {
popupPlacement = Plasma::LeftPosedTopAlignedPopup;
} else {
popupPlacement = Plasma::LeftPosedBottomAlignedPopup;
}
break; break;
default: default:
dialog->setResizeHandleCorners(Dialog::NorthEast); popupPlacement = FloatingPopup;
resizeCorners = Dialog::All;
break;
} }
dialog->move(pos); dialog->setResizeHandleCorners(resizeCorners);
if (move) {
dialog->move(dialogPos);
}
} }
} // Plasma namespace } // Plasma namespace

View File

@ -126,7 +126,6 @@ public:
void destroyMessageOverlay(); void destroyMessageOverlay();
void addGlobalShortcutsPage(KConfigDialog *dialog); void addGlobalShortcutsPage(KConfigDialog *dialog);
void addPublishPage(KConfigDialog *dialog); void addPublishPage(KConfigDialog *dialog);
void clearShortcutEditorPtr();
void configDialogFinished(); void configDialogFinished();
KConfigDialog *generateGenericConfigDialog(); KConfigDialog *generateGenericConfigDialog();
void addStandardConfigurationPages(KConfigDialog *dialog); void addStandardConfigurationPages(KConfigDialog *dialog);
@ -193,7 +192,7 @@ public:
KAction *activationAction; KAction *activationAction;
// configuration // configuration
KKeySequenceWidget *shortcutEditor; //TODO: subclass KConfigDialog and encapsulate this in there QWeakPointer<KKeySequenceWidget> shortcutEditor; //TODO: subclass KConfigDialog and encapsulate this in there
ItemStatus itemStatus; ItemStatus itemStatus;
QString remoteLocation; QString remoteLocation;

View File

@ -100,9 +100,6 @@ void AssociatedApplicationManager::setApplication(Plasma::Applet *applet, const
QString AssociatedApplicationManager::application(const Plasma::Applet *applet) const QString AssociatedApplicationManager::application(const Plasma::Applet *applet) const
{ {
return d->applicationNames.value(applet); return d->applicationNames.value(applet);
if (!d->applicationNames.contains(applet)) {
connect(applet, SIGNAL(destroyed(QObject *)), this, SLOT(cleanupApplet(QObject *)));
}
} }
void AssociatedApplicationManager::setUrls(Plasma::Applet *applet, const KUrl::List &urls) void AssociatedApplicationManager::setUrls(Plasma::Applet *applet, const KUrl::List &urls)

View File

@ -40,6 +40,10 @@ public:
view(0), view(0),
resizeCorners(Dialog::NoCorner), resizeCorners(Dialog::NoCorner),
resizeStartCorner(Dialog::NoCorner), resizeStartCorner(Dialog::NoCorner),
leftResizeMin(-1),
topResizeMin(-1),
rightResizeMin(-1),
bottomResizeMin(-1),
moveTimer(0), moveTimer(0),
aspectRatioMode(Plasma::IgnoreAspectRatio), aspectRatioMode(Plasma::IgnoreAspectRatio),
resizeChecksWithBorderCheck(false) resizeChecksWithBorderCheck(false)
@ -72,6 +76,10 @@ public:
Dialog::ResizeCorners resizeCorners; Dialog::ResizeCorners resizeCorners;
QMap<Dialog::ResizeCorner, QRect> resizeAreas; QMap<Dialog::ResizeCorner, QRect> resizeAreas;
int resizeStartCorner; int resizeStartCorner;
int leftResizeMin;
int topResizeMin;
int rightResizeMin;
int bottomResizeMin;
QTimer *moveTimer; QTimer *moveTimer;
QTimer *adjustViewTimer; QTimer *adjustViewTimer;
QTimer *adjustSizeTimer; QTimer *adjustSizeTimer;

View File

@ -58,7 +58,7 @@ bool EffectWatcher::x11Event(XEvent *event)
bool nowEffectActive = isEffectActive(); bool nowEffectActive = isEffectActive();
if (m_effectActive != nowEffectActive) { if (m_effectActive != nowEffectActive) {
m_effectActive = nowEffectActive; m_effectActive = nowEffectActive;
emit blurBehindChanged(m_effectActive); emit effectChanged(m_effectActive);
} }
} }
} }

View File

@ -41,7 +41,7 @@ protected:
#endif #endif
Q_SIGNALS: Q_SIGNALS:
void blurBehindChanged(bool blur); void effectChanged(bool on);
private: private:
QString m_property; QString m_property;
@ -50,4 +50,4 @@ private:
} }
#endif #endif

View File

@ -22,6 +22,7 @@
#include <math.h> #include <math.h>
#include <float.h> // FLT_MAX #include <float.h> // FLT_MAX
#include <QCoreApplication>
#include <QFileInfo> #include <QFileInfo>
#include <kconfiggroup.h> #include <kconfiggroup.h>
@ -82,7 +83,10 @@ PlasmoidPackage::PlasmoidPackage(QObject *parent)
PlasmoidPackage::~PlasmoidPackage() PlasmoidPackage::~PlasmoidPackage()
{ {
#ifndef PLASMA_NO_KNEWSTUFF #ifndef PLASMA_NO_KNEWSTUFF
delete m_knsDialog.data(); if (!QCoreApplication::closingDown()) {
// let it "leak" on application close as this causes crashes otherwise, BUG 288153
delete m_knsDialog.data();
}
#endif #endif
} }
@ -103,6 +107,7 @@ void PlasmoidPackage::createNewWidgetBrowser(QWidget *parent)
KNS3::DownloadDialog *knsDialog = m_knsDialog.data(); KNS3::DownloadDialog *knsDialog = m_knsDialog.data();
if (!knsDialog) { if (!knsDialog) {
m_knsDialog = knsDialog = new KNS3::DownloadDialog("plasmoids.knsrc", parent); m_knsDialog = knsDialog = new KNS3::DownloadDialog("plasmoids.knsrc", parent);
knsDialog->setProperty("DoNotCloseController", true);
connect(knsDialog, SIGNAL(accepted()), this, SIGNAL(newWidgetBrowserFinished())); connect(knsDialog, SIGNAL(accepted()), this, SIGNAL(newWidgetBrowserFinished()));
} }

View File

@ -36,12 +36,13 @@ public:
void iconSizeChanged(int group); void iconSizeChanged(int group);
void internalTogglePopup(bool fromActivatedSignal = false); void internalTogglePopup(bool fromActivatedSignal = false);
void showDialog();
void hideTimedPopup(); void hideTimedPopup();
void clearPopupLostFocus(); void clearPopupLostFocus();
void dialogSizeChanged(); void dialogSizeChanged();
void dialogStatusChanged(bool status); void dialogStatusChanged(bool status);
void restoreDialogSize(); void restoreDialogSize();
void updateDialogPosition(); void updateDialogPosition(bool move = true);
void popupConstraintsEvent(Plasma::Constraints constraints); void popupConstraintsEvent(Plasma::Constraints constraints);
void checkExtenderAppearance(Plasma::FormFactor f); void checkExtenderAppearance(Plasma::FormFactor f);
KConfigGroup popupConfigGroup(); KConfigGroup popupConfigGroup();
@ -61,6 +62,7 @@ public:
Plasma::AspectRatioMode savedAspectRatio; Plasma::AspectRatioMode savedAspectRatio;
QTimer *autohideTimer; QTimer *autohideTimer;
QBasicTimer delayedShowTimer; QBasicTimer delayedShowTimer;
QBasicTimer showDialogTimer;
QPoint clicked; QPoint clicked;
ItemStatus preShowStatus; ItemStatus preShowStatus;
bool popupLostFocus : 1; bool popupLostFocus : 1;

View File

@ -61,7 +61,7 @@ public:
if (!textBox) { if (!textBox) {
textBox = new Plasma::FrameSvg(q); textBox = new Plasma::FrameSvg(q);
textBox->setImagePath("widgets/lineedit"); textBox->setImagePath("widgets/lineedit");
textBox->setElementPrefix("sunken"); textBox->setElementPrefix("base");
} }
} }
@ -197,7 +197,6 @@ void Style::drawComplexControl(ComplexControl control,
case CC_SpinBox: { case CC_SpinBox: {
d->createTextBox(); d->createTextBox();
d->textBox->setElementPrefix("base");
d->textBox->resizeFrame(option->rect.size()); d->textBox->resizeFrame(option->rect.size());
d->textBox->paintFrame(painter); d->textBox->paintFrame(painter);
@ -252,7 +251,6 @@ void Style::drawComplexControl(ComplexControl control,
qApp->style()->drawComplexControl(control, option, painter, widget); qApp->style()->drawComplexControl(control, option, painter, widget);
} else { } else {
d->createTextBox(); d->createTextBox();
d->textBox->setElementPrefix("base");
d->textBox->resizeFrame(option->rect.size()); d->textBox->resizeFrame(option->rect.size());
d->textBox->paintFrame(painter); d->textBox->paintFrame(painter);
@ -283,7 +281,6 @@ void Style::drawPrimitive(PrimitiveElement element, const QStyleOption *option,
} }
d->createTextBox(); d->createTextBox();
d->textBox->setElementPrefix("base");
d->textBox->resizeFrame(option->rect.size()); d->textBox->resizeFrame(option->rect.size());
d->textBox->paintFrame(painter); d->textBox->paintFrame(painter);
break; break;
@ -306,12 +303,13 @@ QRect Style::subControlRect(ComplexControl control, const QStyleOptionComplex *o
rect.moveCenter(QPoint(option->rect.center().x(), rect.center().y())); rect.moveCenter(QPoint(option->rect.center().x(), rect.center().y()));
} }
} }
return rect;
break; break;
} }
default: default:
return rect; break;
} }
return rect;
} }
int Style::styleHint(StyleHint hint, const QStyleOption *option, const QWidget *widget, QStyleHintReturn *returnData) const int Style::styleHint(StyleHint hint, const QStyleOption *option, const QWidget *widget, QStyleHintReturn *returnData) const
@ -350,7 +348,6 @@ QRect Style::subElementRect(SubElement element, const QStyleOption *option, cons
switch (element) { switch (element) {
case SE_LineEditContents: { case SE_LineEditContents: {
d->createTextBox(); d->createTextBox();
d->textBox->setElementPrefix("base");
qreal left, top, right, bottom; qreal left, top, right, bottom;
d->textBox->getMargins(left, top, right, bottom); d->textBox->getMargins(left, top, right, bottom);
@ -365,9 +362,15 @@ QSize Style::sizeFromContents(ContentsType type, const QStyleOption *option,
const QSize &contentsSize, const QWidget *widget) const const QSize &contentsSize, const QWidget *widget) const
{ {
switch (type) { switch (type) {
case CT_SpinBox: {
d->createTextBox();
qreal left, top, right, bottom;
d->textBox->getMargins(left, top, right, bottom);
return contentsSize + QSize(left + right - 2, top + bottom - 2);
}
case CT_LineEdit: { case CT_LineEdit: {
d->createTextBox(); d->createTextBox();
d->textBox->setElementPrefix("base");
qreal left, top, right, bottom; qreal left, top, right, bottom;
d->textBox->getMargins(left, top, right, bottom); d->textBox->getMargins(left, top, right, bottom);
@ -376,7 +379,6 @@ QSize Style::sizeFromContents(ContentsType type, const QStyleOption *option,
default: default:
return qApp->style()->sizeFromContents(type, option, contentsSize, widget); return qApp->style()->sizeFromContents(type, option, contentsSize, widget);
} }
} }
} }

View File

@ -0,0 +1,85 @@
/******************************************************************************
* Copyright 2011 by Aaron Seigo <aseigo@kde.org> *
* *
* This library 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. *
* *
* This library 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 "themedwidgetinterface_p.h"
#include "theme.h"
namespace Plasma
{
PaletteHelper *PaletteHelper::s_paletteHelper = 0;
PaletteHelper::PaletteHelper()
: QObject()
{
generatePalettes();
connect(Theme::defaultTheme(), SIGNAL(themeChanged()), this, SLOT(generatePalettes()));
connect(KGlobalSettings::self(), SIGNAL(kdisplayPaletteChanged()), this, SLOT(generatePalettes()));
}
PaletteHelper *PaletteHelper::self()
{
if (!s_paletteHelper) {
s_paletteHelper = new PaletteHelper;
}
return s_paletteHelper;
}
void PaletteHelper::generatePalettes()
{
Theme *theme = Theme::defaultTheme();
QColor color = theme->color(Theme::TextColor);
palette = qApp->palette();
palette.setColor(QPalette::Normal, QPalette::WindowText, color);
palette.setColor(QPalette::Inactive, QPalette::WindowText, color);
palette.setColor(QPalette::Normal, QPalette::Link, theme->color(Theme::LinkColor));
palette.setColor(QPalette::Normal, QPalette::LinkVisited, theme->color(Theme::VisitedLinkColor));
qreal alpha = color.alphaF();
color.setAlphaF(0.6);
palette.setColor(QPalette::Disabled, QPalette::WindowText, color);
color.setAlphaF(alpha);
palette.setColor(QPalette::Normal, QPalette::Text, color);
palette.setColor(QPalette::Inactive, QPalette::Text, color);
const QColor buttonColor = Theme::defaultTheme()->color(Theme::ButtonTextColor);
palette.setColor(QPalette::Normal, QPalette::ButtonText, buttonColor);
palette.setColor(QPalette::Inactive, QPalette::ButtonText, buttonColor);
//FIXME: hardcoded colors .. looks incorrect
palette.setColor(QPalette::Normal, QPalette::Base, QColor(0,0,0,0));
palette.setColor(QPalette::Inactive, QPalette::Base, QColor(0,0,0,0));
buttonPalette = palette;
buttonPalette.setColor(QPalette::Normal, QPalette::Text, buttonColor);
buttonPalette.setColor(QPalette::Inactive, QPalette::Text, buttonColor);
emit palettesUpdated();
}
} // namespace Plasma
#include "themedwidgetinterface_p.moc"

View File

@ -28,6 +28,28 @@
namespace Plasma namespace Plasma
{ {
class PaletteHelper : public QObject
{
Q_OBJECT
public:
static PaletteHelper *self();
public Q_SLOTS:
void generatePalettes();
Q_SIGNALS:
void palettesUpdated();
public:
QPalette palette;
QPalette buttonPalette;
private:
PaletteHelper();
static PaletteHelper *s_paletteHelper;
};
template <class T> template <class T>
class ThemedWidgetInterface class ThemedWidgetInterface
{ {
@ -36,10 +58,10 @@ public:
: q(publicClass), : q(publicClass),
customPalette(false), customPalette(false),
customFont(false), customFont(false),
buttonColorForText(false) buttonColorForText(false),
internalPaletteChange(false)
{ {
QObject::connect(Theme::defaultTheme(), SIGNAL(themeChanged()), q, SLOT(setPalette())); QObject::connect(PaletteHelper::self(), SIGNAL(palettesUpdated()), q, SLOT(setPalette()));
QObject::connect(KGlobalSettings::self(), SIGNAL(kdisplayPaletteChanged()), q, SLOT(setPalette()));
} }
void initTheming() void initTheming()
@ -52,33 +74,10 @@ public:
void setPalette() void setPalette()
{ {
if (!customPalette) { if (!customPalette) {
QColor color = Theme::defaultTheme()->color(Theme::TextColor); internalPaletteChange = true;
QPalette p = q->palette(); q->setPalette((buttonColorForText ? PaletteHelper::self()->buttonPalette
p.setColor(QPalette::Normal, QPalette::WindowText, color); : PaletteHelper::self()->palette));
p.setColor(QPalette::Inactive, QPalette::WindowText, color); internalPaletteChange = false;
p.setColor(QPalette::Normal, QPalette::Link, Theme::defaultTheme()->color(Theme::LinkColor));
p.setColor(QPalette::Normal, QPalette::LinkVisited, Theme::defaultTheme()->color(Theme::VisitedLinkColor));
qreal alpha = color.alphaF();
color.setAlphaF(0.6);
p.setColor(QPalette::Disabled, QPalette::WindowText, color);
color.setAlphaF(alpha);
const QColor buttonColor = Theme::defaultTheme()->color(Theme::ButtonTextColor);
p.setColor(QPalette::Normal, QPalette::Text, buttonColorForText ? buttonColor : color);
p.setColor(QPalette::Inactive, QPalette::Text, buttonColorForText ? buttonColor : color);
p.setColor(QPalette::Normal, QPalette::ButtonText, buttonColor);
p.setColor(QPalette::Inactive, QPalette::ButtonText, buttonColor);
//FIXME: hardcoded colors .. looks incorrect
p.setColor(QPalette::Normal, QPalette::Base, QColor(0,0,0,0));
p.setColor(QPalette::Inactive, QPalette::Base, QColor(0,0,0,0));
q->setPalette(p);
customPalette = false;
} }
if (!customFont) { if (!customFont) {
@ -95,7 +94,10 @@ public:
break; break;
case QEvent::PaletteChange: case QEvent::PaletteChange:
customPalette = true; if (!internalPaletteChange &&
q->palette() != (buttonColorForText ? PaletteHelper::self()->buttonPalette : PaletteHelper::self()->palette)) {
customPalette = true;
}
break; break;
default: default:
@ -103,6 +105,13 @@ public:
} }
} }
void setWidget(QWidget *widget)
{
internalPaletteChange = true;
q->setWidget(widget);
internalPaletteChange = false;
}
void event(QEvent *event) void event(QEvent *event)
{ {
if (event->type() == QEvent::Show) { if (event->type() == QEvent::Show) {
@ -114,6 +123,7 @@ public:
bool customPalette : 1; bool customPalette : 1;
bool customFont : 1; bool customFont : 1;
bool buttonColorForText : 1; bool buttonColorForText : 1;
bool internalPaletteChange : 1;
}; };
} // namespace Plasma } // namespace Plasma

View File

@ -356,10 +356,9 @@ void ToolTip::resizeEvent(QResizeEvent *e)
void ToolTip::paintEvent(QPaintEvent *e) void ToolTip::paintEvent(QPaintEvent *e)
{ {
QPainter painter(this); QPainter painter(this);
painter.setRenderHint(QPainter::Antialiasing);
painter.setClipRect(e->rect()); painter.setClipRect(e->rect());
painter.setCompositionMode(QPainter::CompositionMode_Source); painter.setCompositionMode(QPainter::CompositionMode_Source);
painter.fillRect(rect(), Qt::transparent); painter.fillRect(e->rect(), Qt::transparent);
d->background->paintFrame(&painter); d->background->paintFrame(&painter);
} }

View File

@ -85,8 +85,9 @@ public:
defaultWallpaperWidth(DEFAULT_WALLPAPER_WIDTH), defaultWallpaperWidth(DEFAULT_WALLPAPER_WIDTH),
defaultWallpaperHeight(DEFAULT_WALLPAPER_HEIGHT), defaultWallpaperHeight(DEFAULT_WALLPAPER_HEIGHT),
pixmapCache(0), pixmapCache(0),
cachesToDiscard(NoCache),
locolor(false), locolor(false),
compositingActive(KWindowSystem::compositingActive()), compositingActive(KWindowSystem::self()->compositingActive()),
blurActive(false), blurActive(false),
isDefault(false), isDefault(false),
useGlobal(true), useGlobal(true),
@ -97,27 +98,32 @@ public:
ThemeConfig config; ThemeConfig config;
cacheTheme = config.cacheTheme(); cacheTheme = config.cacheTheme();
saveTimer = new QTimer(q);
saveTimer->setSingleShot(true);
saveTimer->setInterval(600);
QObject::connect(saveTimer, SIGNAL(timeout()), q, SLOT(scheduledCacheUpdate()));
updateNotificationTimer = new QTimer(q);
updateNotificationTimer->setSingleShot(true);
updateNotificationTimer->setInterval(500);
QObject::connect(updateNotificationTimer, SIGNAL(timeout()), q, SLOT(notifyOfChanged()));
if (QPixmap::defaultDepth() > 8) { if (QPixmap::defaultDepth() > 8) {
QObject::connect(KWindowSystem::self(), SIGNAL(compositingChanged(bool)), q, SLOT(compositingChanged(bool))); QObject::connect(KWindowSystem::self(), SIGNAL(compositingChanged(bool)), q, SLOT(compositingChanged(bool)));
#ifdef Q_WS_X11 #ifdef Q_WS_X11
//watch for blur effect property changes as well //watch for blur effect property changes as well
effectWatcher = 0; if (!s_blurEffectWatcher) {
effectWatcher = new EffectWatcher("_KDE_NET_WM_BLUR_BEHIND_REGION"); s_blurEffectWatcher = new EffectWatcher("_KDE_NET_WM_BLUR_BEHIND_REGION");
QObject::connect(effectWatcher, SIGNAL(blurBehindChanged(bool)), q, SLOT(blurBehindChanged(bool))); }
QObject::connect(s_blurEffectWatcher, SIGNAL(effectChanged(bool)), q, SLOT(blurBehindChanged(bool)));
#endif #endif
} }
saveTimer = new QTimer(q);
saveTimer->setSingleShot(true);
QObject::connect(saveTimer, SIGNAL(timeout()), q, SLOT(scheduledCacheUpdate()));
} }
~ThemePrivate() ~ThemePrivate()
{ {
delete pixmapCache; delete pixmapCache;
#ifdef Q_WS_X11
delete effectWatcher;
#endif
} }
KConfigGroup &config() KConfigGroup &config()
@ -144,6 +150,8 @@ public:
void compositingChanged(bool active); void compositingChanged(bool active);
void discardCache(CacheTypes caches); void discardCache(CacheTypes caches);
void scheduledCacheUpdate(); void scheduledCacheUpdate();
void scheduleThemeChangeNotification(CacheTypes caches);
void notifyOfChanged();
void colorsChanged(); void colorsChanged();
void blurBehindChanged(bool blur); void blurBehindChanged(bool blur);
bool useCache(); bool useCache();
@ -159,7 +167,10 @@ public:
static const char *systemColorsTheme; static const char *systemColorsTheme;
static const char *themeRcFile; static const char *themeRcFile;
static PackageStructure::Ptr packageStructure; static PackageStructure::Ptr packageStructure;
#ifdef Q_WS_X11
static EffectWatcher *s_blurEffectWatcher;
#endif
Theme *q; Theme *q;
QString themeName; QString themeName;
QList<QString> fallbackThemes; QList<QString> fallbackThemes;
@ -183,10 +194,10 @@ public:
QHash<styles, QString> cachedStyleSheets; QHash<styles, QString> cachedStyleSheets;
QHash<QString, QString> discoveries; QHash<QString, QString> discoveries;
QTimer *saveTimer; QTimer *saveTimer;
QTimer *updateNotificationTimer;
int toolTipDelay;
CacheTypes cachesToDiscard;
#ifdef Q_WS_X11
EffectWatcher *effectWatcher;
#endif
bool locolor : 1; bool locolor : 1;
bool compositingActive : 1; bool compositingActive : 1;
bool blurActive : 1; bool blurActive : 1;
@ -203,6 +214,9 @@ const char *ThemePrivate::themeRcFile = "plasmarc";
// the system colors theme is used to cache unthemed svgs with colorization needs // the system colors theme is used to cache unthemed svgs with colorization needs
// these svgs do not follow the theme's colors, but rather the system colors // these svgs do not follow the theme's colors, but rather the system colors
const char *ThemePrivate::systemColorsTheme = "internal-system-colors"; const char *ThemePrivate::systemColorsTheme = "internal-system-colors";
#ifdef Q_WS_X11
EffectWatcher *ThemePrivate::s_blurEffectWatcher = 0;
#endif
bool ThemePrivate::useCache() bool ThemePrivate::useCache()
{ {
@ -270,8 +284,8 @@ void ThemePrivate::compositingChanged(bool active)
#ifdef Q_WS_X11 #ifdef Q_WS_X11
if (compositingActive != active) { if (compositingActive != active) {
compositingActive = active; compositingActive = active;
discardCache(PixmapCache | SvgElementsCache); //kDebug() << QTime::currentTime();
emit q->themeChanged(); scheduleThemeChangeNotification(PixmapCache | SvgElementsCache);
} }
#endif #endif
} }
@ -324,17 +338,31 @@ void ThemePrivate::scheduledCacheUpdate()
void ThemePrivate::colorsChanged() void ThemePrivate::colorsChanged()
{ {
discardCache(PixmapCache);
colorScheme = KColorScheme(QPalette::Active, KColorScheme::Window, colors); colorScheme = KColorScheme(QPalette::Active, KColorScheme::Window, colors);
buttonColorScheme = KColorScheme(QPalette::Active, KColorScheme::Button, colors); buttonColorScheme = KColorScheme(QPalette::Active, KColorScheme::Button, colors);
viewColorScheme = KColorScheme(QPalette::Active, KColorScheme::View, colors); viewColorScheme = KColorScheme(QPalette::Active, KColorScheme::View, colors);
emit q->themeChanged(); scheduleThemeChangeNotification(PixmapCache);
} }
void ThemePrivate::blurBehindChanged(bool blur) void ThemePrivate::blurBehindChanged(bool blur)
{ {
blurActive = blur; if (blurActive != blur) {
discardCache(PixmapCache | SvgElementsCache); blurActive = blur;
scheduleThemeChangeNotification(PixmapCache | SvgElementsCache);
}
}
void ThemePrivate::scheduleThemeChangeNotification(CacheTypes caches)
{
cachesToDiscard |= caches;
updateNotificationTimer->start();
}
void ThemePrivate::notifyOfChanged()
{
//kDebug() << cachesToDiscard;
discardCache(cachesToDiscard);
cachesToDiscard = NoCache;
emit q->themeChanged(); emit q->themeChanged();
} }
@ -508,7 +536,10 @@ void ThemePrivate::settingsFileChanged(const QString &file)
void Theme::settingsChanged() void Theme::settingsChanged()
{ {
d->setThemeName(d->config().readEntry("name", ThemePrivate::defaultTheme), false); KConfigGroup cg = d->config();
d->setThemeName(cg.readEntry("name", ThemePrivate::defaultTheme), false);
cg = KConfigGroup(cg.config(), "PlasmaToolTips");
d->toolTipDelay = cg.readEntry("Delay", qreal(0.7));
} }
void Theme::setThemeName(const QString &themeName) void Theme::setThemeName(const QString &themeName)
@ -670,9 +701,7 @@ void ThemePrivate::setThemeName(const QString &tempThemeName, bool writeSettings
cg.sync(); cg.sync();
} }
discardCache(SvgElementsCache); scheduleThemeChangeNotification(SvgElementsCache);
emit q->themeChanged();
} }
QString Theme::themeName() const QString Theme::themeName() const
@ -685,7 +714,7 @@ QString Theme::imagePath(const QString &name) const
// look for a compressed svg file in the theme // look for a compressed svg file in the theme
if (name.contains("../") || name.isEmpty()) { if (name.contains("../") || name.isEmpty()) {
// we don't support relative paths // we don't support relative paths
kDebug() << "Theme says: bad image path " << name; //kDebug() << "Theme says: bad image path " << name;
return QString(); return QString();
} }
@ -958,7 +987,7 @@ void Theme::insertIntoCache(const QString& key, const QPixmap& pix, const QStrin
d->keysToCache.insert(key, id); d->keysToCache.insert(key, id);
d->idsToCache.insert(id, key); d->idsToCache.insert(id, key);
d->saveTimer->start(600); d->saveTimer->start();
} }
} }
@ -1082,6 +1111,11 @@ KUrl Theme::homepage() const
return brandConfig.readEntry("homepage", KUrl("http://www.kde.org")); return brandConfig.readEntry("homepage", KUrl("http://www.kde.org"));
} }
int Theme::toolTipDelay() const
{
return d->toolTipDelay;
}
} }
#include <theme.moc> #include <theme.moc>

View File

@ -379,6 +379,11 @@ class PLASMA_EXPORT Theme : public QObject
*/ */
KUrl homepage() const; KUrl homepage() const;
/**
* @return the default tool tip delay; -1 means "no tooltips"
*/
int toolTipDelay() const;
Q_SIGNALS: Q_SIGNALS:
/** /**
* Emitted when the user changes the theme. SVGs should be reloaded at * Emitted when the user changes the theme. SVGs should be reloaded at
@ -404,6 +409,7 @@ class PLASMA_EXPORT Theme : public QObject
Q_PRIVATE_SLOT(d, void settingsFileChanged(const QString &)) Q_PRIVATE_SLOT(d, void settingsFileChanged(const QString &))
Q_PRIVATE_SLOT(d, void scheduledCacheUpdate()) Q_PRIVATE_SLOT(d, void scheduledCacheUpdate())
Q_PRIVATE_SLOT(d, void onAppExitCleanup()) Q_PRIVATE_SLOT(d, void onAppExitCleanup())
Q_PRIVATE_SLOT(d, void notifyOfChanged())
}; };
} // Plasma namespace } // Plasma namespace

View File

@ -140,21 +140,18 @@ void ToolTipManager::show(QGraphicsWidget *widget)
return; return;
} }
qreal delay = 0.0; d->delayedHide = false;
ToolTipContent content = d->tooltips[widget]; d->hideTimer->stop();
d->showTimer->stop();
const int defaultDelay = Theme::defaultTheme()->toolTipDelay();
if (!content.isInstantPopup()) { if (defaultDelay < 0) {
KConfig config("plasmarc"); return;
KConfigGroup cg(&config, "PlasmaToolTips");
delay = cg.readEntry("Delay", qreal(0.7));
if (delay < 0) {
return;
}
} }
d->hideTimer->stop(); ToolTipContent content = d->tooltips[widget];
d->delayedHide = false; qreal delay = content.isInstantPopup() ? 0.0 : defaultDelay;
d->showTimer->stop();
d->currentWidget = widget; d->currentWidget = widget;
if (d->isShown) { if (d->isShown) {
@ -214,6 +211,13 @@ void ToolTipManager::unregisterWidget(QGraphicsWidget *widget)
return; return;
} }
if (widget == d->currentWidget) {
d->currentWidget = 0;
d->showTimer->stop(); // stop the timer to show the tooltip
d->delayedHide = false;
d->hideTipWidget();
}
widget->removeEventFilter(this); widget->removeEventFilter(this);
d->removeWidget(widget); d->removeWidget(widget);
} }
@ -249,6 +253,11 @@ void ToolTipManager::setContent(QGraphicsWidget *widget, const ToolTipContent &d
//look if the data prefers aother graphicswidget, otherwise use the one used as event catcher //look if the data prefers aother graphicswidget, otherwise use the one used as event catcher
QGraphicsWidget *referenceWidget = data.graphicsWidget() ? data.graphicsWidget() : widget; QGraphicsWidget *referenceWidget = data.graphicsWidget() ? data.graphicsWidget() : widget;
Corona *corona = qobject_cast<Corona *>(referenceWidget->scene()); Corona *corona = qobject_cast<Corona *>(referenceWidget->scene());
if (!corona) {
// fallback to the corona we were given
corona = m_corona;
}
if (corona) { if (corona) {
d->tipWidget->moveTo(corona->popupPosition(referenceWidget, d->tipWidget->size(), Qt::AlignCenter)); d->tipWidget->moveTo(corona->popupPosition(referenceWidget, d->tipWidget->size(), Qt::AlignCenter));
} }
@ -345,14 +354,13 @@ void ToolTipManagerPrivate::clearTips()
void ToolTipManagerPrivate::resetShownState() void ToolTipManagerPrivate::resetShownState()
{ {
if (currentWidget) { if (!tipWidget || !tipWidget->isVisible() || delayedHide) {
if (!tipWidget || !tipWidget->isVisible() || delayedHide) { //One might have moused out and back in again
//One might have moused out and back in again showTimer->stop();
delayedHide = false; delayedHide = false;
isShown = false; isShown = false;
currentWidget = 0; currentWidget = 0;
hideTipWidget(); hideTipWidget();
}
} }
} }
@ -404,6 +412,11 @@ void ToolTipManagerPrivate::showToolTip()
tipWidget->prepareShowing(); tipWidget->prepareShowing();
QGraphicsWidget *referenceWidget = tooltip.value().graphicsWidget() ? tooltip.value().graphicsWidget() : currentWidget; QGraphicsWidget *referenceWidget = tooltip.value().graphicsWidget() ? tooltip.value().graphicsWidget() : currentWidget;
Corona *corona = qobject_cast<Corona *>(referenceWidget->scene()); Corona *corona = qobject_cast<Corona *>(referenceWidget->scene());
if (!corona) {
// fallback to the corona we were given
corona = q->m_corona;
}
if (corona) { if (corona) {
tipWidget->moveTo(corona->popupPosition(referenceWidget, tipWidget->size(), Qt::AlignCenter)); tipWidget->moveTo(corona->popupPosition(referenceWidget, tipWidget->size(), Qt::AlignCenter));
} }

View File

@ -186,8 +186,8 @@ void View::setScreen(int screen, int desktop)
// handle views that are working with panel containment types // handle views that are working with panel containment types
if (d->containment && if (d->containment &&
(d->containment->type() == Containment::PanelContainment || (d->containment->containmentType() == Containment::PanelContainment ||
d->containment->type() == Containment::CustomPanelContainment)) { d->containment->containmentType() == Containment::CustomPanelContainment)) {
d->containment->setScreen(screen, desktop); d->containment->setScreen(screen, desktop);
return; return;
} }

View File

@ -87,7 +87,7 @@ CheckBox::CheckBox(QGraphicsWidget *parent)
{ {
QCheckBox *native = new QCheckBox; QCheckBox *native = new QCheckBox;
connect(native, SIGNAL(toggled(bool)), this, SIGNAL(toggled(bool))); connect(native, SIGNAL(toggled(bool)), this, SIGNAL(toggled(bool)));
setWidget(native); d->setWidget(native);
native->setWindowIcon(QIcon()); native->setWindowIcon(QIcon());
native->setAttribute(Qt::WA_NoSystemBackground); native->setAttribute(Qt::WA_NoSystemBackground);

View File

@ -166,7 +166,7 @@ void ComboBox::setNativeWidget(KComboBox *nativeWidget)
connect(nativeWidget, SIGNAL(currentIndexChanged(const QString &)), connect(nativeWidget, SIGNAL(currentIndexChanged(const QString &)),
this, SIGNAL(textChanged(const QString &))); this, SIGNAL(textChanged(const QString &)));
setWidget(nativeWidget); d->setWidget(nativeWidget);
nativeWidget->setWindowIcon(QIcon()); nativeWidget->setWindowIcon(QIcon());
nativeWidget->setAttribute(Qt::WA_NoSystemBackground); nativeWidget->setAttribute(Qt::WA_NoSystemBackground);

View File

@ -50,7 +50,7 @@ GroupBox::GroupBox(QGraphicsWidget *parent)
d(new GroupBoxPrivate(this)) d(new GroupBoxPrivate(this))
{ {
QGroupBox *native = new QGroupBox; QGroupBox *native = new QGroupBox;
setWidget(native); d->setWidget(native);
native->setWindowIcon(QIcon()); native->setWindowIcon(QIcon());
native->setAttribute(Qt::WA_NoSystemBackground); native->setAttribute(Qt::WA_NoSystemBackground);
d->initTheming(); d->initTheming();

View File

@ -644,15 +644,25 @@ void IconWidget::setSvg(const QString &svgFilePath, const QString &elementId)
if (!d->iconSvg) { if (!d->iconSvg) {
d->iconSvg = new Plasma::Svg(this); d->iconSvg = new Plasma::Svg(this);
connect(d->iconSvg, SIGNAL(repaintNeeded()), this, SLOT(svgChanged())); connect(d->iconSvg, SIGNAL(repaintNeeded()), this, SLOT(svgChanged()));
d->oldIcon = d->icon;
} else {
d->oldIcon = d->iconSvg->pixmap(d->iconSvgElement);
} }
d->iconSvg->setImagePath(svgFilePath); d->iconSvg->setImagePath(svgFilePath);
d->iconSvg->setContainsMultipleImages(!elementId.isNull()); d->iconSvg->setContainsMultipleImages(!elementId.isNull());
d->iconSvgElement = elementId; d->iconSvgElement = elementId;
d->iconSvgElementChanged = true; d->iconSvgElementChanged = true;
d->icon = QIcon();
updateGeometry(); updateGeometry();
update();
if (!(d->states & IconWidgetPrivate::HoverState) && !d->iconChangeTimer->isActive() && !d->oldIcon.isNull()) {
d->animateMainIcon(true, d->states);
} else {
d->oldIcon = QIcon();
update();
}
d->iconChangeTimer->start(300);
d->icon = QIcon();
} }
QString IconWidget::svg() const QString IconWidget::svg() const
@ -741,20 +751,19 @@ void IconWidgetPrivate::animateMainIcon(bool show, const IconWidgetStates state)
QPropertyAnimation *animation = hoverAnimation->animation(); QPropertyAnimation *animation = hoverAnimation->animation();
if (!animation) { if (!animation) {
animation = new QPropertyAnimation(hoverAnimation, "value"); animation = new QPropertyAnimation(hoverAnimation, "value");
animation->setProperty("duration", 150); animation->setDuration(150);
animation->setProperty("easingCurve", QEasingCurve::OutQuad); animation->setEasingCurve(QEasingCurve::OutQuad);
animation->setProperty("startValue", 0.0); animation->setStartValue(0.0);
animation->setProperty("endValue", 1.0); animation->setEndValue(1.0);
hoverAnimation->setAnimation(animation); hoverAnimation->setAnimation(animation);
q->connect(animation, SIGNAL(finished()), q, SLOT(hoverAnimationFinished())); q->connect(animation, SIGNAL(finished()), q, SLOT(hoverAnimationFinished()));
} else if (animation->state() == QAbstractAnimation::Running) { } else if (animation->state() == QAbstractAnimation::Running) {
animation->pause(); animation->pause();
} }
animation->setProperty("direction", show ? animation->setDirection(show ? QAbstractAnimation::Forward : QAbstractAnimation::Backward);
QAbstractAnimation::Forward : QAbstractAnimation::Backward); animation->start(show ? QAbstractAnimation::KeepWhenStopped : QAbstractAnimation::DeleteWhenStopped);
animation->start(show ? q->update();
QAbstractAnimation::KeepWhenStopped : QAbstractAnimation::DeleteWhenStopped);
} }
void IconWidgetPrivate::hoverAnimationFinished() void IconWidgetPrivate::hoverAnimationFinished()
@ -1458,7 +1467,6 @@ void IconWidget::hoverEnterEvent(QGraphicsSceneHoverEvent *event)
d->oldIcon = QIcon(); d->oldIcon = QIcon();
d->animateMainIcon(true, d->states|IconWidgetPrivate::HoverState); d->animateMainIcon(true, d->states|IconWidgetPrivate::HoverState);
update();
QGraphicsWidget::hoverEnterEvent(event); QGraphicsWidget::hoverEnterEvent(event);
} }
@ -1475,7 +1483,6 @@ void IconWidget::hoverLeaveEvent(QGraphicsSceneHoverEvent *event)
d->states &= ~IconWidgetPrivate::PressedState; d->states &= ~IconWidgetPrivate::PressedState;
d->animateMainIcon(false, d->states|IconWidgetPrivate::HoverState); d->animateMainIcon(false, d->states|IconWidgetPrivate::HoverState);
update();
QGraphicsWidget::hoverLeaveEvent(event); QGraphicsWidget::hoverLeaveEvent(event);
} }
@ -1486,10 +1493,8 @@ bool IconWidget::sceneEventFilter(QGraphicsItem *watched, QEvent *event)
if (event->type() == QEvent::GraphicsSceneDragEnter) { if (event->type() == QEvent::GraphicsSceneDragEnter) {
d->animateMainIcon(true, d->states|IconWidgetPrivate::HoverState); d->animateMainIcon(true, d->states|IconWidgetPrivate::HoverState);
update();
} else if (event->type() == QEvent::GraphicsSceneDragLeave) { } else if (event->type() == QEvent::GraphicsSceneDragLeave) {
d->animateMainIcon(false, d->states|IconWidgetPrivate::HoverState); d->animateMainIcon(false, d->states|IconWidgetPrivate::HoverState);
update();
} }
return false; return false;

View File

@ -105,7 +105,7 @@ Label::Label(QGraphicsWidget *parent)
connect(native, SIGNAL(linkActivated(QString)), this, SIGNAL(linkActivated(QString))); connect(native, SIGNAL(linkActivated(QString)), this, SIGNAL(linkActivated(QString)));
connect(native, SIGNAL(linkHovered(QString)), this, SIGNAL(linkHovered(QString))); connect(native, SIGNAL(linkHovered(QString)), this, SIGNAL(linkHovered(QString)));
setWidget(native); d->setWidget(native);
d->initTheming(); d->initTheming();
} }

View File

@ -130,7 +130,7 @@ void LineEdit::setNativeWidget(KLineEdit *nativeWidget)
nativeWidget->setWindowFlags(nativeWidget->windowFlags()|Qt::BypassGraphicsProxyWidget); nativeWidget->setWindowFlags(nativeWidget->windowFlags()|Qt::BypassGraphicsProxyWidget);
setWidget(nativeWidget); d->setWidget(nativeWidget);
nativeWidget->setWindowIcon(QIcon()); nativeWidget->setWindowIcon(QIcon());
nativeWidget->setAttribute(Qt::WA_NoSystemBackground); nativeWidget->setAttribute(Qt::WA_NoSystemBackground);

View File

@ -77,7 +77,7 @@ RadioButton::RadioButton(QGraphicsWidget *parent)
{ {
QRadioButton *native = new QRadioButton; QRadioButton *native = new QRadioButton;
connect(native, SIGNAL(toggled(bool)), this, SIGNAL(toggled(bool))); connect(native, SIGNAL(toggled(bool)), this, SIGNAL(toggled(bool)));
setWidget(native); d->setWidget(native);
native->setWindowIcon(QIcon()); native->setWindowIcon(QIcon());
native->setAttribute(Qt::WA_NoSystemBackground); native->setAttribute(Qt::WA_NoSystemBackground);
d->initTheming(); d->initTheming();

View File

@ -933,7 +933,7 @@ void SignalPlotter::drawPlots(QPainter *p, int top, int w, int h, int horizontal
qMax(prev_prev_datapoints[j], qMax(prev_prev_datapoints[j],
prev_prev_prev_datapoints[j]))); prev_prev_prev_datapoints[j])));
double current_minvalue = double current_minvalue =
qMin(datapoints[j], qMin<double>(datapoints[j],
qMin(prev_datapoints[j], qMin(prev_datapoints[j],
qMin(prev_prev_datapoints[j], qMin(prev_prev_datapoints[j],
prev_prev_prev_datapoints[j]))); prev_prev_prev_datapoints[j])));

View File

@ -67,7 +67,7 @@ SpinBox::SpinBox(QGraphicsWidget *parent)
d->focusIndicator = new FocusIndicator(this, "widgets/lineedit"); d->focusIndicator = new FocusIndicator(this, "widgets/lineedit");
setWidget(native); d->setWidget(native);
native->setWindowIcon(QIcon()); native->setWindowIcon(QIcon());
native->setAttribute(Qt::WA_NoSystemBackground); native->setAttribute(Qt::WA_NoSystemBackground);
native->setAutoFillBackground(false); native->setAutoFillBackground(false);

View File

@ -40,7 +40,6 @@ class TextBrowserPrivate : public ThemedWidgetInterface<TextBrowser>
public: public:
TextBrowserPrivate(TextBrowser *browser) TextBrowserPrivate(TextBrowser *browser)
: ThemedWidgetInterface<TextBrowser>(browser), : ThemedWidgetInterface<TextBrowser>(browser),
native(0),
savedMinimumHeight(0), savedMinimumHeight(0),
savedMaximumHeight(QWIDGETSIZE_MAX), savedMaximumHeight(QWIDGETSIZE_MAX),
wasNotFixed(true) wasNotFixed(true)
@ -49,7 +48,8 @@ public:
void setFixedHeight() void setFixedHeight()
{ {
if (native && native->document() && KTextBrowser *native = q->nativeWidget();
if (native->document() &&
q->sizePolicy().verticalPolicy() == QSizePolicy::Fixed && q->sizePolicy().verticalPolicy() == QSizePolicy::Fixed &&
native->verticalScrollBarPolicy() == Qt::ScrollBarAlwaysOff) { native->verticalScrollBarPolicy() == Qt::ScrollBarAlwaysOff) {
native->document()->setTextWidth(q->size().width()); native->document()->setTextWidth(q->size().width());
@ -84,7 +84,7 @@ TextBrowser::TextBrowser(QGraphicsWidget *parent)
connect(native, SIGNAL(textChanged()), this, SIGNAL(textChanged())); connect(native, SIGNAL(textChanged()), this, SIGNAL(textChanged()));
connect(native, SIGNAL(textChanged()), this, SLOT(setFixedHeight())); connect(native, SIGNAL(textChanged()), this, SLOT(setFixedHeight()));
native->setWindowIcon(QIcon()); native->setWindowIcon(QIcon());
setWidget(native); d->setWidget(native);
d->native = native; d->native = native;
native->setAttribute(Qt::WA_NoSystemBackground); native->setAttribute(Qt::WA_NoSystemBackground);
native->setFrameShape(QFrame::NoFrame); native->setFrameShape(QFrame::NoFrame);
@ -114,12 +114,12 @@ QString TextBrowser::text() const
void TextBrowser::setHorizontalScrollBarPolicy(Qt::ScrollBarPolicy policy) void TextBrowser::setHorizontalScrollBarPolicy(Qt::ScrollBarPolicy policy)
{ {
d->native->setHorizontalScrollBarPolicy(policy); nativeWidget()->setHorizontalScrollBarPolicy(policy);
} }
void TextBrowser::setVerticalScrollBarPolicy(Qt::ScrollBarPolicy policy) void TextBrowser::setVerticalScrollBarPolicy(Qt::ScrollBarPolicy policy)
{ {
d->native->setVerticalScrollBarPolicy(policy); nativeWidget()->setVerticalScrollBarPolicy(policy);
} }
void TextBrowser::setStyleSheet(const QString &stylesheet) void TextBrowser::setStyleSheet(const QString &stylesheet)
@ -173,8 +173,8 @@ void TextBrowser::resizeEvent(QGraphicsSceneResizeEvent *event)
void TextBrowser::wheelEvent(QGraphicsSceneWheelEvent *event) void TextBrowser::wheelEvent(QGraphicsSceneWheelEvent *event)
{ {
if (d->native->verticalScrollBarPolicy() == Qt::ScrollBarAlwaysOff && if (nativeWidget()->verticalScrollBarPolicy() == Qt::ScrollBarAlwaysOff &&
d->native->horizontalScrollBarPolicy() == Qt::ScrollBarAlwaysOff) { nativeWidget()->horizontalScrollBarPolicy() == Qt::ScrollBarAlwaysOff) {
event->ignore(); event->ignore();
} else { } else {
QGraphicsProxyWidget::wheelEvent(event); QGraphicsProxyWidget::wheelEvent(event);

View File

@ -108,7 +108,7 @@ void TextEdit::setNativeWidget(KTextEdit *nativeWidget)
connect(nativeWidget, SIGNAL(textChanged()), this, SIGNAL(textChanged())); connect(nativeWidget, SIGNAL(textChanged()), this, SIGNAL(textChanged()));
nativeWidget->setWindowIcon(QIcon()); nativeWidget->setWindowIcon(QIcon());
setWidget(nativeWidget); d->setWidget(nativeWidget);
nativeWidget->setAttribute(Qt::WA_NoSystemBackground); nativeWidget->setAttribute(Qt::WA_NoSystemBackground);
nativeWidget->setFrameShape(QFrame::NoFrame); nativeWidget->setFrameShape(QFrame::NoFrame);

View File

@ -134,22 +134,19 @@ void slideWindow(QWidget *widget, Plasma::Location location)
Display *dpy = QX11Info::display(); Display *dpy = QX11Info::display();
Atom atom = XInternAtom( dpy, "_KDE_SLIDE", False ); Atom atom = XInternAtom( dpy, "_KDE_SLIDE", False );
QVarLengthArray<long, 2> data(2); QVarLengthArray<long, 2> data(2);
data[0] = -1;
switch (location) { switch (location) {
case LeftEdge: case LeftEdge:
data[0] = widget->geometry().left();
data[1] = 0; data[1] = 0;
break; break;
case TopEdge: case TopEdge:
data[0] = widget->geometry().top();
data[1] = 1; data[1] = 1;
break; break;
case RightEdge: case RightEdge:
data[0] = widget->geometry().right();
data[1] = 2; data[1] = 2;
break; break;
case BottomEdge: case BottomEdge:
data[0] = widget->geometry().bottom();
data[1] = 3; data[1] = 3;
default: default:
break; break;