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
c8f0fd2a
Commit
c8f0fd2a
authored
Sep 04, 2019
by
JC Brand
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactor cleaner separation between converse-vcard and other plugins
parent
64135b77
Changes
9
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
129 additions
and
97 deletions
+129
-97
spec/messages.js
spec/messages.js
+1
-1
spec/protocol.js
spec/protocol.js
+1
-0
spec/roster.js
spec/roster.js
+35
-36
src/converse-profile.js
src/converse-profile.js
+2
-1
src/headless/converse-core.js
src/headless/converse-core.js
+4
-0
src/headless/converse-muc.js
src/headless/converse-muc.js
+1
-1
src/headless/converse-roster.js
src/headless/converse-roster.js
+28
-42
src/headless/converse-vcard.js
src/headless/converse-vcard.js
+56
-15
tests/mock.js
tests/mock.js
+1
-1
No files found.
spec/messages.js
View file @
c8f0fd2a
...
@@ -1712,7 +1712,7 @@
...
@@ -1712,7 +1712,7 @@
'
message
'
:
msg_text
'
message
'
:
msg_text
});
});
view
.
model
.
sendMessage
(
msg_text
);
view
.
model
.
sendMessage
(
msg_text
);
await
u
.
waitUntil
(()
=>
sizzle
(
'
.chat-msg .chat-msg__text
'
,
chat_content
).
length
===
5
);
await
u
.
waitUntil
(()
=>
sizzle
(
'
.chat-msg .chat-msg__text
'
,
chat_content
).
length
===
4
,
1000
);
msg_txt
=
sizzle
(
'
.chat-msg:last .chat-msg__text
'
,
chat_content
).
pop
().
textContent
;
msg_txt
=
sizzle
(
'
.chat-msg:last .chat-msg__text
'
,
chat_content
).
pop
().
textContent
;
expect
(
msg_txt
).
toEqual
(
msg_text
);
expect
(
msg_txt
).
toEqual
(
msg_text
);
...
...
spec/protocol.js
View file @
c8f0fd2a
...
@@ -271,6 +271,7 @@
...
@@ -271,6 +271,7 @@
'
jid
'
:
'
contact@example.org
'
,
'
jid
'
:
'
contact@example.org
'
,
'
subscription
'
:
'
to
'
,
'
subscription
'
:
'
to
'
,
'
name
'
:
'
Nicky
'
});
'
name
'
:
'
Nicky
'
});
_converse
.
connection
.
_dataRecv
(
test_utils
.
createRequest
(
stanza
));
_converse
.
connection
.
_dataRecv
(
test_utils
.
createRequest
(
stanza
));
// Check that the IQ set was acknowledged.
// Check that the IQ set was acknowledged.
expect
(
Strophe
.
serialize
(
sent_stanza
)).
toBe
(
// Strophe adds the xmlns attr (although not in spec)
expect
(
Strophe
.
serialize
(
sent_stanza
)).
toBe
(
// Strophe adds the xmlns attr (although not in spec)
...
...
spec/roster.js
View file @
c8f0fd2a
This diff is collapsed.
Click to expand it.
src/converse-profile.js
View file @
c8f0fd2a
...
@@ -310,7 +310,8 @@ converse.plugins.add('converse-profile', {
...
@@ -310,7 +310,8 @@ converse.plugins.add('converse-profile', {
/******************** Event Handlers ********************/
/******************** Event Handlers ********************/
_converse
.
api
.
listen
.
on
(
'
controlBoxPaneInitialized
'
,
(
view
)
=>
{
_converse
.
api
.
listen
.
on
(
'
controlBoxPaneInitialized
'
,
async
view
=>
{
await
_converse
.
api
.
waitUntil
(
'
statusInitialized
'
);
_converse
.
xmppstatusview
=
new
_converse
.
XMPPStatusView
({
'
model
'
:
_converse
.
xmppstatus
});
_converse
.
xmppstatusview
=
new
_converse
.
XMPPStatusView
({
'
model
'
:
_converse
.
xmppstatus
});
view
.
el
.
insertAdjacentElement
(
'
afterBegin
'
,
_converse
.
xmppstatusview
.
render
().
el
);
view
.
el
.
insertAdjacentElement
(
'
afterBegin
'
,
_converse
.
xmppstatusview
.
render
().
el
);
});
});
...
...
src/headless/converse-core.js
View file @
c8f0fd2a
...
@@ -1288,6 +1288,10 @@ _converse.initialize = async function (settings, callback) {
...
@@ -1288,6 +1288,10 @@ _converse.initialize = async function (settings, callback) {
});
});
},
},
getNickname
()
{
return
_converse
.
nickname
;
},
constructPresence
(
type
,
status_message
)
{
constructPresence
(
type
,
status_message
)
{
let
presence
;
let
presence
;
type
=
_
.
isString
(
type
)
?
type
:
(
this
.
get
(
'
status
'
)
||
_converse
.
default_state
);
type
=
_
.
isString
(
type
)
?
type
:
(
this
.
get
(
'
status
'
)
||
_converse
.
default_state
);
...
...
src/headless/converse-muc.js
View file @
c8f0fd2a
...
@@ -222,7 +222,7 @@ converse.plugins.add('converse-muc', {
...
@@ -222,7 +222,7 @@ converse.plugins.add('converse-muc', {
throw
new
Error
(
throw
new
Error
(
"
Can't call _converse.getDefaultMUCNickname before the statusInitialized has been fired.
"
);
"
Can't call _converse.getDefaultMUCNickname before the statusInitialized has been fired.
"
);
}
}
const
nick
=
_converse
.
nickname
||
(
_converse
.
vcards
?
_converse
.
xmppstatus
.
vcard
.
get
(
'
nickname
'
)
:
undefined
);
const
nick
=
_converse
.
xmppstatus
.
getNickname
(
);
if
(
nick
)
{
if
(
nick
)
{
return
nick
;
return
nick
;
}
else
if
(
_converse
.
muc_nickname_from_jid
)
{
}
else
if
(
_converse
.
muc_nickname_from_jid
)
{
...
...
src/headless/converse-roster.js
View file @
c8f0fd2a
...
@@ -15,7 +15,7 @@ const u = converse.env.utils;
...
@@ -15,7 +15,7 @@ const u = converse.env.utils;
converse
.
plugins
.
add
(
'
converse-roster
'
,
{
converse
.
plugins
.
add
(
'
converse-roster
'
,
{
dependencies
:
[
"
converse-vcard
"
],
dependencies
:
[],
initialize
()
{
initialize
()
{
/* The initialize function gets called as soon as the plugin is
/* The initialize function gets called as soon as the plugin is
...
@@ -221,30 +221,12 @@ converse.plugins.add('converse-roster', {
...
@@ -221,30 +221,12 @@ converse.plugins.add('converse-roster', {
});
});
_converse
.
ModelWithVCardAndPresence
=
Backbone
.
Model
.
extend
({
/**
initialize
()
{
* @class
this
.
setVCard
();
* @namespace _converse.RosterContact
this
.
setPresence
();
* @memberOf _converse
},
*/
_converse
.
RosterContact
=
Backbone
.
Model
.
extend
({
setVCard
()
{
if
(
!
_converse
.
vcards
)
{
// VCards aren't supported
return
;
}
const
jid
=
this
.
get
(
'
jid
'
);
this
.
vcard
=
_converse
.
vcards
.
findWhere
({
'
jid
'
:
jid
})
||
_converse
.
vcards
.
create
({
'
jid
'
:
jid
});
},
setPresence
()
{
const
jid
=
this
.
get
(
'
jid
'
);
this
.
presence
=
_converse
.
presences
.
findWhere
({
'
jid
'
:
jid
})
||
_converse
.
presences
.
create
({
'
jid
'
:
jid
});
}
});
_converse
.
RosterContact
=
_converse
.
ModelWithVCardAndPresence
.
extend
({
defaults
:
{
defaults
:
{
'
chat_state
'
:
undefined
,
'
chat_state
'
:
undefined
,
'
image
'
:
_converse
.
DEFAULT_IMAGE
,
'
image
'
:
_converse
.
DEFAULT_IMAGE
,
...
@@ -253,13 +235,10 @@ converse.plugins.add('converse-roster', {
...
@@ -253,13 +235,10 @@ converse.plugins.add('converse-roster', {
'
status
'
:
undefined
,
'
status
'
:
undefined
,
},
},
initialize
(
attributes
)
{
async
initialize
(
attributes
)
{
_converse
.
ModelWithVCardAndPresence
.
prototype
.
initialize
.
apply
(
this
,
arguments
);
this
.
setPresence
();
const
{
jid
}
=
attributes
;
const
{
jid
}
=
attributes
,
const
bare_jid
=
Strophe
.
getBareJidFromJid
(
jid
).
toLowerCase
();
bare_jid
=
Strophe
.
getBareJidFromJid
(
jid
).
toLowerCase
(),
resource
=
Strophe
.
getResourceFromJid
(
jid
);
attributes
.
jid
=
bare_jid
;
attributes
.
jid
=
bare_jid
;
this
.
set
(
_
.
assignIn
({
this
.
set
(
_
.
assignIn
({
'
groups
'
:
[],
'
groups
'
:
[],
...
@@ -276,24 +255,31 @@ converse.plugins.add('converse-roster', {
...
@@ -276,24 +255,31 @@ converse.plugins.add('converse-roster', {
*/
*/
this
.
presence
.
on
(
'
change:show
'
,
()
=>
_converse
.
api
.
trigger
(
'
contactPresenceChanged
'
,
this
));
this
.
presence
.
on
(
'
change:show
'
,
()
=>
_converse
.
api
.
trigger
(
'
contactPresenceChanged
'
,
this
));
this
.
presence
.
on
(
'
change:show
'
,
()
=>
this
.
trigger
(
'
presenceChanged
'
));
this
.
presence
.
on
(
'
change:show
'
,
()
=>
this
.
trigger
(
'
presenceChanged
'
));
/**
* Synchronous event which provides a hook for further initializing a RosterContact
* @event _converse#rosterContactInitialized
* @param { _converse.RosterContact } contact
*/
await
_converse
.
api
.
trigger
(
'
rosterContactInitialized
'
,
this
,
{
'
Synchronous
'
:
true
});
},
setPresence
()
{
const
jid
=
this
.
get
(
'
jid
'
);
this
.
presence
=
_converse
.
presences
.
findWhere
({
'
jid
'
:
jid
})
||
_converse
.
presences
.
create
({
'
jid
'
:
jid
});
},
},
getDisplayName
()
{
getDisplayName
()
{
// Gets overridden in converse-vcard where the fullname is may be returned
if
(
this
.
get
(
'
nickname
'
))
{
if
(
this
.
get
(
'
nickname
'
))
{
return
this
.
get
(
'
nickname
'
);
return
this
.
get
(
'
nickname
'
);
}
else
if
(
this
.
vcard
)
{
return
this
.
vcard
.
getDisplayName
();
}
else
{
}
else
{
return
this
.
get
(
'
jid
'
);
return
this
.
get
(
'
jid
'
);
}
}
},
},
getFullname
()
{
getFullname
()
{
if
(
this
.
vcard
)
{
// Gets overridden in converse-vcard where the fullname may be returned
return
this
.
vcard
.
get
(
'
fullname
'
);
}
else
{
return
this
.
get
(
'
jid
'
);
return
this
.
get
(
'
jid
'
);
}
},
},
/**
/**
...
@@ -308,7 +294,7 @@ converse.plugins.add('converse-roster', {
...
@@ -308,7 +294,7 @@ converse.plugins.add('converse-roster', {
if
(
message
&&
message
!==
""
)
{
if
(
message
&&
message
!==
""
)
{
pres
.
c
(
"
status
"
).
t
(
message
).
up
();
pres
.
c
(
"
status
"
).
t
(
message
).
up
();
}
}
const
nick
=
_converse
.
nickname
||
_converse
.
xmppstatus
.
vcard
.
get
(
'
nickname
'
)
||
_converse
.
xmppstatus
.
vcard
.
get
(
'
fullname
'
);
const
nick
=
_converse
.
xmppstatus
.
getNickname
(
);
if
(
nick
)
{
if
(
nick
)
{
pres
.
c
(
'
nick
'
,
{
'
xmlns
'
:
Strophe
.
NS
.
NICK
}).
t
(
nick
).
up
();
pres
.
c
(
'
nick
'
,
{
'
xmlns
'
:
Strophe
.
NS
.
NICK
}).
t
(
nick
).
up
();
}
}
...
@@ -483,11 +469,11 @@ converse.plugins.add('converse-roster', {
...
@@ -483,11 +469,11 @@ converse.plugins.add('converse-roster', {
},
},
subscribeToSuggestedItems
(
msg
)
{
subscribeToSuggestedItems
(
msg
)
{
_
.
each
(
msg
.
querySelectorAll
(
'
item
'
),
function
(
item
)
{
Array
.
from
(
msg
.
querySelectorAll
(
'
item
'
)).
forEach
(
item
=>
{
if
(
item
.
getAttribute
(
'
action
'
)
===
'
add
'
)
{
if
(
item
.
getAttribute
(
'
action
'
)
===
'
add
'
)
{
_converse
.
roster
.
addAndSubscribe
(
_converse
.
roster
.
addAndSubscribe
(
item
.
getAttribute
(
'
jid
'
),
item
.
getAttribute
(
'
jid
'
),
_converse
.
xmppstatus
.
vcard
.
get
(
'
nickname
'
)
||
_converse
.
xmppstatus
.
vcard
.
get
(
'
fullname
'
)
_converse
.
xmppstatus
.
getNickname
(
)
);
);
}
}
});
});
...
...
src/headless/converse-vcard.js
View file @
c8f0fd2a
...
@@ -16,12 +16,46 @@ const u = converse.env.utils;
...
@@ -16,12 +16,46 @@ const u = converse.env.utils;
converse
.
plugins
.
add
(
'
converse-vcard
'
,
{
converse
.
plugins
.
add
(
'
converse-vcard
'
,
{
dependencies
:
[
"
converse-roster
"
],
overrides
:
{
XMPPStatus
:
{
getNickname
()
{
const
{
_converse
}
=
this
.
__super__
;
const
nick
=
this
.
__super__
.
getNickname
.
apply
(
this
);
if
(
!
nick
&&
_converse
.
xmppstatus
.
vcard
)
{
return
_converse
.
xmppstatus
.
vcard
.
get
(
'
nickname
'
)
||
_converse
.
xmppstatus
.
vcard
.
get
(
'
fullname
'
);
}
else
{
return
nick
;
}
}
},
RosterContact
:
{
getDisplayName
()
{
if
(
!
this
.
get
(
'
nickname
'
)
&&
this
.
vcard
)
{
return
this
.
vcard
.
getDisplayName
();
}
else
{
return
this
.
__super__
.
getDisplayName
.
apply
(
this
);
}
},
getFullname
()
{
if
(
this
.
vcard
)
{
return
this
.
vcard
.
get
(
'
fullname
'
);
}
else
{
return
this
.
__super__
.
getFullname
.
apply
(
this
);
}
}
}
},
initialize
()
{
initialize
()
{
/* The initialize function gets called as soon as the plugin is
/* The initialize function gets called as soon as the plugin is
* loaded by converse.js's plugin machinery.
* loaded by converse.js's plugin machinery.
*/
*/
const
{
_converse
}
=
this
;
const
{
_converse
}
=
this
;
_converse
.
VCard
=
Backbone
.
Model
.
extend
({
_converse
.
VCard
=
Backbone
.
Model
.
extend
({
defaults
:
{
defaults
:
{
'
image
'
:
_converse
.
DEFAULT_IMAGE
,
'
image
'
:
_converse
.
DEFAULT_IMAGE
,
...
@@ -97,14 +131,6 @@ converse.plugins.add('converse-vcard', {
...
@@ -97,14 +131,6 @@ converse.plugins.add('converse-vcard', {
return
iq
;
return
iq
;
}
}
function
setVCard
(
jid
,
data
)
{
if
(
!
jid
)
{
throw
Error
(
"
No jid provided for the VCard data
"
);
}
const
vcard_el
=
Strophe
.
xmlHtmlNode
(
tpl_vcard
(
data
)).
firstElementChild
;
return
_converse
.
api
.
sendIQ
(
createStanza
(
"
set
"
,
jid
,
vcard_el
));
}
async
function
getVCard
(
_converse
,
jid
)
{
async
function
getVCard
(
_converse
,
jid
)
{
const
to
=
Strophe
.
getBareJidFromJid
(
jid
)
===
_converse
.
bare_jid
?
null
:
jid
;
const
to
=
Strophe
.
getBareJidFromJid
(
jid
)
===
_converse
.
bare_jid
?
null
:
jid
;
let
iq
;
let
iq
;
...
@@ -148,6 +174,19 @@ converse.plugins.add('converse-vcard', {
...
@@ -148,6 +174,19 @@ converse.plugins.add('converse-vcard', {
_converse
.
api
.
listen
.
on
(
'
addClientFeatures
'
,
()
=>
_converse
.
api
.
disco
.
own
.
features
.
add
(
Strophe
.
NS
.
VCARD
));
_converse
.
api
.
listen
.
on
(
'
addClientFeatures
'
,
()
=>
_converse
.
api
.
disco
.
own
.
features
.
add
(
Strophe
.
NS
.
VCARD
));
function
setVCardOnModel
(
model
)
{
// TODO: if we can make this method async and wait for the VCard to
// be updated, then we'll avoid unnecessary re-rendering of roster contacts.
const
jid
=
model
.
get
(
'
jid
'
);
model
.
vcard
=
_converse
.
vcards
.
findWhere
({
'
jid
'
:
jid
});
if
(
!
model
.
vcard
)
{
model
.
vcard
=
_converse
.
vcards
.
create
({
'
jid
'
:
jid
});
}
}
_converse
.
api
.
listen
.
on
(
'
rosterContactInitialized
'
,
contact
=>
setVCardOnModel
(
contact
));
/************************ BEGIN API ************************/
/************************ BEGIN API ************************/
Object
.
assign
(
_converse
.
api
,
{
Object
.
assign
(
_converse
.
api
,
{
/**
/**
...
@@ -177,7 +216,11 @@ converse.plugins.add('converse-vcard', {
...
@@ -177,7 +216,11 @@ converse.plugins.add('converse-vcard', {
* }).
* }).
*/
*/
set
(
jid
,
data
)
{
set
(
jid
,
data
)
{
return
setVCard
(
jid
,
data
);
if
(
!
jid
)
{
throw
Error
(
"
No jid provided for the VCard data
"
);
}
const
vcard_el
=
Strophe
.
xmlHtmlNode
(
tpl_vcard
(
data
)).
firstElementChild
;
return
_converse
.
api
.
sendIQ
(
createStanza
(
"
set
"
,
jid
,
vcard_el
));
},
},
/**
/**
...
@@ -233,12 +276,10 @@ converse.plugins.add('converse-vcard', {
...
@@ -233,12 +276,10 @@ converse.plugins.add('converse-vcard', {
* _converse.api.vcard.update(chatbox);
* _converse.api.vcard.update(chatbox);
* });
* });
*/
*/
update
(
model
,
force
)
{
async
update
(
model
,
force
)
{
return
this
.
get
(
model
,
force
)
const
vcard
=
await
this
.
get
(
model
,
force
);
.
then
(
vcard
=>
{
delete
vcard
[
'
stanza
'
]
delete
vcard
[
'
stanza
'
]
model
.
save
(
vcard
);
model
.
save
(
vcard
);
});
}
}
}
}
});
});
...
...
tests/mock.js
View file @
c8f0fd2a
...
@@ -71,7 +71,7 @@
...
@@ -71,7 +71,7 @@
// Names from http://www.fakenamegenerator.com/
// Names from http://www.fakenamegenerator.com/
mock
.
req_names
=
[
mock
.
req_names
=
[
'
Escalus,
P
rince of Verona
'
,
'
The Nurse
'
,
'
Paris
'
'
Escalus,
p
rince of Verona
'
,
'
The Nurse
'
,
'
Paris
'
];
];
mock
.
pend_names
=
[
mock
.
pend_names
=
[
'
Lord Capulet
'
,
'
Lady Capulet
'
,
'
Servant
'
'
Lord Capulet
'
,
'
Lady Capulet
'
,
'
Servant
'
...
...
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