}
}
+ /* Do not go backwards */
+ if ((MODEST_IS_MSG_VIEW_WINDOW (current_top) || MODEST_IS_MSG_EDIT_WINDOW (current_top)) &&
+ (MODEST_IS_FOLDER_WINDOW (window) || MODEST_IS_ACCOUNTS_WINDOW (window) ||
+ MODEST_IS_MAILBOXES_WINDOW (window))) {
+ gtk_window_present (GTK_WINDOW (window));
+ return FALSE;
+ }
+
if (MODEST_IS_FOLDER_WINDOW (current_top) && MODEST_IS_FOLDER_WINDOW (window)) {
gtk_window_present (GTK_WINDOW (window));
return FALSE;
GSList* tmp_list = NULL;
type = modest_mail_operation_get_type_operation (MODEST_MAIL_OPERATION (pending_ops->data));
- if (type == MODEST_MAIL_OPERATION_TYPE_RECEIVE || type == MODEST_MAIL_OPERATION_TYPE_OPEN) {
+ if (type == MODEST_MAIL_OPERATION_TYPE_RECEIVE ||
+ type == MODEST_MAIL_OPERATION_TYPE_OPEN ||
+ type == MODEST_MAIL_OPERATION_TYPE_SEND_AND_RECEIVE) {
modest_mail_operation_cancel (pending_ops->data);
}
g_object_unref (G_OBJECT (pending_ops->data));
gtk_widget_show_all (GTK_WIDGET (result));
gtk_window_present (GTK_WINDOW (result));
}
-
+
return result;
}
+static gint
+look_for_transient (gconstpointer a,
+ gconstpointer b)
+{
+ GtkWindow *win, *child;
+
+ if (a == b)
+ return 1;
+
+ child = (GtkWindow *) b;
+ win = (GtkWindow *) a;
+
+ if (gtk_window_get_transient_for (win) == child)
+ return 0;
+ else
+ return 1;
+}
static GtkWindow *
modest_hildon2_window_mgr_get_modal (ModestWindowMgr *self)
{
ModestHildon2WindowMgrPrivate *priv;
GList *toplevel_list;
- GtkWindow *toplevel;
+ GtkWidget *current_top, *toplevel;
+ HildonWindowStack *stack;
g_return_val_if_fail (MODEST_IS_HILDON2_WINDOW_MGR (self), NULL);
priv = MODEST_HILDON2_WINDOW_MGR_GET_PRIVATE (self);
- toplevel = NULL;
+ /* Get current top */
+ stack = hildon_window_stack_get_default ();
+ current_top = hildon_window_stack_peek (stack);
+ toplevel = current_top;
toplevel_list = gtk_window_list_toplevels ();
- while (toplevel_list) {
- if (gtk_window_is_active (toplevel_list->data) &&
- gtk_window_get_modal (toplevel_list->data)) {
- toplevel = (GtkWindow *) toplevel_list->data;
+
+ while (toplevel) {
+ GList *parent_link;
+
+ parent_link = g_list_find_custom (toplevel_list, toplevel, look_for_transient);
+ if (parent_link)
+ toplevel = (GtkWidget *) parent_link->data;
+ else
break;
- }
- toplevel_list = g_list_next (toplevel_list);
}
- return toplevel;
+ return (GtkWindow *) toplevel;
}