Keep MUC join dialog open until joined, show errors
This commit is contained in:
parent
7e83529afc
commit
d9b91206c0
|
@ -43,7 +43,14 @@ public class Message : Object {
|
||||||
/** UTC **/
|
/** UTC **/
|
||||||
public DateTime? local_time { get; set; }
|
public DateTime? local_time { get; set; }
|
||||||
public Encryption encryption { get; set; default = Encryption.NONE; }
|
public Encryption encryption { get; set; default = Encryption.NONE; }
|
||||||
public Marked marked { get; set; default = Marked.NONE; }
|
private Marked marked_ = Marked.NONE;
|
||||||
|
public Marked marked {
|
||||||
|
get { return marked_; }
|
||||||
|
set {
|
||||||
|
if (marked == Marked.RECEIVED && marked == Marked.READ) return;
|
||||||
|
marked_ = value;
|
||||||
|
}
|
||||||
|
}
|
||||||
public Xmpp.Message.Stanza stanza { get; set; }
|
public Xmpp.Message.Stanza stanza { get; set; }
|
||||||
|
|
||||||
private Database? db;
|
private Database? db;
|
||||||
|
|
|
@ -9,6 +9,7 @@ public class MucManager : StreamInteractionModule, Object {
|
||||||
public string id { get { return IDENTITY.id; } }
|
public string id { get { return IDENTITY.id; } }
|
||||||
|
|
||||||
public signal void joined(Account account, Jid jid, string nick);
|
public signal void joined(Account account, Jid jid, string nick);
|
||||||
|
public signal void enter_error(Account account, Jid jid, Xep.Muc.MucEnterError error);
|
||||||
public signal void left(Account account, Jid jid);
|
public signal void left(Account account, Jid jid);
|
||||||
public signal void subject_set(Account account, Jid jid, string? subject);
|
public signal void subject_set(Account account, Jid jid, string? subject);
|
||||||
public signal void bookmarks_updated(Account account, Gee.List<Xep.Bookmarks.Conference> conferences);
|
public signal void bookmarks_updated(Account account, Gee.List<Xep.Bookmarks.Conference> conferences);
|
||||||
|
@ -29,12 +30,9 @@ public class MucManager : StreamInteractionModule, Object {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void join(Account account, Jid jid, string? nick, string? password) {
|
public void join(Account account, Jid jid, string? nick, string? password) {
|
||||||
if (enter_errors.has_key(jid)) return;
|
|
||||||
|
|
||||||
Core.XmppStream? stream = stream_interactor.get_stream(account);
|
Core.XmppStream? stream = stream_interactor.get_stream(account);
|
||||||
if (stream == null) return;
|
if (stream == null) return;
|
||||||
string nick_ = nick ?? account.bare_jid.localpart ?? account.bare_jid.domainpart;
|
string nick_ = nick ?? account.bare_jid.localpart ?? account.bare_jid.domainpart;
|
||||||
set_autojoin(stream, jid, nick_, password);
|
|
||||||
|
|
||||||
DateTime? history_since = null;
|
DateTime? history_since = null;
|
||||||
Conversation? conversation = stream_interactor.get_module(ConversationManager.IDENTITY).get_conversation(jid, account);
|
Conversation? conversation = stream_interactor.get_module(ConversationManager.IDENTITY).get_conversation(jid, account);
|
||||||
|
@ -209,11 +207,15 @@ public class MucManager : StreamInteractionModule, Object {
|
||||||
private void on_account_added(Account account) {
|
private void on_account_added(Account account) {
|
||||||
stream_interactor.module_manager.get_module(account, Xep.Muc.Module.IDENTITY).room_entered.connect( (stream, jid_string, nick) => {
|
stream_interactor.module_manager.get_module(account, Xep.Muc.Module.IDENTITY).room_entered.connect( (stream, jid_string, nick) => {
|
||||||
Jid jid = new Jid(jid_string);
|
Jid jid = new Jid(jid_string);
|
||||||
|
enter_errors.unset(jid);
|
||||||
|
set_autojoin(stream, jid, nick, null); // TODO password
|
||||||
joined(account, jid, nick);
|
joined(account, jid, nick);
|
||||||
stream_interactor.get_module(MessageProcessor.IDENTITY).send_unsent_messages(account, jid);
|
stream_interactor.get_module(MessageProcessor.IDENTITY).send_unsent_messages(account, jid);
|
||||||
});
|
});
|
||||||
stream_interactor.module_manager.get_module(account, Xep.Muc.Module.IDENTITY).room_enter_error.connect( (stream, jid, error) => {
|
stream_interactor.module_manager.get_module(account, Xep.Muc.Module.IDENTITY).room_enter_error.connect( (stream, jid_str, error) => {
|
||||||
enter_errors[new Jid(jid)] = error;
|
Jid jid = new Jid(jid_str);
|
||||||
|
enter_errors[jid] = error;
|
||||||
|
enter_error(account, jid, error);
|
||||||
});
|
});
|
||||||
stream_interactor.module_manager.get_module(account, Xep.Muc.Module.IDENTITY).self_removed_from_room.connect( (stream, jid, code) => {
|
stream_interactor.module_manager.get_module(account, Xep.Muc.Module.IDENTITY).self_removed_from_room.connect( (stream, jid, code) => {
|
||||||
left(account, new Jid(jid));
|
left(account, new Jid(jid));
|
||||||
|
|
|
@ -72,15 +72,14 @@ SOURCES
|
||||||
src/main.vala
|
src/main.vala
|
||||||
|
|
||||||
src/ui/application.vala
|
src/ui/application.vala
|
||||||
src/ui/add_conversation/chat/add_contact_dialog.vala
|
src/ui/add_conversation/add_conference_dialog.vala
|
||||||
src/ui/add_conversation/chat/roster_list.vala
|
src/ui/add_conversation/add_contact_dialog.vala
|
||||||
src/ui/add_conversation/chat/dialog.vala
|
src/ui/add_conversation/add_groupchat_dialog.vala
|
||||||
src/ui/add_conversation/conference/add_groupchat_dialog.vala
|
src/ui/add_conversation/conference_details_fragment.vala
|
||||||
src/ui/add_conversation/conference/conference_details_fragment.vala
|
src/ui/add_conversation/conference_list.vala
|
||||||
src/ui/add_conversation/conference/conference_list.vala
|
|
||||||
src/ui/add_conversation/conference/dialog.vala
|
|
||||||
src/ui/add_conversation/accounts_combo_box.vala
|
|
||||||
src/ui/add_conversation/list_row.vala
|
src/ui/add_conversation/list_row.vala
|
||||||
|
src/ui/add_conversation/roster_list.vala
|
||||||
|
src/ui/add_conversation/select_contact_dialog.vala
|
||||||
src/ui/add_conversation/select_jid_fragment.vala
|
src/ui/add_conversation/select_jid_fragment.vala
|
||||||
src/ui/avatar_generator.vala
|
src/ui/avatar_generator.vala
|
||||||
src/ui/chat_input/edit_history.vala
|
src/ui/chat_input/edit_history.vala
|
||||||
|
@ -121,6 +120,7 @@ SOURCES
|
||||||
src/ui/occupant_menu/view.vala
|
src/ui/occupant_menu/view.vala
|
||||||
src/ui/settings_dialog.vala
|
src/ui/settings_dialog.vala
|
||||||
src/ui/unified_window.vala
|
src/ui/unified_window.vala
|
||||||
|
src/ui/util/accounts_combo_box.vala
|
||||||
src/ui/util/helper.vala
|
src/ui/util/helper.vala
|
||||||
src/ui/util/label_hybrid.vala
|
src/ui/util/label_hybrid.vala
|
||||||
CUSTOM_VAPIS
|
CUSTOM_VAPIS
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<interface>
|
<interface>
|
||||||
<template class="DinoUiAddConversationChatAddContactDialog">
|
<template class="DinoUiAddContactDialog">
|
||||||
<property name="default_width">300</property>
|
<property name="default_width">300</property>
|
||||||
<property name="modal">True</property>
|
<property name="modal">True</property>
|
||||||
<child type="titlebar">
|
<child type="titlebar">
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<interface>
|
<interface>
|
||||||
<template class="DinoUiAddConversationConferenceAddGroupchatDialog">
|
<template class="DinoUiAddGroupchatDialog">
|
||||||
<property name="default_width">400</property>
|
<property name="default_width">400</property>
|
||||||
<property name="modal">True</property>
|
<property name="modal">True</property>
|
||||||
<child type="titlebar">
|
<child type="titlebar">
|
||||||
|
@ -170,20 +170,6 @@
|
||||||
<property name="height">1</property>
|
<property name="height">1</property>
|
||||||
</packing>
|
</packing>
|
||||||
</child>
|
</child>
|
||||||
<child>
|
|
||||||
<object class="GtkCheckButton" id="autojoin_checkbutton">
|
|
||||||
<property name="active">False</property>
|
|
||||||
<property name="label" translatable="yes">Join on startup</property>
|
|
||||||
<property name="xalign">0</property>
|
|
||||||
<property name="visible">True</property>
|
|
||||||
</object>
|
|
||||||
<packing>
|
|
||||||
<property name="left_attach">1</property>
|
|
||||||
<property name="top_attach">5</property>
|
|
||||||
<property name="width">1</property>
|
|
||||||
<property name="height">1</property>
|
|
||||||
</packing>
|
|
||||||
</child>
|
|
||||||
<child>
|
<child>
|
||||||
<object class="GtkLabel" id="alias_label">
|
<object class="GtkLabel" id="alias_label">
|
||||||
<property name="label" translatable="yes">Alias</property>
|
<property name="label" translatable="yes">Alias</property>
|
||||||
|
@ -192,7 +178,7 @@
|
||||||
</object>
|
</object>
|
||||||
<packing>
|
<packing>
|
||||||
<property name="left_attach">0</property>
|
<property name="left_attach">0</property>
|
||||||
<property name="top_attach">6</property>
|
<property name="top_attach">5</property>
|
||||||
<property name="width">1</property>
|
<property name="width">1</property>
|
||||||
<property name="height">1</property>
|
<property name="height">1</property>
|
||||||
</packing>
|
</packing>
|
||||||
|
@ -206,7 +192,7 @@
|
||||||
</object>
|
</object>
|
||||||
<packing>
|
<packing>
|
||||||
<property name="left_attach">1</property>
|
<property name="left_attach">1</property>
|
||||||
<property name="top_attach">6</property>
|
<property name="top_attach">5</property>
|
||||||
<property name="width">1</property>
|
<property name="width">1</property>
|
||||||
<property name="height">1</property>
|
<property name="height">1</property>
|
||||||
</packing>
|
</packing>
|
||||||
|
|
|
@ -1,6 +1,9 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<interface>
|
<interface>
|
||||||
<template class="DinoUiAddConversationConferenceConferenceDetailsFragment">
|
<template class="DinoUiConferenceDetailsFragment">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<child>
|
||||||
|
<object class="GtkOverlay">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<child>
|
<child>
|
||||||
<object class="GtkGrid">
|
<object class="GtkGrid">
|
||||||
|
@ -168,10 +171,9 @@
|
||||||
</packing>
|
</packing>
|
||||||
</child>
|
</child>
|
||||||
<child>
|
<child>
|
||||||
<object class="GtkLabel">
|
<object class="GtkLabel" id="password_text_label">
|
||||||
<property name="label" translatable="yes">Password</property>
|
<property name="label" translatable="yes">Password</property>
|
||||||
<property name="xalign">1</property>
|
<property name="xalign">1</property>
|
||||||
<property name="visible">True</property>
|
|
||||||
<style>
|
<style>
|
||||||
<class name="dim-label"/>
|
<class name="dim-label"/>
|
||||||
</style>
|
</style>
|
||||||
|
@ -185,7 +187,6 @@
|
||||||
</child>
|
</child>
|
||||||
<child>
|
<child>
|
||||||
<object class="GtkStack" id="password_stack">
|
<object class="GtkStack" id="password_stack">
|
||||||
<property name="visible">True</property>
|
|
||||||
<child>
|
<child>
|
||||||
<object class="GtkButton" id="password_button">
|
<object class="GtkButton" id="password_button">
|
||||||
<property name="relief">none</property>
|
<property name="relief">none</property>
|
||||||
|
@ -221,6 +222,75 @@
|
||||||
</packing>
|
</packing>
|
||||||
</child>
|
</child>
|
||||||
</object>
|
</object>
|
||||||
|
<packing>
|
||||||
|
<property name="index">-1</property>
|
||||||
|
</packing>
|
||||||
|
</child>
|
||||||
|
<child type="overlay">
|
||||||
|
<object class="GtkRevealer" id="notification_revealer">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">False</property>
|
||||||
|
<property name="halign">center</property>
|
||||||
|
<property name="valign">start</property>
|
||||||
|
<child>
|
||||||
|
<object class="GtkFrame" id="frame2">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">False</property>
|
||||||
|
<property name="label_xalign">0</property>
|
||||||
|
<property name="shadow_type">none</property>
|
||||||
|
<style>
|
||||||
|
<class name="app-notification"/>
|
||||||
|
</style>
|
||||||
|
<child>
|
||||||
|
<object class="GtkBox" id="box2">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">False</property>
|
||||||
|
<property name="spacing">20</property>
|
||||||
|
<child>
|
||||||
|
<object class="GtkLabel" id="notification_label">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">False</property>
|
||||||
|
<property name="label" translatable="yes">This is an app-notification. Click the button to dismiss</property>
|
||||||
|
</object>
|
||||||
|
<packing>
|
||||||
|
<property name="expand">False</property>
|
||||||
|
<property name="fill">True</property>
|
||||||
|
<property name="position">0</property>
|
||||||
|
</packing>
|
||||||
|
</child>
|
||||||
|
<child>
|
||||||
|
<object class="GtkButton" id="notification_button">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">True</property>
|
||||||
|
<property name="receives_default">True</property>
|
||||||
|
<property name="relief">none</property>
|
||||||
|
<child>
|
||||||
|
<object class="GtkImage" id="image2">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="can_focus">False</property>
|
||||||
|
<property name="icon_name">window-close-symbolic</property>
|
||||||
|
</object>
|
||||||
|
</child>
|
||||||
|
<style>
|
||||||
|
<class name="image-button"/>
|
||||||
|
</style>
|
||||||
|
</object>
|
||||||
|
<packing>
|
||||||
|
<property name="expand">False</property>
|
||||||
|
<property name="fill">True</property>
|
||||||
|
<property name="position">1</property>
|
||||||
|
</packing>
|
||||||
|
</child>
|
||||||
|
</object>
|
||||||
|
</child>
|
||||||
|
<child type="label_item">
|
||||||
|
<placeholder/>
|
||||||
|
</child>
|
||||||
|
</object>
|
||||||
|
</child>
|
||||||
|
</object>
|
||||||
|
</child>
|
||||||
|
</object>
|
||||||
</child>
|
</child>
|
||||||
</template>
|
</template>
|
||||||
</interface>
|
</interface>
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<interface>
|
<interface>
|
||||||
<template class="DinoUiAddConversationListRow" parent="GtkListBoxRow">
|
<template class="DinoUiListRow" parent="GtkListBoxRow">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<child>
|
<child>
|
||||||
<object class="GtkGrid" id="outer_grid">
|
<object class="GtkGrid" id="outer_grid">
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<interface>
|
<interface>
|
||||||
<template class="DinoUiAddConversationSelectJidFragment">
|
<template class="DinoUiSelectJidFragment">
|
||||||
<property name="height_request">500</property>
|
<property name="height_request">500</property>
|
||||||
<property name="width_request">460</property>
|
<property name="width_request">460</property>
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
|
|
|
@ -3,9 +3,9 @@ using Gtk;
|
||||||
|
|
||||||
using Dino.Entities;
|
using Dino.Entities;
|
||||||
|
|
||||||
namespace Dino.Ui.AddConversation.Conference {
|
namespace Dino.Ui {
|
||||||
|
|
||||||
public class Dialog : Gtk.Dialog {
|
public class AddConferenceDialog : Gtk.Dialog {
|
||||||
|
|
||||||
public signal void conversation_opened(Conversation conversation);
|
public signal void conversation_opened(Conversation conversation);
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@ public class Dialog : Gtk.Dialog {
|
||||||
|
|
||||||
private StreamInteractor stream_interactor;
|
private StreamInteractor stream_interactor;
|
||||||
|
|
||||||
public Dialog(StreamInteractor stream_interactor) {
|
public AddConferenceDialog(StreamInteractor stream_interactor) {
|
||||||
Object(use_header_bar : 1);
|
Object(use_header_bar : 1);
|
||||||
this.title = _("Join Conference");
|
this.title = _("Join Conference");
|
||||||
this.modal = true;
|
this.modal = true;
|
||||||
|
@ -35,6 +35,8 @@ public class Dialog : Gtk.Dialog {
|
||||||
setup_jid_add_view();
|
setup_jid_add_view();
|
||||||
setup_conference_details_view();
|
setup_conference_details_view();
|
||||||
show_jid_add_view();
|
show_jid_add_view();
|
||||||
|
|
||||||
|
stream_interactor.get_module(MucManager.IDENTITY).joined.connect((account, jid, nick) => { Idle.add(() => { on_joined(account, jid, nick); return false; } ); });
|
||||||
}
|
}
|
||||||
|
|
||||||
private void show_jid_add_view() {
|
private void show_jid_add_view() {
|
||||||
|
@ -102,7 +104,7 @@ public class Dialog : Gtk.Dialog {
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setup_conference_details_view() {
|
private void setup_conference_details_view() {
|
||||||
details_fragment = new ConferenceDetailsFragment(stream_interactor);
|
details_fragment = new ConferenceDetailsFragment(stream_interactor, ok_button);
|
||||||
stack.add_named(details_fragment, "details");
|
stack.add_named(details_fragment, "details");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -134,8 +136,16 @@ public class Dialog : Gtk.Dialog {
|
||||||
|
|
||||||
private void on_ok_button_clicked() {
|
private void on_ok_button_clicked() {
|
||||||
stream_interactor.get_module(MucManager.IDENTITY).join(details_fragment.account, new Jid(details_fragment.jid), details_fragment.nick, details_fragment.password);
|
stream_interactor.get_module(MucManager.IDENTITY).join(details_fragment.account, new Jid(details_fragment.jid), details_fragment.nick, details_fragment.password);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void on_joined(Account account, Jid jid, string nick) {
|
||||||
|
if (account.equals(details_fragment.account) && jid.equals_bare(new Jid(details_fragment.jid))) {
|
||||||
|
Conversation conversation = stream_interactor.get_module(ConversationManager.IDENTITY).create_conversation(jid, account, Conversation.Type.GROUPCHAT);
|
||||||
|
stream_interactor.get_module(ConversationManager.IDENTITY).start_conversation(conversation, true);
|
||||||
|
conversation_opened(conversation);
|
||||||
close();
|
close();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void on_cancel() {
|
private void on_cancel() {
|
||||||
close();
|
close();
|
|
@ -3,7 +3,7 @@ using Gtk;
|
||||||
|
|
||||||
using Dino.Entities;
|
using Dino.Entities;
|
||||||
|
|
||||||
namespace Dino.Ui.AddConversation.Chat {
|
namespace Dino.Ui {
|
||||||
|
|
||||||
[GtkTemplate (ui = "/im/dino/add_conversation/add_contact_dialog.ui")]
|
[GtkTemplate (ui = "/im/dino/add_conversation/add_contact_dialog.ui")]
|
||||||
protected class AddContactDialog : Gtk.Dialog {
|
protected class AddContactDialog : Gtk.Dialog {
|
|
@ -3,7 +3,7 @@ using Gtk;
|
||||||
|
|
||||||
using Dino.Entities;
|
using Dino.Entities;
|
||||||
|
|
||||||
namespace Dino.Ui.AddConversation.Conference {
|
namespace Dino.Ui {
|
||||||
|
|
||||||
[GtkTemplate (ui = "/im/dino/add_conversation/add_groupchat_dialog.ui")]
|
[GtkTemplate (ui = "/im/dino/add_conversation/add_groupchat_dialog.ui")]
|
||||||
protected class AddGroupchatDialog : Gtk.Dialog {
|
protected class AddGroupchatDialog : Gtk.Dialog {
|
||||||
|
@ -16,7 +16,6 @@ protected class AddGroupchatDialog : Gtk.Dialog {
|
||||||
[GtkChild] private Entry jid_entry;
|
[GtkChild] private Entry jid_entry;
|
||||||
[GtkChild] private Entry alias_entry;
|
[GtkChild] private Entry alias_entry;
|
||||||
[GtkChild] private Entry nick_entry;
|
[GtkChild] private Entry nick_entry;
|
||||||
[GtkChild] private CheckButton autojoin_checkbutton;
|
|
||||||
|
|
||||||
private StreamInteractor stream_interactor;
|
private StreamInteractor stream_interactor;
|
||||||
private Xmpp.Xep.Bookmarks.Conference? edit_confrence = null;
|
private Xmpp.Xep.Bookmarks.Conference? edit_confrence = null;
|
||||||
|
@ -46,7 +45,6 @@ protected class AddGroupchatDialog : Gtk.Dialog {
|
||||||
account_combobox.selected = account;
|
account_combobox.selected = account;
|
||||||
jid_entry.text = conference.jid;
|
jid_entry.text = conference.jid;
|
||||||
nick_entry.text = conference.nick ?? "";
|
nick_entry.text = conference.nick ?? "";
|
||||||
autojoin_checkbutton.active = conference.autojoin;
|
|
||||||
alias_entry.text = conference.name;
|
alias_entry.text = conference.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,7 +67,6 @@ protected class AddGroupchatDialog : Gtk.Dialog {
|
||||||
Xmpp.Xep.Bookmarks.Conference conference = new Xmpp.Xep.Bookmarks.Conference(jid_entry.text);
|
Xmpp.Xep.Bookmarks.Conference conference = new Xmpp.Xep.Bookmarks.Conference(jid_entry.text);
|
||||||
conference.nick = nick_entry.text != "" ? nick_entry.text : null;
|
conference.nick = nick_entry.text != "" ? nick_entry.text : null;
|
||||||
conference.name = alias_entry.text;
|
conference.name = alias_entry.text;
|
||||||
conference.autojoin = autojoin_checkbutton.active;
|
|
||||||
if (edit_confrence == null) {
|
if (edit_confrence == null) {
|
||||||
stream_interactor.get_module(MucManager.IDENTITY).add_bookmark(account_combobox.selected, conference);
|
stream_interactor.get_module(MucManager.IDENTITY).add_bookmark(account_combobox.selected, conference);
|
||||||
} else {
|
} else {
|
|
@ -3,7 +3,7 @@ using Gtk;
|
||||||
|
|
||||||
using Dino.Entities;
|
using Dino.Entities;
|
||||||
|
|
||||||
namespace Dino.Ui.AddConversation.Conference {
|
namespace Dino.Ui {
|
||||||
|
|
||||||
[GtkTemplate (ui = "/im/dino/add_conversation/conference_details_fragment.ui")]
|
[GtkTemplate (ui = "/im/dino/add_conversation/conference_details_fragment.ui")]
|
||||||
protected class ConferenceDetailsFragment : Box {
|
protected class ConferenceDetailsFragment : Box {
|
||||||
|
@ -64,12 +64,20 @@ protected class ConferenceDetailsFragment : Box {
|
||||||
[GtkChild] private Stack password_stack;
|
[GtkChild] private Stack password_stack;
|
||||||
[GtkChild] private Button password_button;
|
[GtkChild] private Button password_button;
|
||||||
[GtkChild] private Label password_label;
|
[GtkChild] private Label password_label;
|
||||||
|
[GtkChild] private Label password_text_label;
|
||||||
[GtkChild] private Entry password_entry;
|
[GtkChild] private Entry password_entry;
|
||||||
|
|
||||||
private StreamInteractor stream_interactor;
|
[GtkChild] private Revealer notification_revealer;
|
||||||
|
[GtkChild] private Button notification_button;
|
||||||
|
[GtkChild] private Label notification_label;
|
||||||
|
|
||||||
public ConferenceDetailsFragment(StreamInteractor stream_interactor) {
|
private StreamInteractor stream_interactor;
|
||||||
|
private Button ok_button;
|
||||||
|
|
||||||
|
public ConferenceDetailsFragment(StreamInteractor stream_interactor, Button ok_button) {
|
||||||
this.stream_interactor = stream_interactor;
|
this.stream_interactor = stream_interactor;
|
||||||
|
this.ok_button = ok_button;
|
||||||
|
|
||||||
account_combobox.initialize(stream_interactor);
|
account_combobox.initialize(stream_interactor);
|
||||||
|
|
||||||
accounts_stack.set_visible_child_name("label");
|
accounts_stack.set_visible_child_name("label");
|
||||||
|
@ -90,6 +98,18 @@ protected class ConferenceDetailsFragment : Box {
|
||||||
|
|
||||||
jid_entry.key_release_event.connect(() => { done = true; return false; }); // just for notifying
|
jid_entry.key_release_event.connect(() => { done = true; return false; }); // just for notifying
|
||||||
nick_entry.key_release_event.connect(() => { done = true; return false; });
|
nick_entry.key_release_event.connect(() => { done = true; return false; });
|
||||||
|
|
||||||
|
stream_interactor.get_module(MucManager.IDENTITY).enter_error.connect((account, jid, error) => {
|
||||||
|
Idle.add(() => {
|
||||||
|
on_enter_error(account, jid, error);
|
||||||
|
return false;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
notification_button.clicked.connect(() => { notification_revealer.set_reveal_child(false); });
|
||||||
|
ok_button.clicked.connect(() => {
|
||||||
|
ok_button.label = _("Joining...");
|
||||||
|
ok_button.sensitive = false;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public void set_editable() {
|
public void set_editable() {
|
||||||
|
@ -108,9 +128,40 @@ protected class ConferenceDetailsFragment : Box {
|
||||||
jid = "";
|
jid = "";
|
||||||
nick = "";
|
nick = "";
|
||||||
password = "";
|
password = "";
|
||||||
|
password_text_label.visible = false;
|
||||||
|
password_stack.visible = false;
|
||||||
|
notification_revealer.set_reveal_child(false);
|
||||||
reset_editable();
|
reset_editable();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void on_enter_error(Account account, Jid jid, Xmpp.Xep.Muc.MucEnterError error) {
|
||||||
|
ok_button.label = _("Join");
|
||||||
|
ok_button.sensitive = true;
|
||||||
|
string label_text = "";
|
||||||
|
switch (error) {
|
||||||
|
case Xmpp.Xep.Muc.MucEnterError.PASSWORD_REQUIRED:
|
||||||
|
label_text = _("Password required to enter room");
|
||||||
|
password_text_label.visible = true;
|
||||||
|
password_stack.visible = true;
|
||||||
|
break;
|
||||||
|
case Xmpp.Xep.Muc.MucEnterError.BANNED:
|
||||||
|
label_text = _("Banned from joining or creating conference"); break;
|
||||||
|
case Xmpp.Xep.Muc.MucEnterError.ROOM_DOESNT_EXIST:
|
||||||
|
label_text = _("Room does not exist"); break;
|
||||||
|
case Xmpp.Xep.Muc.MucEnterError.CREATION_RESTRICTED:
|
||||||
|
label_text = _("Not allowed to create room"); break;
|
||||||
|
case Xmpp.Xep.Muc.MucEnterError.NOT_IN_MEMBER_LIST:
|
||||||
|
label_text = _("Room is members only"); break;
|
||||||
|
case Xmpp.Xep.Muc.MucEnterError.USE_RESERVED_ROOMNICK:
|
||||||
|
case Xmpp.Xep.Muc.MucEnterError.NICK_CONFLICT:
|
||||||
|
label_text = _("Choose a different nick"); break;
|
||||||
|
case Xmpp.Xep.Muc.MucEnterError.OCCUPANT_LIMIT_REACHED:
|
||||||
|
label_text = _("Room has too many occupants"); break;
|
||||||
|
}
|
||||||
|
notification_label.label = label_text;
|
||||||
|
notification_revealer.set_reveal_child(true);
|
||||||
|
}
|
||||||
|
|
||||||
private bool on_jid_key_release_event(EventKey event) {
|
private bool on_jid_key_release_event(EventKey event) {
|
||||||
jid_label.label = jid_entry.text;
|
jid_label.label = jid_entry.text;
|
||||||
if (event.keyval == Key.Return) jid_stack.set_visible_child_name("label");
|
if (event.keyval == Key.Return) jid_stack.set_visible_child_name("label");
|
|
@ -4,7 +4,7 @@ using Gtk;
|
||||||
using Xmpp;
|
using Xmpp;
|
||||||
using Dino.Entities;
|
using Dino.Entities;
|
||||||
|
|
||||||
namespace Dino.Ui.AddConversation.Conference {
|
namespace Dino.Ui {
|
||||||
|
|
||||||
protected class ConferenceList : FilterableList {
|
protected class ConferenceList : FilterableList {
|
||||||
|
|
|
@ -3,7 +3,7 @@ using Gtk;
|
||||||
|
|
||||||
using Dino.Entities;
|
using Dino.Entities;
|
||||||
|
|
||||||
namespace Dino.Ui.AddConversation {
|
namespace Dino.Ui {
|
||||||
|
|
||||||
[GtkTemplate (ui = "/im/dino/add_conversation/list_row.ui")]
|
[GtkTemplate (ui = "/im/dino/add_conversation/list_row.ui")]
|
||||||
public class ListRow : ListBoxRow {
|
public class ListRow : ListBoxRow {
|
||||||
|
|
|
@ -4,7 +4,7 @@ using Gtk;
|
||||||
using Dino.Entities;
|
using Dino.Entities;
|
||||||
using Xmpp;
|
using Xmpp;
|
||||||
|
|
||||||
namespace Dino.Ui.AddConversation.Chat {
|
namespace Dino.Ui {
|
||||||
|
|
||||||
protected class RosterList : FilterableList {
|
protected class RosterList : FilterableList {
|
||||||
|
|
|
@ -4,9 +4,9 @@ using Gtk;
|
||||||
|
|
||||||
using Dino.Entities;
|
using Dino.Entities;
|
||||||
|
|
||||||
namespace Dino.Ui.AddConversation.Chat {
|
namespace Dino.Ui {
|
||||||
|
|
||||||
public class Dialog : Gtk.Dialog {
|
public class SelectContactDialog : Gtk.Dialog {
|
||||||
|
|
||||||
public signal void selected(Account account, Jid jid);
|
public signal void selected(Account account, Jid jid);
|
||||||
|
|
||||||
|
@ -17,7 +17,7 @@ public class Dialog : Gtk.Dialog {
|
||||||
private StreamInteractor stream_interactor;
|
private StreamInteractor stream_interactor;
|
||||||
private Gee.List<Account> accounts;
|
private Gee.List<Account> accounts;
|
||||||
|
|
||||||
public Dialog(StreamInteractor stream_interactor, Gee.List<Account> accounts) {
|
public SelectContactDialog(StreamInteractor stream_interactor, Gee.List<Account> accounts) {
|
||||||
Object(use_header_bar : 1);
|
Object(use_header_bar : 1);
|
||||||
modal = true;
|
modal = true;
|
||||||
|
|
||||||
|
@ -75,4 +75,20 @@ public class Dialog : Gtk.Dialog {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class AddChatDialog : SelectContactDialog {
|
||||||
|
|
||||||
|
public signal void added(Conversation conversation);
|
||||||
|
|
||||||
|
public AddChatDialog(StreamInteractor stream_interactor, Gee.List<Account> accounts) {
|
||||||
|
base(stream_interactor, accounts);
|
||||||
|
title = _("Start Chat");
|
||||||
|
ok_button.label = _("Start");
|
||||||
|
selected.connect((account, jid) => {
|
||||||
|
Conversation conversation = stream_interactor.get_module(ConversationManager.IDENTITY).create_conversation(jid, account, Conversation.Type.CHAT);
|
||||||
|
stream_interactor.get_module(ConversationManager.IDENTITY).start_conversation(conversation, true);
|
||||||
|
added(conversation);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
|
@ -3,7 +3,7 @@ using Gtk;
|
||||||
|
|
||||||
using Dino.Entities;
|
using Dino.Entities;
|
||||||
|
|
||||||
namespace Dino.Ui.AddConversation {
|
namespace Dino.Ui {
|
||||||
|
|
||||||
[GtkTemplate (ui = "/im/dino/add_conversation/select_jid_fragment.ui")]
|
[GtkTemplate (ui = "/im/dino/add_conversation/select_jid_fragment.ui")]
|
||||||
public class SelectJidFragment : Gtk.Box {
|
public class SelectJidFragment : Gtk.Box {
|
||||||
|
|
|
@ -40,9 +40,9 @@ public class Dino.Ui.Application : Gtk.Application, Dino.Application {
|
||||||
case "join":
|
case "join":
|
||||||
Dialog dialog = new Dialog.with_buttons(_("Join Conference"), window, Gtk.DialogFlags.MODAL | Gtk.DialogFlags.USE_HEADER_BAR, _("Join"), ResponseType.OK, _("Cancel"), ResponseType.CANCEL);
|
Dialog dialog = new Dialog.with_buttons(_("Join Conference"), window, Gtk.DialogFlags.MODAL | Gtk.DialogFlags.USE_HEADER_BAR, _("Join"), ResponseType.OK, _("Cancel"), ResponseType.CANCEL);
|
||||||
dialog.modal = true;
|
dialog.modal = true;
|
||||||
Widget ok_button = dialog.get_widget_for_response(ResponseType.OK);
|
Button ok_button = dialog.get_widget_for_response(ResponseType.OK) as Button;
|
||||||
ok_button.get_style_context().add_class("suggested-action");
|
ok_button.get_style_context().add_class("suggested-action");
|
||||||
AddConversation.Conference.ConferenceDetailsFragment conference_fragment = new AddConversation.Conference.ConferenceDetailsFragment(stream_interactor);
|
ConferenceDetailsFragment conference_fragment = new ConferenceDetailsFragment(stream_interactor, ok_button);
|
||||||
conference_fragment.jid = jid;
|
conference_fragment.jid = jid;
|
||||||
conference_fragment.set_editable();
|
conference_fragment.set_editable();
|
||||||
Box content_area = dialog.get_content_area();
|
Box content_area = dialog.get_content_area();
|
||||||
|
@ -64,14 +64,10 @@ public class Dino.Ui.Application : Gtk.Application, Dino.Application {
|
||||||
stream_interactor.get_module(ConversationManager.IDENTITY).start_conversation(conversation, true);
|
stream_interactor.get_module(ConversationManager.IDENTITY).start_conversation(conversation, true);
|
||||||
window.on_conversation_selected(conversation);
|
window.on_conversation_selected(conversation);
|
||||||
} else {
|
} else {
|
||||||
AddConversation.Chat.Dialog dialog = new AddConversation.Chat.Dialog(stream_interactor, stream_interactor.get_accounts());
|
AddChatDialog dialog = new AddChatDialog(stream_interactor, stream_interactor.get_accounts());
|
||||||
dialog.set_filter(jid);
|
dialog.set_filter(jid);
|
||||||
dialog.set_transient_for(window);
|
dialog.set_transient_for(window);
|
||||||
dialog.title = _("Start Chat");
|
dialog.added.connect((conversation) => {
|
||||||
dialog.ok_button.label = _("Start");
|
|
||||||
dialog.selected.connect((account, jid) => {
|
|
||||||
Conversation conversation = stream_interactor.get_module(ConversationManager.IDENTITY).create_conversation(jid, account, Conversation.Type.CHAT);
|
|
||||||
stream_interactor.get_module(ConversationManager.IDENTITY).start_conversation(conversation, true);
|
|
||||||
window.on_conversation_selected(conversation);
|
window.on_conversation_selected(conversation);
|
||||||
});
|
});
|
||||||
dialog.present();
|
dialog.present();
|
||||||
|
|
|
@ -26,13 +26,9 @@ public class ConversationListTitlebar : Gtk.HeaderBar {
|
||||||
private void create_add_menu(Window window) {
|
private void create_add_menu(Window window) {
|
||||||
SimpleAction contacts_action = new SimpleAction("add_chat", null);
|
SimpleAction contacts_action = new SimpleAction("add_chat", null);
|
||||||
contacts_action.activate.connect(() => {
|
contacts_action.activate.connect(() => {
|
||||||
AddConversation.Chat.Dialog add_chat_dialog = new AddConversation.Chat.Dialog(stream_interactor, stream_interactor.get_accounts());
|
AddChatDialog add_chat_dialog = new AddChatDialog(stream_interactor, stream_interactor.get_accounts());
|
||||||
add_chat_dialog.set_transient_for(window);
|
add_chat_dialog.set_transient_for(window);
|
||||||
add_chat_dialog.title = _("Start Chat");
|
add_chat_dialog.added.connect((conversation) => {
|
||||||
add_chat_dialog.ok_button.label = _("Start");
|
|
||||||
add_chat_dialog.selected.connect((account, jid) => {
|
|
||||||
Conversation conversation = stream_interactor.get_module(ConversationManager.IDENTITY).create_conversation(jid, account, Conversation.Type.CHAT);
|
|
||||||
stream_interactor.get_module(ConversationManager.IDENTITY).start_conversation(conversation, true);
|
|
||||||
conversation_opened(conversation);
|
conversation_opened(conversation);
|
||||||
});
|
});
|
||||||
add_chat_dialog.present();
|
add_chat_dialog.present();
|
||||||
|
@ -41,7 +37,7 @@ public class ConversationListTitlebar : Gtk.HeaderBar {
|
||||||
|
|
||||||
SimpleAction conference_action = new SimpleAction("add_conference", null);
|
SimpleAction conference_action = new SimpleAction("add_conference", null);
|
||||||
conference_action.activate.connect(() => {
|
conference_action.activate.connect(() => {
|
||||||
AddConversation.Conference.Dialog add_conference_dialog = new AddConversation.Conference.Dialog(stream_interactor);
|
AddConferenceDialog add_conference_dialog = new AddConferenceDialog(stream_interactor);
|
||||||
add_conference_dialog.set_transient_for(window);
|
add_conference_dialog.set_transient_for(window);
|
||||||
add_conference_dialog.conversation_opened.connect((conversation) => conversation_opened(conversation));
|
add_conference_dialog.conversation_opened.connect((conversation) => conversation_opened(conversation));
|
||||||
add_conference_dialog.present();
|
add_conference_dialog.present();
|
||||||
|
|
|
@ -144,6 +144,8 @@ public class List : ListBox {
|
||||||
private void header(ListBoxRow row, ListBoxRow? before_row) {
|
private void header(ListBoxRow row, ListBoxRow? before_row) {
|
||||||
if (row.get_header() == null && before_row != null) {
|
if (row.get_header() == null && before_row != null) {
|
||||||
row.set_header(new Separator(Orientation.HORIZONTAL));
|
row.set_header(new Separator(Orientation.HORIZONTAL));
|
||||||
|
} else if (row.get_header() != null && before_row == null) {
|
||||||
|
row.set_header(null);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,7 @@ public class Notifications : Object {
|
||||||
if (conversation == null) return;
|
if (conversation == null) return;
|
||||||
stream_interactor.get_module(PresenceManager.IDENTITY).approve_subscription(conversation.account, conversation.counterpart);
|
stream_interactor.get_module(PresenceManager.IDENTITY).approve_subscription(conversation.account, conversation.counterpart);
|
||||||
if (stream_interactor.get_module(RosterManager.IDENTITY).get_roster_item(conversation.account, conversation.counterpart) == null) {
|
if (stream_interactor.get_module(RosterManager.IDENTITY).get_roster_item(conversation.account, conversation.counterpart) == null) {
|
||||||
AddConversation.Chat.AddContactDialog dialog = new AddConversation.Chat.AddContactDialog(stream_interactor);
|
AddContactDialog dialog = new AddContactDialog(stream_interactor);
|
||||||
dialog.jid = conversation.counterpart.bare_jid.to_string();
|
dialog.jid = conversation.counterpart.bare_jid.to_string();
|
||||||
dialog.account = conversation.account;
|
dialog.account = conversation.account;
|
||||||
dialog.present();
|
dialog.present();
|
||||||
|
|
|
@ -29,7 +29,7 @@ public class View : Popover {
|
||||||
hide();
|
hide();
|
||||||
Gee.List<Account> acc_list = new ArrayList<Account>(Account.equals_func);
|
Gee.List<Account> acc_list = new ArrayList<Account>(Account.equals_func);
|
||||||
acc_list.add(conversation.account);
|
acc_list.add(conversation.account);
|
||||||
AddConversation.Chat.Dialog add_chat_dialog = new AddConversation.Chat.Dialog(stream_interactor, acc_list);
|
SelectContactDialog add_chat_dialog = new SelectContactDialog(stream_interactor, acc_list);
|
||||||
add_chat_dialog.set_transient_for(window);
|
add_chat_dialog.set_transient_for(window);
|
||||||
add_chat_dialog.title = _("Invite to Conference");
|
add_chat_dialog.title = _("Invite to Conference");
|
||||||
add_chat_dialog.ok_button.label = _("Invite");
|
add_chat_dialog.ok_button.label = _("Invite");
|
||||||
|
|
|
@ -163,7 +163,7 @@ public class Module : XmppStreamModule {
|
||||||
public override void attach(XmppStream stream) {
|
public override void attach(XmppStream stream) {
|
||||||
stream.add_flag(new Muc.Flag());
|
stream.add_flag(new Muc.Flag());
|
||||||
stream.get_module(Message.Module.IDENTITY).received_message.connect(on_received_message);
|
stream.get_module(Message.Module.IDENTITY).received_message.connect(on_received_message);
|
||||||
stream.get_module(Presence.Module.IDENTITY).received_presence.connect(on_received_presence);
|
stream.get_module(Presence.Module.IDENTITY).received_presence.connect(check_for_enter_error);
|
||||||
stream.get_module(Presence.Module.IDENTITY).received_available.connect(on_received_available);
|
stream.get_module(Presence.Module.IDENTITY).received_available.connect(on_received_available);
|
||||||
stream.get_module(Presence.Module.IDENTITY).received_unavailable.connect(on_received_unavailable);
|
stream.get_module(Presence.Module.IDENTITY).received_unavailable.connect(on_received_unavailable);
|
||||||
if (stream.get_module(ServiceDiscovery.Module.IDENTITY) != null) {
|
if (stream.get_module(ServiceDiscovery.Module.IDENTITY) != null) {
|
||||||
|
@ -179,7 +179,7 @@ public class Module : XmppStreamModule {
|
||||||
|
|
||||||
public override void detach(XmppStream stream) {
|
public override void detach(XmppStream stream) {
|
||||||
stream.get_module(Message.Module.IDENTITY).received_message.disconnect(on_received_message);
|
stream.get_module(Message.Module.IDENTITY).received_message.disconnect(on_received_message);
|
||||||
stream.get_module(Presence.Module.IDENTITY).received_presence.disconnect(on_received_presence);
|
stream.get_module(Presence.Module.IDENTITY).received_presence.disconnect(check_for_enter_error);
|
||||||
stream.get_module(Presence.Module.IDENTITY).received_available.disconnect(on_received_available);
|
stream.get_module(Presence.Module.IDENTITY).received_available.disconnect(on_received_available);
|
||||||
stream.get_module(Presence.Module.IDENTITY).received_unavailable.disconnect(on_received_unavailable);
|
stream.get_module(Presence.Module.IDENTITY).received_unavailable.disconnect(on_received_unavailable);
|
||||||
}
|
}
|
||||||
|
@ -206,7 +206,7 @@ public class Module : XmppStreamModule {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void on_received_presence(XmppStream stream, Presence.Stanza presence) {
|
private void check_for_enter_error(XmppStream stream, Presence.Stanza presence) {
|
||||||
Flag flag = stream.get_flag(Flag.IDENTITY);
|
Flag flag = stream.get_flag(Flag.IDENTITY);
|
||||||
if (presence.is_error() && flag.is_muc_enter_outstanding() && flag.is_occupant(presence.from)) {
|
if (presence.is_error() && flag.is_muc_enter_outstanding() && flag.is_occupant(presence.from)) {
|
||||||
string bare_jid = get_bare_jid(presence.from);
|
string bare_jid = get_bare_jid(presence.from);
|
||||||
|
|
|
@ -12,7 +12,9 @@ namespace Xmpp.Xep.Ping {
|
||||||
public void send_ping(XmppStream stream, string jid, owned OnResult? listener) {
|
public void send_ping(XmppStream stream, string jid, owned OnResult? listener) {
|
||||||
Iq.Stanza iq = new Iq.Stanza.get(new StanzaNode.build("ping", NS_URI).add_self_xmlns());
|
Iq.Stanza iq = new Iq.Stanza.get(new StanzaNode.build("ping", NS_URI).add_self_xmlns());
|
||||||
iq.to = jid;
|
iq.to = jid;
|
||||||
stream.get_module(Iq.Module.IDENTITY).send_iq(stream, iq, (stream) => { listener(stream); });
|
stream.get_module(Iq.Module.IDENTITY).send_iq(stream, iq, (stream) => {
|
||||||
|
if (listener != null) listener(stream);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
public override void attach(XmppStream stream) {
|
public override void attach(XmppStream stream) {
|
||||||
|
|
Loading…
Reference in a new issue