#ifndef SECTIONCONTENT_H #define SECTIONCONTENT_H #include #include #include class QWidget; #include "ads/API.h" ADS_NAMESPACE_BEGIN class MainContainerWidget; class ADS_EXPORT_API SectionContent { friend class MainContainerWidget; private: SectionContent(); SectionContent(const SectionContent&); SectionContent& operator=(const SectionContent&); public: typedef QSharedPointer RefPtr; typedef QWeakPointer WeakPtr; enum Flag { None = 0, Closeable = 1, Maximizable = 2, AllFlags = Closeable | Maximizable }; Q_DECLARE_FLAGS(Flags, Flag) /*! * Creates new content, associates it to container and takes ownership of * title- and content- widgets. * \param uniqueName An unique identifier across the entire process. * \param container The parent ContainerWidget in which this content will be active. * \param title The widget to use as title. * \param content The widget to use as content. * \return May return a invalid ref-pointer in case of invalid parameters. */ static RefPtr newSectionContent(const QString& uniqueName, MainContainerWidget* container, QWidget* title, QWidget* content); virtual ~SectionContent(); int uid() const; QString uniqueName() const; MainContainerWidget* containerWidget() const; QWidget* titleWidget() const; QWidget* contentWidget() const; Flags flags() const; QString visibleTitle() const; QString title() const; void setTitle(const QString& title); void setFlags(const Flags f); private: const int _uid; QString _uniqueName; QPointer _containerWidget; QPointer _titleWidget; QPointer _contentWidget; // Optional attributes QString _title; Flags _flags; /* Note: This method could be a problem in static build environment * since it may begin with 0 for every module which uses ADS. */ static int GetNextUid(); }; ADS_NAMESPACE_END #endif