#define wxUSE_LIBHILDON 0
#endif
-#if wxUSE_NOTIFICATION_MESSAGE && !wxUSE_LIBHILDON
+#ifndef wxUSE_LIBHILDON2
+ #define wxUSE_LIBHILDON2 0
+#endif
+
+#if wxUSE_NOTIFICATION_MESSAGE && (!wxUSE_LIBHILDON || !wxUSE_LIBHILDON2)
#ifndef WX_PRECOMP
#include "wx/dialog.h"
#include "wx/timer.h"
+ #include "wx/sizer.h"
+ #include "wx/statbmp.h"
#endif //WX_PRECOMP
+#include "wx/artprov.h"
+
// even if the platform has the native implementation, we still normally want
// to use the generic one (unless it's totally unsuitable for the target UI as
// is the case of Hildon) because it may provide more features, so include
public:
wxNotificationMessageDialog(wxWindow *parent,
const wxString& text,
- int timeout);
+ int timeout,
+ int flags);
void Set(wxWindow *parent,
const wxString& text,
- int timeout);
+ int timeout,
+ int flags);
bool IsAutomatic() const { return m_timer.IsRunning(); }
void SetDeleteOnHide() { m_deleteOnHide = true; }
DECLARE_EVENT_TABLE()
- DECLARE_NO_COPY_CLASS(wxNotificationMessageDialog)
+ wxDECLARE_NO_COPY_CLASS(wxNotificationMessageDialog);
};
// ============================================================================
wxNotificationMessageDialog::wxNotificationMessageDialog(wxWindow *parent,
const wxString& text,
- int timeout)
+ int timeout,
+ int flags)
: wxDialog(parent, wxID_ANY, _("Notice"),
wxDefaultPosition, wxDefaultSize,
0 /* no caption, no border styles */),
{
m_deleteOnHide = false;
- Set(parent, text, timeout);
+ Set(parent, text, timeout, flags);
}
void
wxNotificationMessageDialog::Set(wxWindow * WXUNUSED(parent),
const wxString& text,
- int timeout)
+ int timeout,
+ int flags)
{
- wxSizer *sizer = CreateTextSizer(text);
- SetSizerAndFit(sizer);
+ wxSizer * const sizerTop = new wxBoxSizer(wxHORIZONTAL);
+ if ( flags & wxICON_MASK )
+ {
+ sizerTop->Add(new wxStaticBitmap
+ (
+ this,
+ wxID_ANY,
+ wxArtProvider::GetMessageBoxIcon(flags)
+ ),
+ wxSizerFlags().Centre().Border());
+ }
+
+ sizerTop->Add(CreateTextSizer(text), wxSizerFlags(1).Border());
+ SetSizerAndFit(sizerTop);
if ( timeout != wxGenericNotificationMessage::Timeout_Never )
{
(
GetParent(),
GetFullMessage(),
- timeout
+ timeout,
+ GetFlags()
);
}
else // update the existing dialog
{
- m_dialog->Set(GetParent(), GetFullMessage(), timeout);
+ m_dialog->Set(GetParent(), GetFullMessage(), timeout, GetFlags());
}
m_dialog->Show();
return true;
}
-#endif // wxUSE_NOTIFICATION_MESSAGE && !wxUSE_LIBHILDON
+#endif // wxUSE_NOTIFICATION_MESSAGE && (!wxUSE_LIBHILDON || !wxUSE_LIBHILDON2)