Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
converse.js
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
converse.js
Commits
34b8cd2e
Commit
34b8cd2e
authored
Mar 28, 2019
by
JC Brand
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Prevent user from adding themselves as contact
parent
ab76a905
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
35 additions
and
25 deletions
+35
-25
CHANGES.md
CHANGES.md
+1
-0
dist/converse.js
dist/converse.js
+12
-11
spec/controlbox.js
spec/controlbox.js
+11
-5
src/converse-rosterview.js
src/converse-rosterview.js
+8
-6
src/templates/add_contact_modal.html
src/templates/add_contact_modal.html
+3
-3
No files found.
CHANGES.md
View file @
34b8cd2e
...
@@ -5,6 +5,7 @@
...
@@ -5,6 +5,7 @@
-
Updated translation: lt
-
Updated translation: lt
-
Upgrade to Backbone 1.4.0, Strophe 1.3.2 and Jasmine 2.99.2
-
Upgrade to Backbone 1.4.0, Strophe 1.3.2 and Jasmine 2.99.2
-
Remove dependency on (our fork of) Awesomplete
-
Remove dependency on (our fork of) Awesomplete
-
Prevent user from adding themselves as contact
-
Fix "flashing" of roster filter when you have less than 5 roster contacts
-
Fix "flashing" of roster filter when you have less than 5 roster contacts
-
Fix handling of CAPTCHAs offered by ejabberd
-
Fix handling of CAPTCHAs offered by ejabberd
-
Don't send out receipts or markers for MAM messages
-
Don't send out receipts or markers for MAM messages
...
...
dist/converse.js
View file @
34b8cd2e
...
@@ -59145,7 +59145,7 @@ _converse_headless_converse_core__WEBPACK_IMPORTED_MODULE_4__["default"].plugins
...
@@ -59145,7 +59145,7 @@ _converse_headless_converse_core__WEBPACK_IMPORTED_MODULE_4__["default"].plugins
}));
}));
if (list.length !== 1) {
if (list.length !== 1) {
const el = this.el.querySelector('.
suggestion-box__name .
invalid-feedback');
const el = this.el.querySelector('.invalid-feedback');
el.textContent = __('Sorry, could not find a contact with that name');
el.textContent = __('Sorry, could not find a contact with that name');
u.addClass('d-block', el);
u.addClass('d-block', el);
return;
return;
...
@@ -59163,16 +59163,19 @@ _converse_headless_converse_core__WEBPACK_IMPORTED_MODULE_4__["default"].plugins
...
@@ -59163,16 +59163,19 @@ _converse_headless_converse_core__WEBPACK_IMPORTED_MODULE_4__["default"].plugins
},
},
validateSubmission(jid) {
validateSubmission(jid) {
const el = this.el.querySelector('.invalid-feedback');
if (!jid || _.compact(jid.split('@')).length < 2) {
if (!jid || _.compact(jid.split('@')).length < 2) {
// XXX: we used to have to do this manually, instead of via
// toHTML because Awesomplete messes things up and
// confuses Snabbdom
// We now use _converse.AutoComplete, can this be removed?
u.addClass('is-invalid', this.el.querySelector('input[name="jid"]'));
u.addClass('is-invalid', this.el.querySelector('input[name="jid"]'));
u.addClass('d-block', this.el.querySelector('.suggestion-box__jid .invalid-feedback'));
u.addClass('d-block', el);
return false;
} else if (Strophe.getBareJidFromJid(jid) === _converse.bare_jid) {
el.textContent = __('You cannot add yourself as a contact');
u.addClass('d-block', el);
return false;
return false;
}
}
u.removeClass('d-block', el);
return true;
return true;
},
},
...
@@ -92176,17 +92179,15 @@ __p += '\n value="' +
...
@@ -92176,17 +92179,15 @@ __p += '\n value="' +
__e(o.jid) +
__e(o.jid) +
'"\n class="form-control suggestion-box__input"\n placeholder="' +
'"\n class="form-control suggestion-box__input"\n placeholder="' +
__e(o.contact_placeholder) +
__e(o.contact_placeholder) +
'"/>\n <div class="invalid-feedback">' +
'"/>\n <span class="suggestion-box__additions visually-hidden" role="status" aria-live="assertive" aria-relevant="additions"></span>\n </div>\n </div>\n <div class="form-group">\n <label class="clearfix" for="name">' +
__e(o.error_message) +
'</div>\n <span class="suggestion-box__additions visually-hidden" role="status" aria-live="assertive" aria-relevant="additions"></span>\n </div>\n </div>\n <div class="form-group">\n <label class="clearfix" for="name">' +
__e(o.label_nickname) +
__e(o.label_nickname) +
':</label>\n <div class="suggestion-box suggestion-box__name">\n <ul class="suggestion-box__results suggestion-box__results--above" hidden=""></ul>\n <input type="text" name="name" value="' +
':</label>\n <div class="suggestion-box suggestion-box__name">\n <ul class="suggestion-box__results suggestion-box__results--above" hidden=""></ul>\n <input type="text" name="name" value="' +
__e(o.nickname) +
__e(o.nickname) +
'"\n class="form-control suggestion-box__input"\n placeholder="' +
'"\n class="form-control suggestion-box__input"\n placeholder="' +
__e(o.nickname_placeholder) +
__e(o.nickname_placeholder) +
'"/>\n <div class="invalid-feedback">' +
'"/>\n <
span class="suggestion-box__additions visually-hidden" role="status" aria-live="assertive" aria-relevant="additions"></span>\n </div>\n </div>\n <div class="form-group">\n <
div class="invalid-feedback">' +
__e(o.error_message) +
__e(o.error_message) +
'</div>\n
<span class="suggestion-box__additions visually-hidden" role="status" aria-live="assertive" aria-relevant="additions"></span>\n </div>\n\n
</div>\n <button type="submit" class="btn btn-primary">' +
'</div>\n </div>\n <button type="submit" class="btn btn-primary">' +
__e(o.label_add) +
__e(o.label_add) +
'</button>\n </div>\n </form>\n </div>\n </div>\n</div>\n';
'</button>\n </div>\n </form>\n </div>\n </div>\n</div>\n';
return __p
return __p
spec/controlbox.js
View file @
34b8cd2e
...
@@ -322,7 +322,9 @@
...
@@ -322,7 +322,9 @@
'
open
'
:
_
.
noop
,
'
open
'
:
_
.
noop
,
'
send
'
:
function
()
{
'
send
'
:
function
()
{
const
value
=
modal
.
el
.
querySelector
(
'
input[name="name"]
'
).
value
;
const
value
=
modal
.
el
.
querySelector
(
'
input[name="name"]
'
).
value
;
if
(
value
===
'
ambiguous
'
)
{
if
(
value
===
'
dummy
'
)
{
xhr
.
responseText
=
JSON
.
stringify
([{
"
jid
"
:
"
dummy@localhost
"
,
"
fullname
"
:
"
Max Mustermann
"
}]);
}
else
if
(
value
===
'
ambiguous
'
)
{
xhr
.
responseText
=
JSON
.
stringify
([
xhr
.
responseText
=
JSON
.
stringify
([
{
"
jid
"
:
"
marty@mcfly.net
"
,
"
fullname
"
:
"
Marty McFly
"
},
{
"
jid
"
:
"
marty@mcfly.net
"
,
"
fullname
"
:
"
Marty McFly
"
},
{
"
jid
"
:
"
doc@brown.com
"
,
"
fullname
"
:
"
Doc Brown
"
}
{
"
jid
"
:
"
doc@brown.com
"
,
"
fullname
"
:
"
Doc Brown
"
}
...
@@ -358,16 +360,20 @@
...
@@ -358,16 +360,20 @@
const
input_el
=
modal
.
el
.
querySelector
(
'
input[name="name"]
'
);
const
input_el
=
modal
.
el
.
querySelector
(
'
input[name="name"]
'
);
input_el
.
value
=
'
ambiguous
'
;
input_el
.
value
=
'
ambiguous
'
;
modal
.
el
.
querySelector
(
'
button[type="submit"]
'
).
click
();
modal
.
el
.
querySelector
(
'
button[type="submit"]
'
).
click
();
let
feedback_el
=
modal
.
el
.
querySelector
(
'
.invalid-feedback
'
);
let
feedback_el
=
modal
.
el
.
querySelector
(
'
.suggestion-box__name .invalid-feedback
'
);
expect
(
feedback_el
.
textContent
).
toBe
(
'
Sorry, could not find a contact with that name
'
);
expect
(
feedback_el
.
textContent
).
toBe
(
'
Sorry, could not find a contact with that name
'
);
feedback_el
.
textContent
=
''
;
feedback_el
.
textContent
=
''
;
input_el
.
value
=
'
insufficient
'
;
input_el
.
value
=
'
insufficient
'
;
modal
.
el
.
querySelector
(
'
button[type="submit"]
'
).
click
();
modal
.
el
.
querySelector
(
'
button[type="submit"]
'
).
click
();
feedback_el
=
modal
.
el
.
querySelector
(
'
.invalid-feedback
'
);
feedback_el
=
modal
.
el
.
querySelector
(
'
.suggestion-box__name .invalid-feedback
'
);
expect
(
feedback_el
.
textContent
).
toBe
(
'
Sorry, could not find a contact with that name
'
);
expect
(
feedback_el
.
textContent
).
toBe
(
'
Sorry, could not find a contact with that name
'
);
feedback_el
.
textContent
=
''
;
input_el
.
value
=
'
dummy
'
;
modal
.
el
.
querySelector
(
'
button[type="submit"]
'
).
click
();
feedback_el
=
modal
.
el
.
querySelector
(
'
.invalid-feedback
'
);
expect
(
feedback_el
.
textContent
).
toBe
(
'
You cannot add yourself as a contact
'
);
input_el
.
value
=
'
Marty McFly
'
;
input_el
.
value
=
'
Marty McFly
'
;
modal
.
el
.
querySelector
(
'
button[type="submit"]
'
).
click
();
modal
.
el
.
querySelector
(
'
button[type="submit"]
'
).
click
();
...
...
src/converse-rosterview.js
View file @
34b8cd2e
...
@@ -190,7 +190,7 @@ converse.plugins.add('converse-rosterview', {
...
@@ -190,7 +190,7 @@ converse.plugins.add('converse-rosterview', {
const
r
=
this
.
xhr
.
responseText
;
const
r
=
this
.
xhr
.
responseText
;
const
list
=
JSON
.
parse
(
r
).
map
(
i
=>
({
'
label
'
:
i
.
fullname
||
i
.
jid
,
'
value
'
:
i
.
jid
}));
const
list
=
JSON
.
parse
(
r
).
map
(
i
=>
({
'
label
'
:
i
.
fullname
||
i
.
jid
,
'
value
'
:
i
.
jid
}));
if
(
list
.
length
!==
1
)
{
if
(
list
.
length
!==
1
)
{
const
el
=
this
.
el
.
querySelector
(
'
.
suggestion-box__name .
invalid-feedback
'
);
const
el
=
this
.
el
.
querySelector
(
'
.invalid-feedback
'
);
el
.
textContent
=
__
(
'
Sorry, could not find a contact with that name
'
)
el
.
textContent
=
__
(
'
Sorry, could not find a contact with that name
'
)
u
.
addClass
(
'
d-block
'
,
el
);
u
.
addClass
(
'
d-block
'
,
el
);
return
;
return
;
...
@@ -206,15 +206,17 @@ converse.plugins.add('converse-rosterview', {
...
@@ -206,15 +206,17 @@ converse.plugins.add('converse-rosterview', {
},
},
validateSubmission
(
jid
)
{
validateSubmission
(
jid
)
{
const
el
=
this
.
el
.
querySelector
(
'
.invalid-feedback
'
);
if
(
!
jid
||
_
.
compact
(
jid
.
split
(
'
@
'
)).
length
<
2
)
{
if
(
!
jid
||
_
.
compact
(
jid
.
split
(
'
@
'
)).
length
<
2
)
{
// XXX: we used to have to do this manually, instead of via
// toHTML because Awesomplete messes things up and
// confuses Snabbdom
// We now use _converse.AutoComplete, can this be removed?
u
.
addClass
(
'
is-invalid
'
,
this
.
el
.
querySelector
(
'
input[name="jid"]
'
));
u
.
addClass
(
'
is-invalid
'
,
this
.
el
.
querySelector
(
'
input[name="jid"]
'
));
u
.
addClass
(
'
d-block
'
,
this
.
el
.
querySelector
(
'
.suggestion-box__jid .invalid-feedback
'
));
u
.
addClass
(
'
d-block
'
,
el
);
return
false
;
}
else
if
(
Strophe
.
getBareJidFromJid
(
jid
)
===
_converse
.
bare_jid
)
{
el
.
textContent
=
__
(
'
You cannot add yourself as a contact
'
)
u
.
addClass
(
'
d-block
'
,
el
);
return
false
;
return
false
;
}
}
u
.
removeClass
(
'
d-block
'
,
el
);
return
true
;
return
true
;
},
},
...
...
src/templates/add_contact_modal.html
View file @
34b8cd2e
...
@@ -17,7 +17,6 @@
...
@@ -17,7 +17,6 @@
value=
"{{{o.jid}}}"
value=
"{{{o.jid}}}"
class=
"form-control suggestion-box__input"
class=
"form-control suggestion-box__input"
placeholder=
"{{{o.contact_placeholder}}}"
/>
placeholder=
"{{{o.contact_placeholder}}}"
/>
<div
class=
"invalid-feedback"
>
{{{o.error_message}}}
</div>
<span
class=
"suggestion-box__additions visually-hidden"
role=
"status"
aria-live=
"assertive"
aria-relevant=
"additions"
></span>
<span
class=
"suggestion-box__additions visually-hidden"
role=
"status"
aria-live=
"assertive"
aria-relevant=
"additions"
></span>
</div>
</div>
</div>
</div>
...
@@ -28,10 +27,11 @@
...
@@ -28,10 +27,11 @@
<input
type=
"text"
name=
"name"
value=
"{{{o.nickname}}}"
<input
type=
"text"
name=
"name"
value=
"{{{o.nickname}}}"
class=
"form-control suggestion-box__input"
class=
"form-control suggestion-box__input"
placeholder=
"{{{o.nickname_placeholder}}}"
/>
placeholder=
"{{{o.nickname_placeholder}}}"
/>
<div
class=
"invalid-feedback"
>
{{{o.error_message}}}
</div>
<span
class=
"suggestion-box__additions visually-hidden"
role=
"status"
aria-live=
"assertive"
aria-relevant=
"additions"
></span>
<span
class=
"suggestion-box__additions visually-hidden"
role=
"status"
aria-live=
"assertive"
aria-relevant=
"additions"
></span>
</div>
</div>
</div>
<div
class=
"form-group"
>
<div
class=
"invalid-feedback"
>
{{{o.error_message}}}
</div>
</div>
</div>
<button
type=
"submit"
class=
"btn btn-primary"
>
{{{o.label_add}}}
</button>
<button
type=
"submit"
class=
"btn btn-primary"
>
{{{o.label_add}}}
</button>
</div>
</div>
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment