afe0524fa7
the layout size hints can change all together, in any order possible. the only way to have a deterministic behavior is to compress them and do the sync of the size all at once. also being sure to do a single adjustGeometry (one X call) instead of separate setWidth/setHeight a test for the issue is dialog_resizeWithParent.qml BUG:339478 Change-Id: Ia7c3c55e40ff89971beb734dcd205df05bfba687
260 lines
8.6 KiB
C++
260 lines
8.6 KiB
C++
/***************************************************************************
|
|
* Copyright 2011 Marco Martin <mart@kde.org> *
|
|
* Copyright 2013 Sebastian Kügler <sebas@kde.org> *
|
|
* *
|
|
* This program is free software; you can redistribute it and/or modify *
|
|
* it under the terms of the GNU General Public License as published by *
|
|
* the Free Software Foundation; either version 2 of the License, or *
|
|
* (at your option) any later version. *
|
|
* *
|
|
* 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; if not, write to the *
|
|
* Free Software Foundation, Inc., *
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA . *
|
|
***************************************************************************/
|
|
#ifndef DIALOG_PROXY_P
|
|
#define DIALOG_PROXY_P
|
|
|
|
#include <QQuickItem>
|
|
#include <QQuickWindow>
|
|
#include <QPoint>
|
|
#include <QQmlParserStatus>
|
|
|
|
#include <Plasma/Plasma>
|
|
#include <Plasma/Theme>
|
|
|
|
#include <netwm_def.h>
|
|
|
|
#include <plasmaquick_export.h>
|
|
|
|
//
|
|
// W A R N I N G
|
|
// -------------
|
|
//
|
|
// This file is not part of the public Plasma API. It exists purely as an
|
|
// implementation detail. This header file may change from version to
|
|
// version without notice, or even be removed.
|
|
//
|
|
// We mean it.
|
|
//
|
|
|
|
class QQuickItem;
|
|
class QScreen;
|
|
|
|
namespace PlasmaQuick
|
|
{
|
|
|
|
class DialogPrivate;
|
|
|
|
/**
|
|
* @class Dialog
|
|
*
|
|
* Dialog creates a Plasma themed top level window that can contain any QML component.
|
|
*
|
|
* It can be automatically positioned relative to a visual parent
|
|
* The dialog will resize to the size of the main item
|
|
*
|
|
* @code{.qml}
|
|
* import QtQuick 2.0
|
|
* import org.kde.plasma.core 2.0 as PlasmaCore
|
|
* Item {
|
|
* PlasmaCore.Dialog {
|
|
* visible: true
|
|
* mainItem: Item {
|
|
* width: 500
|
|
* height: 500
|
|
*
|
|
* Text {
|
|
* anchors.centerIn: parent
|
|
* color: "red"
|
|
* text: "text"
|
|
* }
|
|
* }
|
|
* }
|
|
* }
|
|
* @endcode
|
|
*
|
|
*/
|
|
class PLASMAQUICK_EXPORT Dialog : public QQuickWindow, public QQmlParserStatus
|
|
{
|
|
Q_OBJECT
|
|
Q_INTERFACES(QQmlParserStatus)
|
|
|
|
/**
|
|
* The main QML item that will be displayed in the Dialog
|
|
*/
|
|
Q_PROPERTY(QQuickItem *mainItem READ mainItem WRITE setMainItem NOTIFY mainItemChanged)
|
|
|
|
/**
|
|
* The main QML item that will be displayed in the Dialog
|
|
*/
|
|
Q_PROPERTY(QQuickItem *visualParent READ visualParent WRITE setVisualParent NOTIFY visualParentChanged)
|
|
|
|
/**
|
|
* Margins of the dialog around the mainItem.
|
|
* @see DialogMargins
|
|
*/
|
|
Q_PROPERTY(QObject *margins READ margins CONSTANT)
|
|
|
|
/**
|
|
* Plasma Location of the dialog window. Useful if this dialog is a popup for a panel
|
|
*/
|
|
Q_PROPERTY(Plasma::Types::Location location READ location WRITE setLocation NOTIFY locationChanged)
|
|
|
|
/**
|
|
* Type of the window
|
|
*/
|
|
Q_PROPERTY(WindowType type READ type WRITE setType NOTIFY typeChanged)
|
|
|
|
/**
|
|
* Whether the dialog should be hidden when the dialog loses focus.
|
|
*
|
|
* The default value is @c false.
|
|
**/
|
|
Q_PROPERTY(bool hideOnWindowDeactivate READ hideOnWindowDeactivate WRITE setHideOnWindowDeactivate NOTIFY hideOnWindowDeactivateChanged)
|
|
|
|
/**
|
|
* Whether the dialog is output only. Default value is @c false. If it is @c true
|
|
* the dialog does not accept input and all pointer events are not accepted, thus the dialog
|
|
* is click through.
|
|
*
|
|
* This property is currently only supported on the X11 platform. On any other platform the
|
|
* property has no effect.
|
|
**/
|
|
Q_PROPERTY(bool outputOnly READ isOutputOnly WRITE setOutputOnly NOTIFY outputOnlyChanged)
|
|
|
|
/**
|
|
* This property holds the window flags of the window.
|
|
* The window flags control the window's appearance in the windowing system,
|
|
* whether it's a dialog, popup, or a regular window, and whether it should
|
|
* have a title bar, etc.
|
|
* Regardless to what the user sets, the flags will always have the
|
|
* FramelessWindowHint flag set
|
|
*/
|
|
Q_PROPERTY(Qt::WindowFlags flags READ flags WRITE setFramelessFlags NOTIFY flagsChanged)
|
|
|
|
/**
|
|
* This property holds how (and if at all) the dialog should draw its own background
|
|
* or if it is complete responsibility of the content item to render a background.
|
|
* Note that in case of NoBackground it loses kwin side shadows and blur
|
|
*/
|
|
Q_PROPERTY(BackgroundHints backgroundHints READ backgroundHints WRITE setBackgroundHints NOTIFY backgroundHintsChanged)
|
|
|
|
Q_PROPERTY(bool visible READ isVisible WRITE setVisible NOTIFY visibleChangedProxy)
|
|
|
|
Q_CLASSINFO("DefaultProperty", "mainItem")
|
|
|
|
public:
|
|
enum WindowType {
|
|
Normal = NET::Normal,
|
|
Dock = NET::Dock,
|
|
DialogWindow = NET::Dialog,
|
|
PopupMenu = NET::PopupMenu,
|
|
Tooltip = NET::Tooltip,
|
|
Notification = NET::Notification
|
|
};
|
|
Q_ENUMS(WindowType)
|
|
|
|
enum BackgroundHints {
|
|
NoBackground = 0, /**< Not drawing a background under the applet, the dialog has its own implementation */
|
|
StandardBackground = 1 /**< The standard background from the theme is drawn */
|
|
};
|
|
Q_ENUMS(BackgroundHints)
|
|
|
|
Dialog(QQuickItem *parent = 0);
|
|
~Dialog();
|
|
|
|
//PROPERTIES ACCESSORS
|
|
QQuickItem *mainItem() const;
|
|
void setMainItem(QQuickItem *mainItem);
|
|
|
|
QQuickItem *visualParent() const;
|
|
void setVisualParent(QQuickItem *visualParent);
|
|
|
|
Plasma::Types::Location location() const;
|
|
void setLocation(Plasma::Types::Location location);
|
|
|
|
QObject *margins() const;
|
|
|
|
void setFramelessFlags(Qt::WindowFlags flags);
|
|
|
|
void setType(WindowType type);
|
|
WindowType type() const;
|
|
|
|
bool hideOnWindowDeactivate() const;
|
|
void setHideOnWindowDeactivate(bool hide);
|
|
|
|
void setOutputOnly(bool outputOnly);
|
|
bool isOutputOnly() const;
|
|
|
|
BackgroundHints backgroundHints() const;
|
|
void setBackgroundHints(BackgroundHints hints);
|
|
|
|
bool isVisible() const;
|
|
void setVisible(bool visible);
|
|
|
|
/**
|
|
* @returns The suggested screen position for the popup
|
|
* @arg item the item the popup has to be positioned relatively to. if null, the popup will be positioned in the center of the window
|
|
* @arg alignment alignment of the popup compared to the item
|
|
*/
|
|
virtual QPoint popupPosition(QQuickItem *item, const QSize &size);
|
|
|
|
Q_SIGNALS:
|
|
void mainItemChanged();
|
|
void locationChanged();
|
|
void visualParentChanged();
|
|
void typeChanged();
|
|
void hideOnWindowDeactivateChanged();
|
|
void outputOnlyChanged();
|
|
void flagsChanged();
|
|
void backgroundHintsChanged();
|
|
void visibleChangedProxy(); //redeclaration of QQuickWindow::visibleChanged
|
|
/**
|
|
* Emitted when the @see hideOnWindowDeactivate property is @c true and this dialog lost focus to a
|
|
* window that is neither a parent dialog to nor a child dialog of this dialog.
|
|
*/
|
|
void windowDeactivated();
|
|
|
|
protected:
|
|
/*
|
|
* set the dialog position. subclasses may change it. ToolTipDialog adjusts the position in an animated way
|
|
*/
|
|
virtual void adjustGeometry(const QRect &geom);
|
|
|
|
//Reimplementations
|
|
virtual void classBegin();
|
|
virtual void componentComplete();
|
|
virtual void resizeEvent(QResizeEvent *re);
|
|
virtual void focusInEvent(QFocusEvent *ev);
|
|
virtual void focusOutEvent(QFocusEvent *ev);
|
|
virtual void showEvent(QShowEvent *event);
|
|
virtual void hideEvent(QHideEvent *event);
|
|
virtual bool event(QEvent *event);
|
|
|
|
private:
|
|
friend class DialogPrivate;
|
|
DialogPrivate *const d;
|
|
|
|
Q_PRIVATE_SLOT(d, void updateInputShape())
|
|
Q_PRIVATE_SLOT(d, void updateTheme())
|
|
Q_PRIVATE_SLOT(d, void updateVisibility(bool visible))
|
|
|
|
Q_PRIVATE_SLOT(d, void updateMinimumWidth())
|
|
Q_PRIVATE_SLOT(d, void updateMinimumHeight())
|
|
Q_PRIVATE_SLOT(d, void updateMaximumWidth())
|
|
Q_PRIVATE_SLOT(d, void updateMaximumHeight())
|
|
Q_PRIVATE_SLOT(d, void updateLayoutParameters())
|
|
|
|
Q_PRIVATE_SLOT(d, void slotMainItemSizeChanged())
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|