-
-
Notifications
You must be signed in to change notification settings - Fork 776
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add a modal to start chats with non-roster contacts
- Loading branch information
Showing
15 changed files
with
114 additions
and
55 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
import { __ } from 'i18n'; | ||
import { html } from 'lit'; | ||
|
||
/** | ||
* @param {import('../new-chat.js').default} el | ||
*/ | ||
export default (el) => { | ||
const i18n_start_chat = __('Start Chat'); | ||
const i18n_xmpp_address = __('XMPP Address'); | ||
return html` <div class="modal-body"> | ||
<span class="modal-alert"></span> | ||
<form @submit=${/** @param {SubmitEvent} ev */(ev) => el.startChatFromForm(ev)}> | ||
<div class="mb-3"> | ||
<label class="form-label" for="jid">${i18n_xmpp_address}</label> | ||
<input type="text" name="jid" class="form-control" required /> | ||
</div> | ||
<button type="submit" class="btn btn-primary">${i18n_start_chat}</button> | ||
</form> | ||
</div>`; | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,7 +2,7 @@ | |
|
||
// See: https://xmpp.org/rfcs/rfc3921.html | ||
|
||
const { Strophe, stx } = converse.env; | ||
const { u, $iq, $pres, sizzle, Strophe, stx } = converse.env; | ||
|
||
describe("The Protocol", function () { | ||
|
||
|
@@ -40,7 +40,6 @@ describe("The Protocol", function () { | |
it("Subscribe to contact, contact accepts and subscribes back", | ||
mock.initConverse([], { roster_groups: false }, async function (_converse) { | ||
|
||
const { u, $iq, $pres, sizzle, Strophe } = converse.env; | ||
let stanza; | ||
await mock.waitForRoster(_converse, 'current', 0); | ||
await mock.waitUntilDiscoConfirmed(_converse, 'montague.lit', [], ['vcard-temp']); | ||
|
@@ -51,7 +50,6 @@ describe("The Protocol", function () { | |
mock.openControlBox(_converse); | ||
const cbview = _converse.chatboxviews.get('controlbox'); | ||
|
||
spyOn(_converse.roster, "addContact").and.callThrough(); | ||
spyOn(_converse.roster, "sendContactAddIQ").and.callThrough(); | ||
spyOn(_converse.api.vcard, "get").and.callThrough(); | ||
|
||
|
@@ -74,7 +72,6 @@ describe("The Protocol", function () { | |
* subscription, the user's client SHOULD perform a "roster set" | ||
* for the new roster item. | ||
*/ | ||
expect(_converse.roster.addContact).toHaveBeenCalled(); | ||
|
||
/* The request consists of sending an IQ | ||
* stanza of type='set' containing a <query/> element qualified by | ||
|
@@ -100,14 +97,14 @@ describe("The Protocol", function () { | |
const IQ_stanzas = _converse.api.connection.get().IQ_stanzas; | ||
const roster_set_stanza = IQ_stanzas.filter(s => sizzle('query[xmlns="jabber:iq:roster"]', s)).pop(); | ||
|
||
expect(Strophe.serialize(roster_set_stanza)).toBe( | ||
`<iq id="${roster_set_stanza.getAttribute('id')}" type="set" xmlns="jabber:client">`+ | ||
`<query xmlns="jabber:iq:roster">`+ | ||
`<item jid="[email protected]" name="Chris Contact">`+ | ||
`<group>My Buddies</group>`+ | ||
`</item>`+ | ||
`</query>`+ | ||
`</iq>` | ||
expect(roster_set_stanza).toEqualStanza( | ||
stx`<iq id="${roster_set_stanza.getAttribute('id')}" type="set" xmlns="jabber:client"> | ||
<query xmlns="jabber:iq:roster"> | ||
<item jid="[email protected]" name="Chris Contact"> | ||
<group>My Buddies</group> | ||
</item> | ||
</query> | ||
</iq>` | ||
); | ||
|
||
const sent_stanzas = []; | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,9 +1,21 @@ | ||
export default class AddContactModal extends BaseModal { | ||
renderModal(): import("lit").TemplateResult<1>; | ||
getModalTitle(): any; | ||
validateSubmission(jid: any): boolean; | ||
afterSubmission(_form: any, jid: any, name: any, group: any): void; | ||
addContactFromForm(ev: any): Promise<void>; | ||
/** | ||
* @param {string} jid | ||
*/ | ||
validateSubmission(jid: string): boolean; | ||
/** | ||
* @param {HTMLFormElement} _form | ||
* @param {string} jid | ||
* @param {string} name | ||
* @param {FormDataEntryValue} group | ||
*/ | ||
afterSubmission(_form: HTMLFormElement, jid: string, name: string, group: FormDataEntryValue): Promise<void>; | ||
/** | ||
* @param {Event} ev | ||
*/ | ||
addContactFromForm(ev: Event): Promise<void>; | ||
} | ||
import BaseModal from 'plugins/modal/modal.js'; | ||
//# sourceMappingURL=add-contact.d.ts.map |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
export default class NewChatModal extends BaseModal { | ||
renderModal(): import("lit").TemplateResult<1>; | ||
getModalTitle(): any; | ||
/** | ||
* @param {string} jid | ||
*/ | ||
validateSubmission(jid: string): boolean; | ||
/** | ||
* @param {HTMLFormElement} _form | ||
* @param {string} jid | ||
*/ | ||
afterSubmission(_form: HTMLFormElement, jid: string): Promise<void>; | ||
/** | ||
* @param {SubmitEvent} ev | ||
*/ | ||
startChatFromForm(ev: SubmitEvent): Promise<void>; | ||
} | ||
import BaseModal from 'plugins/modal/modal.js'; | ||
//# sourceMappingURL=new-chat.d.ts.map |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,3 +1,3 @@ | ||
declare function _default(el: any): import("lit").TemplateResult<1>; | ||
declare function _default(el: import("../add-contact.js").default): import("lit").TemplateResult<1>; | ||
export default _default; | ||
//# sourceMappingURL=add-contact.d.ts.map |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
declare function _default(el: import("../new-chat.js").default): import("lit").TemplateResult<1>; | ||
export default _default; | ||
//# sourceMappingURL=new-chat.d.ts.map |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,4 +1,3 @@ | ||
declare function _default(el: RosterView): import("lit").TemplateResult<1>; | ||
declare function _default(el: import("../rosterview").default): import("lit").TemplateResult<1>; | ||
export default _default; | ||
export type RosterView = import("../rosterview").default; | ||
//# sourceMappingURL=roster.d.ts.map |