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
f032af91
Commit
f032af91
authored
May 31, 2018
by
JC Brand
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Initial work on moving certain settings into a model
parent
b02c70b4
Changes
13
Hide whitespace changes
Inline
Side-by-side
Showing
13 changed files
with
164 additions
and
143 deletions
+164
-143
src/converse-chatboxes.js
src/converse-chatboxes.js
+2
-2
src/converse-controlbox.js
src/converse-controlbox.js
+7
-6
src/converse-core.js
src/converse-core.js
+132
-112
src/converse-dragresize.js
src/converse-dragresize.js
+1
-1
src/converse-embedded.js
src/converse-embedded.js
+1
-1
src/converse-fullscreen.js
src/converse-fullscreen.js
+1
-1
src/converse-headline.js
src/converse-headline.js
+1
-1
src/converse-message-view.js
src/converse-message-view.js
+1
-1
src/converse-minimize.js
src/converse-minimize.js
+1
-1
src/converse-muc.js
src/converse-muc.js
+8
-8
src/converse-notification.js
src/converse-notification.js
+3
-3
src/converse-rosterview.js
src/converse-rosterview.js
+1
-1
src/converse-singleton.js
src/converse-singleton.js
+5
-5
No files found.
src/converse-chatboxes.js
View file @
f032af91
...
@@ -722,7 +722,7 @@
...
@@ -722,7 +722,7 @@
_converse
.
root
.
appendChild
(
el
);
_converse
.
root
.
appendChild
(
el
);
}
}
}
}
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
],
_converse
.
view_mode
))
{
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
],
_converse
.
settings
.
get
(
'
view_mode
'
)
))
{
el
.
classList
.
add
(
'
fullscreen
'
);
el
.
classList
.
add
(
'
fullscreen
'
);
}
}
el
.
innerHTML
=
''
;
el
.
innerHTML
=
''
;
...
@@ -735,7 +735,7 @@
...
@@ -735,7 +735,7 @@
initialize
()
{
initialize
()
{
this
.
model
.
on
(
"
add
"
,
this
.
onChatBoxAdded
,
this
);
this
.
model
.
on
(
"
add
"
,
this
.
onChatBoxAdded
,
this
);
this
.
model
.
on
(
"
destroy
"
,
this
.
removeChat
,
this
);
this
.
model
.
on
(
"
destroy
"
,
this
.
removeChat
,
this
);
this
.
el
.
classList
.
add
(
`converse-
${
_converse
.
view_mode
}
`
);
this
.
el
.
classList
.
add
(
`converse-
${
_converse
.
settings
.
get
(
'
view_mode
'
)
}
`
);
this
.
render
();
this
.
render
();
},
},
...
...
src/converse-controlbox.js
View file @
f032af91
...
@@ -406,8 +406,8 @@
...
@@ -406,8 +406,8 @@
this
.
render
();
this
.
render
();
_
.
forEach
(
this
.
el
.
querySelectorAll
(
'
[data-title]
'
),
(
el
)
=>
{
_
.
forEach
(
this
.
el
.
querySelectorAll
(
'
[data-title]
'
),
(
el
)
=>
{
const
popover
=
new
bootstrap
.
Popover
(
el
,
{
const
popover
=
new
bootstrap
.
Popover
(
el
,
{
'
trigger
'
:
_converse
.
view_mode
===
'
mobile
'
&&
'
click
'
||
'
hover
'
,
'
trigger
'
:
_converse
.
settings
.
get
(
'
view_mode
'
)
===
'
mobile
'
&&
'
click
'
||
'
hover
'
,
'
dismissible
'
:
_converse
.
view_mode
===
'
mobile
'
&&
true
||
false
,
'
dismissible
'
:
_converse
.
settings
.
get
(
'
view_mode
'
)
===
'
mobile
'
&&
true
||
false
,
'
container
'
:
_converse
.
chatboxviews
.
el
'
container
'
:
_converse
.
chatboxviews
.
el
})
})
});
});
...
@@ -465,9 +465,10 @@
...
@@ -465,9 +465,10 @@
if
(
!
this
.
validate
())
{
return
;
}
if
(
!
this
.
validate
())
{
return
;
}
const
form_data
=
new
FormData
(
ev
.
target
);
const
form_data
=
new
FormData
(
ev
.
target
);
_converse
.
trusted
=
form_data
.
get
(
'
trusted
'
);
_converse
.
settings
.
save
({
_converse
.
storage
=
form_data
.
get
(
'
trusted
'
)
?
'
local
'
:
'
session
'
;
'
trusted
'
:
form_data
.
get
(
'
trusted
'
),
'
storage
'
:
form_data
.
get
(
'
trusted
'
)
?
'
local
'
:
'
session
'
});
let
jid
=
form_data
.
get
(
'
jid
'
);
let
jid
=
form_data
.
get
(
'
jid
'
);
if
(
_converse
.
locked_domain
)
{
if
(
_converse
.
locked_domain
)
{
jid
=
Strophe
.
escapeNode
(
jid
)
+
'
@
'
+
_converse
.
locked_domain
;
jid
=
Strophe
.
escapeNode
(
jid
)
+
'
@
'
+
_converse
.
locked_domain
;
...
@@ -578,7 +579,7 @@
...
@@ -578,7 +579,7 @@
});
});
_converse
.
on
(
'
clearSession
'
,
()
=>
{
_converse
.
on
(
'
clearSession
'
,
()
=>
{
if
(
_converse
.
trusted
)
{
if
(
_converse
.
settings
.
get
(
'
trusted
'
)
)
{
const
chatboxes
=
_
.
get
(
_converse
,
'
chatboxes
'
,
null
);
const
chatboxes
=
_
.
get
(
_converse
,
'
chatboxes
'
,
null
);
if
(
!
_
.
isNil
(
chatboxes
))
{
if
(
!
_
.
isNil
(
chatboxes
))
{
const
controlbox
=
chatboxes
.
get
(
'
controlbox
'
);
const
controlbox
=
chatboxes
.
get
(
'
controlbox
'
);
...
...
src/converse-core.js
View file @
f032af91
...
@@ -181,12 +181,12 @@
...
@@ -181,12 +181,12 @@
if
(
level
===
Strophe
.
LogLevel
.
ERROR
)
{
if
(
level
===
Strophe
.
LogLevel
.
ERROR
)
{
logger
.
error
(
`
${
prefix
}
ERROR:
${
message
}
`
,
style
);
logger
.
error
(
`
${
prefix
}
ERROR:
${
message
}
`
,
style
);
}
else
if
(
level
===
Strophe
.
LogLevel
.
WARN
)
{
}
else
if
(
level
===
Strophe
.
LogLevel
.
WARN
)
{
if
(
_converse
.
debug
)
{
if
(
_converse
.
settings
.
get
(
'
debug
'
)
)
{
logger
.
warn
(
`
${
prefix
}
${
moment
().
format
()}
WARNING:
${
message
}
`
,
style
);
logger
.
warn
(
`
${
prefix
}
${
moment
().
format
()}
WARNING:
${
message
}
`
,
style
);
}
}
}
else
if
(
level
===
Strophe
.
LogLevel
.
FATAL
)
{
}
else
if
(
level
===
Strophe
.
LogLevel
.
FATAL
)
{
logger
.
error
(
`
${
prefix
}
FATAL:
${
message
}
`
,
style
);
logger
.
error
(
`
${
prefix
}
FATAL:
${
message
}
`
,
style
);
}
else
if
(
_converse
.
debug
)
{
}
else
if
(
_converse
.
settings
.
get
(
'
debug
'
)
)
{
if
(
level
===
Strophe
.
LogLevel
.
DEBUG
)
{
if
(
level
===
Strophe
.
LogLevel
.
DEBUG
)
{
logger
.
debug
(
`
${
prefix
}
${
moment
().
format
()}
DEBUG:
${
message
}
`
,
style
);
logger
.
debug
(
`
${
prefix
}
${
moment
().
format
()}
DEBUG:
${
message
}
`
,
style
);
}
else
{
}
else
{
...
@@ -227,6 +227,20 @@
...
@@ -227,6 +227,20 @@
_converse
.
promises
[
promise
]
=
u
.
getResolveablePromise
();
_converse
.
promises
[
promise
]
=
u
.
getResolveablePromise
();
}
}
// Instance level constants
_converse
.
TIMEOUTS
=
{
// Set as module attr so that we can override in tests.
'
PAUSED
'
:
10000
,
'
INACTIVE
'
:
90000
};
// XEP-0085 Chat states
// http://xmpp.org/extensions/xep-0085.html
_converse
.
INACTIVE
=
'
inactive
'
;
_converse
.
ACTIVE
=
'
active
'
;
_converse
.
COMPOSING
=
'
composing
'
;
_converse
.
PAUSED
=
'
paused
'
;
_converse
.
GONE
=
'
gone
'
;
_converse
.
emit
=
function
(
name
)
{
_converse
.
emit
=
function
(
name
)
{
/* Event emitter and promise resolver */
/* Event emitter and promise resolver */
_converse
.
trigger
.
apply
(
this
,
arguments
);
_converse
.
trigger
.
apply
(
this
,
arguments
);
...
@@ -236,16 +250,77 @@
...
@@ -236,16 +250,77 @@
}
}
};
};
_converse
.
router
=
new
Backbone
.
Router
();
// Converse has two kinds of settings.
//
// Both kinds of settings can be set when calling converse.initialize.
//
// The core settings (or instance settings), which are set directly on the
// _converse object and which we don't expect to change after
// initialization.
//
// Then there are the app settings, which are stored in the AppSettings
// model. These settings are cached and may be overridden during runtime.
// We now declare the defaults for the instance settings.
_converse
.
default_settings
=
{
'
authentication
'
:
'
login
'
,
// Available values are "login", "prebind", "anonymous" and "external".
'
auto_login
'
:
false
,
// Currently only used in connection with anonymous login
'
auto_reconnect
'
:
true
,
'
blacklisted_plugins
'
:
[],
'
connection_options
'
:
{},
'
credentials_url
'
:
null
,
// URL from where login credentials can be fetched
'
expose_rid_and_sid
'
:
false
,
'
geouri_regex
'
:
/
https
:
\
/
\
/
www
.
openstreetmap
.
org
\
/
.
*
#
map
=
[
0
-
9
]
+
\
/
([
\
-
0
-
9
.]
+
)
\
/
([
\
-
0
-
9
.]
+
)
\
S
*
/g
,
'
geouri_replacement
'
:
'
https://www.openstreetmap.org/?mlat=$1&mlon=$2#map=18/$1/$2
'
,
'
jid
'
:
undefined
,
'
keepalive
'
:
true
,
'
locales_url
'
:
'
locale/{{{locale}}}/LC_MESSAGES/converse.json
'
,
'
locales
'
:
[
'
af
'
,
'
ar
'
,
'
bg
'
,
'
ca
'
,
'
de
'
,
'
es
'
,
'
eu
'
,
'
en
'
,
'
fr
'
,
'
he
'
,
'
hu
'
,
'
id
'
,
'
it
'
,
'
ja
'
,
'
nb
'
,
'
nl
'
,
'
pl
'
,
'
pt_BR
'
,
'
ru
'
,
'
tr
'
,
'
uk
'
,
'
zh_CN
'
,
'
zh_TW
'
],
'
message_carbons
'
:
true
,
'
password
'
:
undefined
,
'
prebind_url
'
:
null
,
'
rid
'
:
undefined
,
'
sid
'
:
undefined
,
'
root
'
:
window
.
document
,
'
storage
'
:
'
session
'
,
'
strict_plugin_dependencies
'
:
false
,
'
whitelisted_plugins
'
:
[]
};
_converse
.
AppSettings
=
Backbone
.
Model
.
extend
({
defaults
()
{
return
{
'
allow_non_roster_messaging
'
:
false
,
'
animate
'
:
true
,
'
auto_away
'
:
0
,
// Seconds after which user status is set to 'away'
'
auto_xa
'
:
0
,
// Seconds after which user status is set to 'xa'
'
bosh_service_url
'
:
undefined
,
'
csi_waiting_time
'
:
0
,
// Support for XEP-0352. Seconds before client is considered idle and CSI is sent out.
'
debug
'
:
false
,
'
default_state
'
:
'
online
'
,
'
nickname
'
:
undefined
,
// XXX: looks like this is not being used?
'
priority
'
:
0
,
'
trusted
'
:
true
,
'
view_mode
'
:
'
overlayed
'
,
// Choices are 'overlayed', 'fullscreen', 'mobile'
'
websocket_url
'
:
undefined
};
}
});
_converse
.
initialize
=
function
(
settings
,
callback
)
{
_converse
.
initialize
=
function
(
settings
,
callback
)
{
"
use strict
"
;
"
use strict
"
;
settings
=
!
_
.
isUndefined
(
settings
)
?
settings
:
{};
const
init_promise
=
u
.
getResolveablePromise
();
const
init_promise
=
u
.
getResolveablePromise
();
_
.
each
(
PROMISES
,
addPromise
);
_
.
each
(
PROMISES
,
addPromise
);
_converse
.
router
=
new
Backbone
.
Router
();
if
(
!
_
.
isUndefined
(
_converse
.
connection
))
{
if
(
!
_
.
isUndefined
(
_converse
.
connection
))
{
// Looks like _converse.initialized was called again without logging
// Looks like _converse.initialized was called again without logging
// out or disconnecting in the previous session.
// out or disconnecting in the previous session.
...
@@ -276,69 +351,28 @@
...
@@ -276,69 +351,28 @@
unloadevent
=
'
unload
'
;
unloadevent
=
'
unload
'
;
}
}
// Instance level constants
// Apply default settings
this
.
TIMEOUTS
=
{
// Set as module attr so that we can override in tests.
// ----------------------
'
PAUSED
'
:
10000
,
settings
=
!
_
.
isUndefined
(
settings
)
?
settings
:
{};
'
INACTIVE
'
:
90000
};
// XEP-0085 Chat states
const
instance_keys
=
_
.
keys
(
_converse
.
default_settings
);
// http://xmpp.org/extensions/xep-0085.html
const
instance_settings
=
_
.
pick
(
settings
,
instance_keys
);
this
.
INACTIVE
=
'
inactive
'
;
_
.
assignIn
(
_converse
,
instance_settings
);
this
.
ACTIVE
=
'
active
'
;
this
.
COMPOSING
=
'
composing
'
;
// TODO: need to also fetch from browserStorage here, and need to
this
.
PAUSED
=
'
paused
'
;
// figure out how to not overwrite browserStorage with settings passed
this
.
GONE
=
'
gone
'
;
// in via converse.initialize
_converse
.
settings
=
new
_converse
.
AppSettings
();
// Default configuration values
// ----------------------------
this
.
default_settings
=
{
allow_non_roster_messaging
:
false
,
animate
:
true
,
authentication
:
'
login
'
,
// Available values are "login", "prebind", "anonymous" and "external".
auto_away
:
0
,
// Seconds after which user status is set to 'away'
auto_login
:
false
,
// Currently only used in connection with anonymous login
auto_reconnect
:
true
,
auto_xa
:
0
,
// Seconds after which user status is set to 'xa'
blacklisted_plugins
:
[],
bosh_service_url
:
undefined
,
connection_options
:
{},
credentials_url
:
null
,
// URL from where login credentials can be fetched
csi_waiting_time
:
0
,
// Support for XEP-0352. Seconds before client is considered idle and CSI is sent out.
debug
:
false
,
default_state
:
'
online
'
,
expose_rid_and_sid
:
false
,
geouri_regex
:
/https:
\/\/
www.openstreetmap.org
\/
.*#map=
[
0-9
]
+
\/([\-
0-9.
]
+
)\/([\-
0-9.
]
+
)\S
*/g
,
geouri_replacement
:
'
https://www.openstreetmap.org/?mlat=$1&mlon=$2#map=18/$1/$2
'
,
jid
:
undefined
,
keepalive
:
true
,
locales_url
:
'
locale/{{{locale}}}/LC_MESSAGES/converse.json
'
,
locales
:
[
'
af
'
,
'
ar
'
,
'
bg
'
,
'
ca
'
,
'
de
'
,
'
es
'
,
'
eu
'
,
'
en
'
,
'
fr
'
,
'
he
'
,
'
hu
'
,
'
id
'
,
'
it
'
,
'
ja
'
,
'
nb
'
,
'
nl
'
,
'
pl
'
,
'
pt_BR
'
,
'
ru
'
,
'
tr
'
,
'
uk
'
,
'
zh_CN
'
,
'
zh_TW
'
],
message_carbons
:
true
,
nickname
:
undefined
,
password
:
undefined
,
prebind_url
:
null
,
priority
:
0
,
rid
:
undefined
,
root
:
window
.
document
,
sid
:
undefined
,
storage
:
'
session
'
,
strict_plugin_dependencies
:
false
,
trusted
:
true
,
view_mode
:
'
overlayed
'
,
// Choices are 'overlayed', 'fullscreen', 'mobile'
websocket_url
:
undefined
,
whitelisted_plugins
:
[]
};
_
.
assignIn
(
this
,
this
.
default_settings
);
// Allow only whitelisted configuration attributes to be overwritten
_
.
assignIn
(
this
,
_
.
pick
(
settings
,
_
.
keys
(
this
.
default_settings
)));
if
(
this
.
authentication
===
_converse
.
ANONYMOUS
)
{
const
id
=
b64_sha1
(
`converse.appsettings-
${
_converse
.
bare_jid
}
`
);
if
(
this
.
auto_login
&&
!
this
.
jid
)
{
_converse
.
xmppstatus
.
browserStorage
=
new
Backbone
.
BrowserStorage
[
_converse
.
storage
](
id
);
_converse
.
xmppstatus
.
fetch
();
const
app_settings
=
_
.
omit
(
settings
,
instance_keys
);
_converse
.
settings
.
save
(
app_settings
);
if
(
_converse
.
authentication
===
_converse
.
ANONYMOUS
)
{
if
(
_converse
.
auto_login
&&
!
_converse
.
jid
)
{
throw
new
Error
(
"
Config Error: you need to provide the server's
"
+
throw
new
Error
(
"
Config Error: you need to provide the server's
"
+
"
domain via the 'jid' option when using anonymous
"
+
"
domain via the 'jid' option when using anonymous
"
+
"
authentication with auto_login.
"
);
"
authentication with auto_login.
"
);
...
@@ -369,7 +403,6 @@
...
@@ -369,7 +403,6 @@
// Module-level functions
// Module-level functions
// ----------------------
// ----------------------
this
.
generateResource
=
()
=>
`/converse.js-
${
Math
.
floor
(
Math
.
random
()
*
139749528
).
toString
()}
`
;
this
.
generateResource
=
()
=>
`/converse.js-
${
Math
.
floor
(
Math
.
random
()
*
139749528
).
toString
()}
`
;
this
.
sendCSI
=
function
(
stat
)
{
this
.
sendCSI
=
function
(
stat
)
{
...
@@ -401,7 +434,7 @@
...
@@ -401,7 +434,7 @@
_converse
.
auto_changed_status
=
false
;
_converse
.
auto_changed_status
=
false
;
// XXX: we should really remember the original state here, and
// XXX: we should really remember the original state here, and
// then set it back to that...
// then set it back to that...
_converse
.
xmppstatus
.
set
(
'
status
'
,
_converse
.
default_state
);
_converse
.
xmppstatus
.
set
(
'
status
'
,
_converse
.
settings
.
get
(
'
default_state
'
)
);
}
}
};
};
...
@@ -416,18 +449,18 @@
...
@@ -416,18 +449,18 @@
}
}
const
stat
=
_converse
.
xmppstatus
.
get
(
'
status
'
);
const
stat
=
_converse
.
xmppstatus
.
get
(
'
status
'
);
_converse
.
idle_seconds
++
;
_converse
.
idle_seconds
++
;
if
(
_converse
.
csi_waiting_time
>
0
&&
if
(
_converse
.
settings
.
get
(
'
csi_waiting_time
'
)
>
0
&&
_converse
.
idle_seconds
>
_converse
.
csi_waiting_time
&&
_converse
.
idle_seconds
>
_converse
.
settings
.
get
(
'
csi_waiting_time
'
)
&&
!
_converse
.
inactive
)
{
!
_converse
.
inactive
)
{
_converse
.
sendCSI
(
_converse
.
INACTIVE
);
_converse
.
sendCSI
(
_converse
.
INACTIVE
);
}
}
if
(
_converse
.
auto_away
>
0
&&
if
(
_converse
.
settings
.
get
(
'
auto_away
'
)
>
0
&&
_converse
.
idle_seconds
>
_converse
.
auto_away
&&
_converse
.
idle_seconds
>
_converse
.
settings
.
get
(
'
auto_away
'
)
&&
stat
!==
'
away
'
&&
stat
!==
'
xa
'
&&
stat
!==
'
dnd
'
)
{
stat
!==
'
away
'
&&
stat
!==
'
xa
'
&&
stat
!==
'
dnd
'
)
{
_converse
.
auto_changed_status
=
true
;
_converse
.
auto_changed_status
=
true
;
_converse
.
xmppstatus
.
set
(
'
status
'
,
'
away
'
);
_converse
.
xmppstatus
.
set
(
'
status
'
,
'
away
'
);
}
else
if
(
_converse
.
auto_xa
>
0
&&
}
else
if
(
_converse
.
settings
.
get
(
'
auto_xa
'
)
>
0
&&
_converse
.
idle_seconds
>
_converse
.
auto_xa
&&
_converse
.
idle_seconds
>
_converse
.
settings
.
get
(
'
auto_xa
'
)
&&
stat
!==
'
xa
'
&&
stat
!==
'
dnd
'
)
{
stat
!==
'
xa
'
&&
stat
!==
'
dnd
'
)
{
_converse
.
auto_changed_status
=
true
;
_converse
.
auto_changed_status
=
true
;
_converse
.
xmppstatus
.
set
(
'
status
'
,
'
xa
'
);
_converse
.
xmppstatus
.
set
(
'
status
'
,
'
xa
'
);
...
@@ -438,7 +471,9 @@
...
@@ -438,7 +471,9 @@
/* Set an interval of one second and register a handler for it.
/* Set an interval of one second and register a handler for it.
* Required for the auto_away, auto_xa and csi_waiting_time features.
* Required for the auto_away, auto_xa and csi_waiting_time features.
*/
*/
if
(
_converse
.
auto_away
<
1
&&
_converse
.
auto_xa
<
1
&&
_converse
.
csi_waiting_time
<
1
)
{
if
(
_converse
.
settings
.
get
(
'
auto_away
'
)
<
1
&&
_converse
.
settings
.
get
(
'
auto_xa
'
)
<
1
&&
_converse
.
settings
.
get
(
'
csi_waiting_time
'
)
<
1
)
{
// Waiting time of less then one second means features aren't used.
// Waiting time of less then one second means features aren't used.
return
;
return
;
}
}
...
@@ -591,8 +626,8 @@
...
@@ -591,8 +626,8 @@
};
};
this
.
incrementMsgCounter
=
function
()
{
this
.
incrementMsgCounter
=
function
()
{
this
.
msg_counter
+=
1
;
_converse
.
msg_counter
+=
1
;
const
unreadMsgCount
=
this
.
msg_counter
;
const
unreadMsgCount
=
_converse
.
msg_counter
;
let
title
=
document
.
title
;
let
title
=
document
.
title
;
if
(
_
.
isNil
(
title
))
{
if
(
_
.
isNil
(
title
))
{
return
;
return
;
...
@@ -643,7 +678,7 @@
...
@@ -643,7 +678,7 @@
};
};
this
.
clearSession
=
function
()
{
this
.
clearSession
=
function
()
{
if
(
!
_converse
.
trusted
)
{
if
(
!
_converse
.
settings
.
get
(
'
trusted
'
)
)
{
window
.
localStorage
.
clear
();
window
.
localStorage
.
clear
();
window
.
sessionStorage
.
clear
();
window
.
sessionStorage
.
clear
();
}
else
if
(
!
_
.
isUndefined
(
this
.
session
)
&&
this
.
session
.
browserStorage
)
{
}
else
if
(
!
_
.
isUndefined
(
this
.
session
)
&&
this
.
session
.
browserStorage
)
{
...
@@ -798,11 +833,10 @@
...
@@ -798,11 +833,10 @@
this
.
XMPPStatus
=
Backbone
.
Model
.
extend
({
this
.
XMPPStatus
=
Backbone
.
Model
.
extend
({
defaults
()
{
defaults
()
{
return
{
return
{
"
jid
"
:
_converse
.
bare_jid
,
"
jid
"
:
_converse
.
bare_jid
,
"
status
"
:
_converse
.
default_state
,
"
status
"
:
_converse
.
settings
.
get
(
'
default_state
'
)
,
}
}
},
},
...
@@ -827,7 +861,7 @@
...
@@ -827,7 +861,7 @@
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
.
settings
.
get
(
'
default_state
'
)
);
status_message
=
_
.
isString
(
status_message
)
?
status_message
:
this
.
get
(
'
status_message
'
);
status_message
=
_
.
isString
(
status_message
)
?
status_message
:
this
.
get
(
'
status_message
'
);
// Most of these presence types are actually not explicitly sent,
// Most of these presence types are actually not explicitly sent,
// but I add all of them here for reference and future proofing.
// but I add all of them here for reference and future proofing.
...
@@ -864,11 +898,11 @@
...
@@ -864,11 +898,11 @@
Strophe
.
log
=
function
(
level
,
msg
)
{
Strophe
.
log
=
function
(
level
,
msg
)
{
_converse
.
log
(
msg
,
level
);
_converse
.
log
(
msg
,
level
);
};
};
if
(
this
.
debug
)
{
if
(
_converse
.
settings
.
get
(
'
debug
'
)
)
{
this
.
connection
.
xmlInput
=
function
(
body
)
{
_converse
.
connection
.
xmlInput
=
function
(
body
)
{
_converse
.
log
(
body
.
outerHTML
,
Strophe
.
LogLevel
.
DEBUG
,
'
color: darkgoldenrod
'
);
_converse
.
log
(
body
.
outerHTML
,
Strophe
.
LogLevel
.
DEBUG
,
'
color: darkgoldenrod
'
);
};
};
this
.
connection
.
xmlOutput
=
function
(
body
)
{
_converse
.
connection
.
xmlOutput
=
function
(
body
)
{
_converse
.
log
(
body
.
outerHTML
,
Strophe
.
LogLevel
.
DEBUG
,
'
color: darkcyan
'
);
_converse
.
log
(
body
.
outerHTML
,
Strophe
.
LogLevel
.
DEBUG
,
'
color: darkcyan
'
);
};
};
}
}
...
@@ -983,7 +1017,7 @@
...
@@ -983,7 +1017,7 @@
// or credentials fetching via HTTP
// or credentials fetching via HTTP
this
.
autoLogin
(
credentials
);
this
.
autoLogin
(
credentials
);
}
else
if
(
this
.
auto_login
)
{
}
else
if
(
this
.
auto_login
)
{
if
(
this
.
credentials_url
)
{
if
(
_converse
.
credentials_url
)
{
this
.
fetchLoginCredentials
().
then
(
this
.
fetchLoginCredentials
().
then
(
this
.
autoLogin
.
bind
(
this
),
this
.
autoLogin
.
bind
(
this
),
this
.
autoLogin
.
bind
(
this
)
this
.
autoLogin
.
bind
(
this
)
...
@@ -1010,7 +1044,8 @@
...
@@ -1010,7 +1044,8 @@
// so we set them on the converse object.
// so we set them on the converse object.
this
.
jid
=
credentials
.
jid
;
this
.
jid
=
credentials
.
jid
;
}
}
if
(
this
.
authentication
===
_converse
.
ANONYMOUS
||
this
.
authentication
===
_converse
.
EXTERNAL
)
{
if
(
_converse
.
authentication
===
_converse
.
ANONYMOUS
||
_converse
.
authentication
===
_converse
.
EXTERNAL
)
{
if
(
!
this
.
jid
)
{
if
(
!
this
.
jid
)
{
throw
new
Error
(
"
Config Error: when using anonymous login
"
+
throw
new
Error
(
"
Config Error: when using anonymous login
"
+
"
you need to provide the server's domain via the 'jid' option.
"
+
"
you need to provide the server's domain via the 'jid' option.
"
+
...
@@ -1021,7 +1056,7 @@
...
@@ -1021,7 +1056,7 @@
this
.
connection
.
reset
();
this
.
connection
.
reset
();
}
}
this
.
connection
.
connect
(
this
.
jid
.
toLowerCase
(),
null
,
this
.
onConnectStatusChanged
);
this
.
connection
.
connect
(
this
.
jid
.
toLowerCase
(),
null
,
this
.
onConnectStatusChanged
);
}
else
if
(
this
.
authentication
===
_converse
.
LOGIN
)
{
}
else
if
(
_converse
.
authentication
===
_converse
.
LOGIN
)
{
const
password
=
_
.
isNil
(
credentials
)
?
(
_converse
.
connection
.
pass
||
this
.
password
)
:
credentials
.
password
;
const
password
=
_
.
isNil
(
credentials
)
?
(
_converse
.
connection
.
pass
||
this
.
password
)
:
credentials
.
password
;
if
(
!
password
)
{
if
(
!
password
)
{
if
(
this
.
auto_login
)
{
if
(
this
.
auto_login
)
{
...
@@ -1048,10 +1083,10 @@
...
@@ -1048,10 +1083,10 @@
this
.
logIn
=
function
(
credentials
,
reconnecting
)
{
this
.
logIn
=
function
(
credentials
,
reconnecting
)
{
// We now try to resume or automatically set up a new session.
// We now try to resume or automatically set up a new session.
// Otherwise the user will be shown a login form.
// Otherwise the user will be shown a login form.
if
(
this
.
authentication
===
_converse
.
PREBIND
)
{
if
(
_converse
.
authentication
===
_converse
.
PREBIND
)
{
this
.
attemptPreboundSession
(
reconnecting
);
_converse
.
attemptPreboundSession
(
reconnecting
);
}
else
{
}
else
{
this
.
attemptNonPreboundSession
(
credentials
,
reconnecting
);
_converse
.
attemptNonPreboundSession
(
credentials
,
reconnecting
);
}
}
};
};
...
@@ -1059,14 +1094,14 @@
...
@@ -1059,14 +1094,14 @@
/* Creates a new Strophe.Connection instance if we don't already have one.
/* Creates a new Strophe.Connection instance if we don't already have one.
*/
*/
if
(
!
this
.
connection
)
{
if
(
!
this
.
connection
)
{
if
(
!
this
.
bosh_service_url
&&
!
this
.
websocket_url
)
{
if
(
!
_converse
.
settings
.
get
(
'
bosh_service_url
'
)
&&
!
_converse
.
settings
.
get
(
'
websocket_url
'
)
)
{
throw
new
Error
(
"
initConnection: you must supply a value for either the bosh_service_url or websocket_url or both.
"
);
throw
new
Error
(
"
initConnection: you must supply a value for either the bosh_service_url or websocket_url or both.
"
);
}
}
if
((
'
WebSocket
'
in
window
||
'
MozWebSocket
'
in
window
)
&&
this
.
websocket_url
)
{
if
((
'
WebSocket
'
in
window
||
'
MozWebSocket
'
in
window
)
&&
_converse
.
settings
.
get
(
'
websocket_url
'
)
)
{
this
.
connection
=
new
Strophe
.
Connection
(
this
.
websocket_url
,
this
.
connection_options
);
this
.
connection
=
new
Strophe
.
Connection
(
_converse
.
settings
.
get
(
'
websocket_url
'
)
,
this
.
connection_options
);
}
else
if
(
this
.
bosh_service_url
)
{
}
else
if
(
_converse
.
settings
.
get
(
'
bosh_service_url
'
)
)
{
this
.
connection
=
new
Strophe
.
Connection
(
this
.
connection
=
new
Strophe
.
Connection
(
this
.
bosh_service_url
,
_converse
.
settings
.
get
(
'
bosh_service_url
'
)
,
_
.
assignIn
(
this
.
connection_options
,
{
'
keepalive
'
:
this
.
keepalive
})
_
.
assignIn
(
this
.
connection_options
,
{
'
keepalive
'
:
this
.
keepalive
})
);
);
}
else
{
}
else
{
...
@@ -1106,7 +1141,7 @@
...
@@ -1106,7 +1141,7 @@
const
whitelist
=
_converse
.
core_plugins
.
concat
(
const
whitelist
=
_converse
.
core_plugins
.
concat
(
_converse
.
whitelisted_plugins
);
_converse
.
whitelisted_plugins
);
if
(
_converse
.
view_mode
===
'
embedded
'
)
{
if
(
_converse
.
settings
.
get
(
'
view_mode
'
)
===
'
embedded
'
)
{
_
.
forEach
([
// eslint-disable-line lodash/prefer-map
_
.
forEach
([
// eslint-disable-line lodash/prefer-map
"
converse-bookmarks
"
,
"
converse-bookmarks
"
,
"
converse-controlbox
"
,
"
converse-controlbox
"
,
...
@@ -1219,23 +1254,8 @@
...
@@ -1219,23 +1254,8 @@
},
},
'
settings
'
:
{
'
settings
'
:
{
'
update
'
(
settings
)
{
'
update
'
(
settings
)
{
u
.
merge
(
_converse
.
default_settings
,
settings
);
const
user_settings
=
_
.
pick
(
_converse
.
user_settings
,
_
.
keys
(
settings
));
u
.
merge
(
_converse
,
settings
);
_converse
.
settings
.
save
(
_
.
extend
(
settings
,
user_settings
));
u
.
applyUserSettings
(
_converse
,
settings
,
_converse
.
user_settings
);
},
'
get
'
(
key
)
{
if
(
_
.
includes
(
_
.
keys
(
_converse
.
default_settings
),
key
))
{
return
_converse
[
key
];
}
},
'
set
'
(
key
,
val
)
{
const
o
=
{};
if
(
_
.
isObject
(
key
))
{
_
.
assignIn
(
_converse
,
_
.
pick
(
key
,
_
.
keys
(
_converse
.
default_settings
)));
}
else
if
(
_
.
isString
(
"
string
"
))
{
o
[
key
]
=
val
;
_
.
assignIn
(
_converse
,
_
.
pick
(
o
,
_
.
keys
(
_converse
.
default_settings
)));
}
}
}
},
},
'
promises
'
:
{
'
promises
'
:
{
...
...
src/converse-dragresize.js
View file @
f032af91
...
@@ -41,7 +41,7 @@
...
@@ -41,7 +41,7 @@
dependencies
:
[
"
converse-chatview
"
,
"
converse-headline
"
,
"
converse-muc-views
"
],
dependencies
:
[
"
converse-chatview
"
,
"
converse-headline
"
,
"
converse-muc-views
"
],
enabled
(
_converse
)
{
enabled
(
_converse
)
{
return
_converse
.
view_mode
==
'
overlayed
'
;
return
_converse
.
settings
.
get
(
'
view_mode
'
)
==
'
overlayed
'
;
},
},
overrides
:
{
overrides
:
{
...
...
src/converse-embedded.js
View file @
f032af91
...
@@ -13,7 +13,7 @@
...
@@ -13,7 +13,7 @@
converse
.
plugins
.
add
(
'
converse-embedded
'
,
{
converse
.
plugins
.
add
(
'
converse-embedded
'
,
{
enabled
(
_converse
)
{
enabled
(
_converse
)
{
return
_converse
.
view_mode
===
'
embedded
'
;
return
_converse
.
settings
.
get
(
'
view_mode
'
)
===
'
embedded
'
;
},
},
initialize
()
{
initialize
()
{
...
...
src/converse-fullscreen.js
View file @
f032af91
...
@@ -21,7 +21,7 @@
...
@@ -21,7 +21,7 @@
converse
.
plugins
.
add
(
'
converse-fullscreen
'
,
{
converse
.
plugins
.
add
(
'
converse-fullscreen
'
,
{
enabled
(
_converse
)
{
enabled
(
_converse
)
{
return
_
.
includes
([
'
fullscreen
'
,
'
embedded
'
],
_converse
.
view_mode
);
return
_
.
includes
([
'
fullscreen
'
,
'
embedded
'
],
_converse
.
settings
.
get
(
'
view_mode
'
)
);
},
},
overrides
:
{
overrides
:
{
...
...
src/converse-headline.js
View file @
f032af91
...
@@ -129,7 +129,7 @@
...
@@ -129,7 +129,7 @@
/* Handler method for all incoming messages of type "headline". */
/* Handler method for all incoming messages of type "headline". */
const
from_jid
=
message
.
getAttribute
(
'
from
'
);
const
from_jid
=
message
.
getAttribute
(
'
from
'
);
if
(
utils
.
isHeadlineMessage
(
_converse
,
message
))
{
if
(
utils
.
isHeadlineMessage
(
_converse
,
message
))
{
if
(
_
.
includes
(
from_jid
,
'
@
'
)
&&
!
_converse
.
allow_non_roster_messaging
)
{
if
(
_
.
includes
(
from_jid
,
'
@
'
)
&&
!
_converse
.
settings
.
get
(
'
allow_non_roster_messaging
'
)
)
{
return
;
return
;
}
}
const
chatbox
=
_converse
.
chatboxes
.
create
({
const
chatbox
=
_converse
.
chatboxes
.
create
({
...
...
src/converse-message-view.js
View file @
f032af91
...
@@ -221,7 +221,7 @@
...
@@ -221,7 +221,7 @@
processMessageText
()
{
processMessageText
()
{
var
text
=
this
.
get
(
'
message
'
);
var
text
=
this
.
get
(
'
message
'
);
text
=
u
.
geoUriToHttp
(
text
,
_converse
.
geouri_replacement
);
text
=
u
.
geoUriToHttp
(
text
,
_converse
.
g
geouri_replacement
eouri_replacement
);
},
},
getExtraMessageClasses
()
{
getExtraMessageClasses
()
{
...
...
src/converse-minimize.js
View file @
f032af91
...
@@ -42,7 +42,7 @@
...
@@ -42,7 +42,7 @@
dependencies
:
[
"
converse-chatview
"
,
"
converse-controlbox
"
,
"
converse-muc
"
,
"
converse-muc-views
"
,
"
converse-headline
"
],
dependencies
:
[
"
converse-chatview
"
,
"
converse-controlbox
"
,
"
converse-muc
"
,
"
converse-muc-views
"
,
"
converse-headline
"
],
enabled
(
_converse
)
{
enabled
(
_converse
)
{
return
_converse
.
view_mode
==
'
overlayed
'
;
return
_converse
.
settings
.
get
(
'
view_mode
'
)
==
'
overlayed
'
;
},
},
overrides
:
{
overrides
:
{
...
...
src/converse-muc.js
View file @
f032af91
...
@@ -108,14 +108,14 @@
...
@@ -108,14 +108,14 @@
// Refer to docs/source/configuration.rst for explanations of these
// Refer to docs/source/configuration.rst for explanations of these
// configuration settings.
// configuration settings.
_converse
.
api
.
settings
.
update
({
_converse
.
api
.
settings
.
update
({
allow_muc
:
true
,
'
allow_muc
'
:
true
,
allow_muc_invitations
:
true
,
'
allow_muc_invitations
'
:
true
,
auto_join_on_invite
:
false
,
'
auto_join_on_invite
'
:
false
,
auto_join_rooms
:
[],
'
auto_join_rooms
'
:
[],
muc_domain
:
undefined
,
'
muc_domain
'
:
undefined
,
muc_history_max_stanzas
:
undefined
,
'
muc_history_max_stanzas
'
:
undefined
,
muc_instant_rooms
:
true
,
'
muc_instant_rooms
'
:
true
,
muc_nickname_from_jid
:
false
'
muc_nickname_from_jid
'
:
false
});
});
_converse
.
api
.
promises
.
add
([
'
roomsAutoJoined
'
]);
_converse
.
api
.
promises
.
add
([
'
roomsAutoJoined
'
]);
...
...
src/converse-notification.js
View file @
f032af91
...
@@ -71,7 +71,7 @@
...
@@ -71,7 +71,7 @@
};
};
_converse
.
isMessageToHiddenChat
=
function
(
message
)
{
_converse
.
isMessageToHiddenChat
=
function
(
message
)
{
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
_converse
.
view_mode
))
{
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
_converse
.
settings
.
get
(
'
view_mode
'
)
))
{
const
jid
=
Strophe
.
getBareJidFromJid
(
message
.
getAttribute
(
'
from
'
));
const
jid
=
Strophe
.
getBareJidFromJid
(
message
.
getAttribute
(
'
from
'
));
const
model
=
_converse
.
chatboxes
.
get
(
jid
);
const
model
=
_converse
.
chatboxes
.
get
(
jid
);
if
(
!
_
.
isNil
(
model
))
{
if
(
!
_
.
isNil
(
model
))
{
...
@@ -138,7 +138,7 @@
...
@@ -138,7 +138,7 @@
const
full_from_jid
=
message
.
getAttribute
(
'
from
'
),
const
full_from_jid
=
message
.
getAttribute
(
'
from
'
),
from_jid
=
Strophe
.
getBareJidFromJid
(
full_from_jid
);
from_jid
=
Strophe
.
getBareJidFromJid
(
full_from_jid
);
if
(
message
.
getAttribute
(
'
type
'
)
===
'
headline
'
)
{
if
(
message
.
getAttribute
(
'
type
'
)
===
'
headline
'
)
{
if
(
!
_
.
includes
(
from_jid
,
'
@
'
)
||
_converse
.
allow_non_roster_messaging
)
{
if
(
!
_
.
includes
(
from_jid
,
'
@
'
)
||
_converse
.
get
(
'
allow_non_roster_messaging
'
)
)
{
title
=
__
(
"
Notification from %1$s
"
,
from_jid
);
title
=
__
(
"
Notification from %1$s
"
,
from_jid
);
}
else
{
}
else
{
return
;
return
;
...
@@ -159,7 +159,7 @@
...
@@ -159,7 +159,7 @@
if
(
!
_
.
isUndefined
(
roster_item
))
{
if
(
!
_
.
isUndefined
(
roster_item
))
{
title
=
__
(
"
%1$s says
"
,
roster_item
.
getDisplayName
());
title
=
__
(
"
%1$s says
"
,
roster_item
.
getDisplayName
());
}
else
{
}
else
{
if
(
_converse
.
allow_non_roster_messaging
)
{
if
(
_converse
.
get
(
'
allow_non_roster_messaging
'
)
)
{
title
=
__
(
"
%1$s says
"
,
from_jid
);
title
=
__
(
"
%1$s says
"
,
from_jid
);
}
else
{
}
else
{
return
;
return
;
...
...
src/converse-rosterview.js
View file @
f032af91
...
@@ -821,7 +821,7 @@
...
@@ -821,7 +821,7 @@
}
}
this
.
filter_view
.
showOrHide
();
this
.
filter_view
.
showOrHide
();
return
this
;
return
this
;
},
_converse
.
animate
?
100
:
0
),
},
_converse
.
get
(
'
animate
'
)
?
100
:
0
),
filter
(
query
,
type
)
{
filter
(
query
,
type
)
{
// First we make sure the filter is restored to its
// First we make sure the filter is restored to its
...
...
src/converse-singleton.js
View file @
f032af91
...
@@ -46,7 +46,7 @@
...
@@ -46,7 +46,7 @@
ChatBoxes
:
{
ChatBoxes
:
{
chatBoxMayBeShown
(
chatbox
)
{
chatBoxMayBeShown
(
chatbox
)
{
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
this
.
__super__
.
_converse
.
view_mode
))
{
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
this
.
__super__
.
_converse
.
settings
.
get
(
'
view_mode
'
)
))
{
return
!
chatbox
.
get
(
'
hidden
'
);
return
!
chatbox
.
get
(
'
hidden
'
);
}
else
{
}
else
{
return
this
.
__super__
.
chatBoxMayBeShown
.
apply
(
this
,
arguments
);
return
this
.
__super__
.
chatBoxMayBeShown
.
apply
(
this
,
arguments
);
...
@@ -55,7 +55,7 @@
...
@@ -55,7 +55,7 @@
createChatBox
(
jid
,
attrs
)
{
createChatBox
(
jid
,
attrs
)
{
/* Make sure new chat boxes are hidden by default. */
/* Make sure new chat boxes are hidden by default. */
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
this
.
__super__
.
_converse
.
view_mode
))
{
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
this
.
__super__
.
_converse
.
settings
.
get
(
'
view_mode
'
)
))
{
attrs
=
attrs
||
{};
attrs
=
attrs
||
{};
attrs
.
hidden
=
true
;
attrs
.
hidden
=
true
;
}
}
...
@@ -65,7 +65,7 @@
...
@@ -65,7 +65,7 @@
ChatBoxView
:
{
ChatBoxView
:
{
shouldShowOnTextMessage
()
{
shouldShowOnTextMessage
()
{
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
this
.
__super__
.
_converse
.
view_mode
))
{
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
this
.
__super__
.
_converse
.
settings
.
get
(
'
view_mode
'
)
))
{
return
false
;
return
false
;
}
else
{
}
else
{
return
this
.
__super__
.
shouldShowOnTextMessage
.
apply
(
this
,
arguments
);
return
this
.
__super__
.
shouldShowOnTextMessage
.
apply
(
this
,
arguments
);
...
@@ -77,7 +77,7 @@
...
@@ -77,7 +77,7 @@
* time. So before opening a chat, we make sure all other
* time. So before opening a chat, we make sure all other
* chats are hidden.
* chats are hidden.
*/
*/
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
this
.
__super__
.
_converse
.
view_mode
))
{
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
this
.
__super__
.
_converse
.
settings
.
get
(
'
view_mode
'
)
))
{
_
.
each
(
this
.
__super__
.
_converse
.
chatboxviews
.
xget
(
this
.
model
.
get
(
'
id
'
)),
hideChat
);
_
.
each
(
this
.
__super__
.
_converse
.
chatboxviews
.
xget
(
this
.
model
.
get
(
'
id
'
)),
hideChat
);
this
.
model
.
set
(
'
hidden
'
,
false
);
this
.
model
.
set
(
'
hidden
'
,
false
);
}
}
...
@@ -87,7 +87,7 @@
...
@@ -87,7 +87,7 @@
ChatRoomView
:
{
ChatRoomView
:
{
show
(
focus
)
{
show
(
focus
)
{
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
this
.
__super__
.
_converse
.
view_mode
))
{
if
(
_
.
includes
([
'
mobile
'
,
'
fullscreen
'
,
'
embedded
'
],
this
.
__super__
.
_converse
.
settings
.
get
(
'
view_mode
'
)
))
{
_
.
each
(
this
.
__super__
.
_converse
.
chatboxviews
.
xget
(
this
.
model
.
get
(
'
id
'
)),
hideChat
);
_
.
each
(
this
.
__super__
.
_converse
.
chatboxviews
.
xget
(
this
.
model
.
get
(
'
id
'
)),
hideChat
);
this
.
model
.
set
(
'
hidden
'
,
false
);
this
.
model
.
set
(
'
hidden
'
,
false
);
}
}
...
...
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