// This file is part of Desktop App Toolkit, // a set of libraries for developing nice desktop applications. // // For license and copyright information please follow this link: // https://github.com/desktop-app/legal/blob/master/LEGAL // #pragma once #include "base/unique_qptr.h" #include "ui/rect_part.h" #include "ui/integration.h" #include #include #include class QPixmap; class QImage; class QWheelEvent; enum class RectPart; using RectParts = base::flags; template class object_ptr; namespace Ui { namespace details { template class AttachmentOwner : public QObject { public: template AttachmentOwner(QObject *parent, Args &&...args) : QObject(parent) , _value(std::forward(args)...) { } not_null value() { return &_value; } private: Value _value; }; } // namespace details template inline base::unique_qptr CreateObject(Args &&...args) { return base::make_unique_q( nullptr, std::forward(args)...); } template inline Value *CreateChild( Parent parent, Args &&...args) { if constexpr (std::is_pointer_v) { Expects(parent != nullptr); if constexpr (std::is_base_of_v) { return new Value(parent, std::forward(args)...); } else { return CreateChild>( parent, std::forward(args)...)->value(); } } else if constexpr (requires(const Parent & t) { t.get(); }) { return new Value(parent.get(), std::forward(args)...); } else { static_assert(requires(const Parent &t) { t.data(); }); return new Value(parent.data(), std::forward(args)...); } } template inline not_null>*> WrapAsQObject( not_null parent, Value &&value) { return CreateChild>>( parent.get(), std::forward(value)); } inline void DestroyChild(QWidget *child) { delete child; } template inline auto Connect(Args &&...args) { return QObject::connect(std::forward(args)...); } template inline not_null*> AttachAsChild( not_null parent, Value &&value) { return WrapAsQObject(parent, std::forward(value))->value(); } [[nodiscard]] bool AppInFocus(); [[nodiscard]] inline bool InFocusChain(not_null widget) { if (const auto top = widget->window()) { if (auto focused = top->focusWidget()) { return !widget->isHidden() && (focused == widget || widget->isAncestorOf(focused)); } } return false; } template inline ChildWidget *AttachParentChild( not_null parent, const object_ptr &child) { if (const auto raw = child.data()) { raw->setParent(parent); raw->show(); return raw; } return nullptr; } void SendPendingMoveResizeEvents(not_null target); [[nodiscard]] QPixmap GrabWidget( not_null target, QRect rect = QRect(), QColor bg = QColor(255, 255, 255, 0)); [[nodiscard]] QImage GrabWidgetToImage( not_null target, QRect rect = QRect(), QColor bg = QColor(255, 255, 255, 0)); void RenderWidget( QPainter &painter, not_null source, const QPoint &targetOffset = QPoint(), const QRegion &sourceRegion = QRegion(), QWidget::RenderFlags renderFlags = QWidget::DrawChildren | QWidget::IgnoreMask); void ForceFullRepaint(not_null widget); void ForceFullRepaintSync(not_null widget); void PostponeCall(FnMut &&callable); template < typename Guard, typename Callable, typename GuardTraits = crl::guard_traits>, typename = std::enable_if_t< sizeof(GuardTraits) != crl::details::dependent_zero>> inline void PostponeCall(Guard && object, Callable && callable) { return PostponeCall(crl::guard( std::forward(object), std::forward(callable))); } void SendSynteticMouseEvent( QWidget *widget, QEvent::Type type, Qt::MouseButton button, const QPoint &globalPoint); inline void SendSynteticMouseEvent( QWidget *widget, QEvent::Type type, Qt::MouseButton button) { return SendSynteticMouseEvent(widget, type, button, QCursor::pos()); } template QPointer MakeWeak(Widget *object) { return QPointer(object); } template QPointer MakeWeak(const Widget *object) { return QPointer(object); } template QPointer MakeWeak(not_null object) { return QPointer(object.get()); } template QPointer MakeWeak(not_null object) { return QPointer(object.get()); } [[nodiscard]] QPixmap PixmapFromImage(QImage &&image); [[nodiscard]] bool IsContentVisible( not_null widget, const QRect &rect = QRect()); int WheelDirection(not_null e); [[nodiscard]] QPoint MapFrom( not_null to, not_null from, QPoint point); [[nodiscard]] QRect MapFrom( not_null to, not_null from, QRect rect); void SetGeomtryWithPossibleScreenChange( not_null widget, QRect geometry); } // namespace Ui