Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
A
AloqaIM-Android
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Administrator
AloqaIM-Android
Commits
c247b15a
Commit
c247b15a
authored
Jan 10, 2018
by
Lucio Maciel
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Listen to Room and Subscription changes
parent
fc0ebff2
Changes
15
Show whitespace changes
Inline
Side-by-side
Showing
15 changed files
with
309 additions
and
46 deletions
+309
-46
.gitignore
.gitignore
+1
-0
build-sdk.sh
app/build-sdk.sh
+19
-3
build.gradle
app/build.gradle
+1
-0
common-d5d174f.jar
app/libs/common-d5d174f.jar
+0
-0
core-d5d174f.jar
app/libs/core-d5d174f.jar
+0
-0
ChatRoomsPresenter.kt
...cket/android/chatrooms/presentation/ChatRoomsPresenter.kt
+192
-13
ChatRoomsView.kt
...at/rocket/android/chatrooms/presentation/ChatRoomsView.kt
+1
-1
ChatRoomsAdapter.kt
...java/chat/rocket/android/chatrooms/ui/ChatRoomsAdapter.kt
+12
-1
ChatRoomsFragment.kt
...ava/chat/rocket/android/chatrooms/ui/ChatRoomsFragment.kt
+52
-5
MainActivity.kt
...ain/java/chat/rocket/android/chatrooms/ui/MainActivity.kt
+1
-2
SettingsRepository.kt
...a/chat/rocket/android/server/domain/SettingsRepository.kt
+20
-15
RocketChatClientFactory.kt
...android/server/infraestructure/RocketChatClientFactory.kt
+5
-0
Extensions.kt
app/src/main/java/chat/rocket/android/util/Extensions.kt
+1
-1
dependencies.gradle
dependencies.gradle
+2
-4
build.gradle
player/build.gradle
+2
-1
No files found.
.gitignore
View file @
c247b15a
...
@@ -53,6 +53,7 @@ hs_err_pid*
...
@@ -53,6 +53,7 @@ hs_err_pid*
# Built application files
# Built application files
*.apk
*.apk
*.ap_
*.ap_
app/libs
# Files for the ART/Dalvik VM
# Files for the ART/Dalvik VM
*.dex
*.dex
...
...
app/build-sdk.sh
View file @
c247b15a
...
@@ -3,6 +3,7 @@
...
@@ -3,6 +3,7 @@
CURRENT_DIR
=
`
pwd
`
CURRENT_DIR
=
`
pwd
`
# The SDK dir should be 2 directories up in the tree, so we use dirname 2 times
# The SDK dir should be 2 directories up in the tree, so we use dirname 2 times
# to get the common parent dir of the SDK and the app
# to get the common parent dir of the SDK and the app
GIT
=
`
which git
`
tmp
=
`
dirname
$CURRENT_DIR
`
tmp
=
`
dirname
$CURRENT_DIR
`
tmp
=
`
dirname
$tmp
`
tmp
=
`
dirname
$tmp
`
SDK_DIR
=
"
$tmp
/Rocket.Chat.Kotlin.SDK"
SDK_DIR
=
"
$tmp
/Rocket.Chat.Kotlin.SDK"
...
@@ -13,23 +14,28 @@ echo "SDK DIR: $SDK_DIR"
...
@@ -13,23 +14,28 @@ echo "SDK DIR: $SDK_DIR"
# check if there are changes not commited
# check if there are changes not commited
function
git_stat
{
function
git_stat
{
local
__resultvar
=
$1
local
__resultvar
=
$1
cd
$SDK_DIR
&&
git
diff
--shortstat
--exit-code
cd
$SDK_DIR
&&
$GIT
diff
--shortstat
--exit-code
eval
$__resultvar
=
"'
$?
'"
eval
$__resultvar
=
"'
$?
'"
}
}
# check for changes already on the index not commited
# check for changes already on the index not commited
function
git_stat_cached
{
function
git_stat_cached
{
local
__resultvar
=
$1
local
__resultvar
=
$1
cd
$SDK_DIR
&&
git
diff
--cached
--shortstat
--exit-code
cd
$SDK_DIR
&&
$GIT
diff
--cached
--shortstat
--exit-code
eval
$__resultvar
=
"'
$?
'"
eval
$__resultvar
=
"'
$?
'"
}
}
# get the SHA of the lastest commit
# get the SHA of the lastest commit
function
git_sha
{
function
git_sha
{
temp_sha
=
`
cd
$SDK_DIR
&&
git
rev-parse
--short
HEAD
`
temp_sha
=
`
cd
$SDK_DIR
&&
$GIT
rev-parse
--short
HEAD
`
echo
"
$temp_sha
"
echo
"
$temp_sha
"
}
}
function
git_app_branch
{
temp_branch
=
`
cd
$CURRENT_DIR
&&
$GIT
rev-parse
--abbrev-ref
HEAD
`
echo
"
$temp_branch
"
}
# check if the tree is dirty (has modifications not commited yet)
# check if the tree is dirty (has modifications not commited yet)
function
check_git_dirty
{
function
check_git_dirty
{
git_stat
stat
git_stat
stat
...
@@ -62,7 +68,17 @@ function check_last_commit {
...
@@ -62,7 +68,17 @@ function check_last_commit {
return
0
return
0
}
}
function
checkout_matching_branch
{
app_branch
=
$(
git_app_branch
)
cd
$SDK_DIR
&&
$GIT
checkout
$app_branch
1>/dev/null 2>/dev/null
}
checkout_matching_branch
SHA
=
$(
git_sha
)
SHA
=
$(
git_sha
)
if
[
"X
$SHA
"
==
"X"
]
;
then
SHA
=
"0.1-SNAPSHOT"
fi
echo
"CURRENT SHA:
$SHA
"
echo
"CURRENT SHA:
$SHA
"
# if the tree is not dirty, there is no new commit and the .jars are still there, just skip the build
# if the tree is not dirty, there is no new commit and the .jars are still there, just skip the build
...
...
app/build.gradle
View file @
c247b15a
...
@@ -54,6 +54,7 @@ dependencies {
...
@@ -54,6 +54,7 @@ dependencies {
kapt
libraries
.
daggerAndroidApt
kapt
libraries
.
daggerAndroidApt
implementation
libraries
.
moshi
implementation
libraries
.
moshi
implementation
libraries
.
kotshi
implementation
libraries
.
room
implementation
libraries
.
room
kapt
libraries
.
roomProcessor
kapt
libraries
.
roomProcessor
...
...
app/libs/common-d5d174f.jar
deleted
100644 → 0
View file @
fc0ebff2
File deleted
app/libs/core-d5d174f.jar
deleted
100644 → 0
View file @
fc0ebff2
File deleted
app/src/main/java/chat/rocket/android/chatrooms/presentation/ChatRoomsPresenter.kt
View file @
c247b15a
...
@@ -7,9 +7,13 @@ import chat.rocket.android.server.domain.SaveChatRoomsInteractor
...
@@ -7,9 +7,13 @@ import chat.rocket.android.server.domain.SaveChatRoomsInteractor
import
chat.rocket.android.server.infraestructure.RocketChatClientFactory
import
chat.rocket.android.server.infraestructure.RocketChatClientFactory
import
chat.rocket.android.util.launchUI
import
chat.rocket.android.util.launchUI
import
chat.rocket.core.RocketChatClient
import
chat.rocket.core.RocketChatClient
import
chat.rocket.core.internal.model.Subscription
import
chat.rocket.core.internal.realtime.*
import
chat.rocket.core.internal.rest.chatRooms
import
chat.rocket.core.internal.rest.chatRooms
import
chat.rocket.core.model.ChatRoom
import
chat.rocket.core.model.ChatRoom
import
kotlinx.coroutines.experimental.async
import
chat.rocket.core.model.Room
import
kotlinx.coroutines.experimental.*
import
timber.log.Timber
import
javax.inject.Inject
import
javax.inject.Inject
class
ChatRoomsPresenter
@Inject
constructor
(
private
val
view
:
ChatRoomsView
,
class
ChatRoomsPresenter
@Inject
constructor
(
private
val
view
:
ChatRoomsView
,
...
@@ -17,21 +21,36 @@ class ChatRoomsPresenter @Inject constructor(private val view: ChatRoomsView,
...
@@ -17,21 +21,36 @@ class ChatRoomsPresenter @Inject constructor(private val view: ChatRoomsView,
private
val
serverInteractor
:
GetCurrentServerInteractor
,
private
val
serverInteractor
:
GetCurrentServerInteractor
,
private
val
getChatRoomsInteractor
:
GetChatRoomsInteractor
,
private
val
getChatRoomsInteractor
:
GetChatRoomsInteractor
,
private
val
saveChatRoomsInteractor
:
SaveChatRoomsInteractor
,
private
val
saveChatRoomsInteractor
:
SaveChatRoomsInteractor
,
private
val
factory
:
RocketChatClientFactory
)
{
factory
:
RocketChatClientFactory
)
{
lateinit
var
client
:
RocketChatClient
fun
chatRooms
()
{
private
val
client
:
RocketChatClient
=
factory
.
create
(
serverInteractor
.
get
()
!!
)
// TODO - check for current server
private
val
currentServer
=
serverInteractor
.
get
()
!!
val
currentServer
=
serverInteractor
.
get
()
!!
private
var
reloadJob
:
Deferred
<
List
<
ChatRoom
>>?
=
null
client
=
factory
.
create
(
currentServer
)
fun
loadChatRooms
()
{
launchUI
(
strategy
)
{
launchUI
(
strategy
)
{
view
.
showLoading
()
view
.
showLoading
()
view
.
updateChatRooms
(
loadRooms
())
subscribeRoomUpdates
()
view
.
hideLoading
()
}
}
private
suspend
fun
loadRooms
():
List
<
ChatRoom
>
{
val
chatRooms
=
client
.
chatRooms
().
update
val
chatRooms
=
client
.
chatRooms
().
update
val
sortedRooms
=
sortRooms
(
chatRooms
)
saveChatRoomsInteractor
.
save
(
currentServer
,
sortedRooms
)
return
sortedRooms
}
private
fun
sortRooms
(
chatRooms
:
List
<
ChatRoom
>):
List
<
ChatRoom
>
{
val
openChatRooms
=
getOpenChatRooms
(
chatRooms
)
val
openChatRooms
=
getOpenChatRooms
(
chatRooms
)
val
sortedOpenChatRooms
=
sortChatRooms
(
openChatRooms
)
return
sortChatRooms
(
openChatRooms
)
saveChatRoomsInteractor
.
save
(
currentServer
,
sortedOpenChatRooms
)
}
view
.
showChatRooms
(
sortedOpenChatRooms
.
toMutableList
())
view
.
hideLoading
()
private
fun
updateRooms
()
{
launch
{
view
.
updateChatRooms
(
getChatRoomsInteractor
.
get
(
currentServer
))
}
}
}
}
...
@@ -42,7 +61,7 @@ class ChatRoomsPresenter @Inject constructor(private val view: ChatRoomsView,
...
@@ -42,7 +61,7 @@ class ChatRoomsPresenter @Inject constructor(private val view: ChatRoomsView,
val
currentServer
=
serverInteractor
.
get
()
!!
val
currentServer
=
serverInteractor
.
get
()
!!
launchUI
(
strategy
)
{
launchUI
(
strategy
)
{
val
roomList
=
getChatRoomsInteractor
.
getByName
(
currentServer
,
name
)
val
roomList
=
getChatRoomsInteractor
.
getByName
(
currentServer
,
name
)
view
.
showChatRooms
(
roomList
.
toMutableList
()
)
view
.
updateChatRooms
(
roomList
)
}
}
}
}
...
@@ -55,4 +74,164 @@ class ChatRoomsPresenter @Inject constructor(private val view: ChatRoomsView,
...
@@ -55,4 +74,164 @@ class ChatRoomsPresenter @Inject constructor(private val view: ChatRoomsView,
chatRoom
->
chatRoom
.
lastMessage
?.
timestamp
chatRoom
->
chatRoom
.
lastMessage
?.
timestamp
}
}
}
}
// TODO - Temporary stuff, remove when adding DB support
private
suspend
fun
subscribeRoomUpdates
()
{
launch
(
CommonPool
+
strategy
.
jobs
)
{
for
(
status
in
client
.
statusChannel
)
{
Timber
.
d
(
"Changing status to: $status"
)
when
(
status
)
{
State
.
Authenticating
->
Timber
.
d
(
"Authenticating"
)
State
.
Connected
->
{
Timber
.
d
(
"Connected"
)
client
.
subscribeSubscriptions
()
client
.
subscribeRooms
()
}
}
}
Timber
.
d
(
"Done on statusChannel"
)
}
when
(
client
.
state
)
{
State
.
Connected
->
{
Timber
.
d
(
"Already connected"
)
}
else
->
client
.
connect
()
}
launch
(
CommonPool
+
strategy
.
jobs
)
{
for
(
message
in
client
.
roomsChannel
)
{
Timber
.
d
(
"Got message: $message"
)
updateRoom
(
message
)
}
}
launch
(
CommonPool
+
strategy
.
jobs
)
{
for
(
message
in
client
.
subscriptionsChannel
)
{
Timber
.
d
(
"Got message: $message"
)
updateSubscription
(
message
)
}
}
}
private
fun
updateRoom
(
message
:
StreamMessage
<
Room
>)
{
launchUI
(
strategy
)
{
when
(
message
.
type
)
{
Type
.
Removed
->
{
removeRoom
(
message
.
data
.
id
)
}
Type
.
Updated
->
{
updateRoom
(
message
.
data
)
}
Type
.
Inserted
->
{
// On insertion, just get all chatrooms again, since we can't create one just
// from a Room
reloadRooms
()
}
}
updateRooms
()
}
}
private
fun
updateSubscription
(
message
:
StreamMessage
<
Subscription
>)
{
launchUI
(
strategy
)
{
when
(
message
.
type
)
{
Type
.
Removed
->
{
removeRoom
(
message
.
data
.
roomId
)
}
Type
.
Updated
->
{
updateSubscription
(
message
.
data
)
}
Type
.
Inserted
->
{
// On insertion, just get all chatrooms again, since we can't create one just
// from a Subscription
reloadRooms
()
}
}
updateRooms
()
}
}
private
suspend
fun
reloadRooms
()
{
Timber
.
d
(
"realoadRooms()"
)
reloadJob
?.
cancel
()
reloadJob
=
async
(
CommonPool
+
strategy
.
jobs
)
{
delay
(
1000
)
Timber
.
d
(
"reloading rooms after wait"
)
loadRooms
()
}
reloadJob
?.
await
()
}
// Update a ChatRoom with a Room information
private
fun
updateRoom
(
room
:
Room
)
{
val
chatRooms
=
getChatRoomsInteractor
.
get
(
currentServer
).
toMutableList
()
val
chatRoom
=
chatRooms
.
find
{
chatRoom
->
chatRoom
.
id
==
room
.
id
}
chatRoom
?.
apply
{
val
newRoom
=
ChatRoom
(
room
.
id
,
room
.
type
,
room
.
user
?:
user
,
room
.
name
?:
name
,
room
.
fullName
?:
fullName
,
room
.
readonly
,
room
.
updatedAt
?:
updatedAt
,
timestamp
,
lastModified
,
room
.
topic
,
room
.
announcement
,
default
,
open
,
alert
,
unread
,
userMenstions
,
groupMentions
,
room
.
lastMessage
,
client
)
removeRoom
(
room
.
id
,
chatRooms
)
chatRooms
.
add
(
newRoom
)
saveChatRoomsInteractor
.
save
(
currentServer
,
sortRooms
(
chatRooms
))
}
}
// Update a ChatRoom with a Subscription information
private
fun
updateSubscription
(
subscription
:
Subscription
)
{
val
chatRooms
=
getChatRoomsInteractor
.
get
(
currentServer
).
toMutableList
()
val
chatRoom
=
chatRooms
.
find
{
chatRoom
->
chatRoom
.
id
==
subscription
.
roomId
}
chatRoom
?.
apply
{
val
newRoom
=
ChatRoom
(
subscription
.
roomId
,
subscription
.
type
,
subscription
.
user
?:
user
,
subscription
.
name
,
subscription
.
fullName
?:
fullName
,
subscription
.
readonly
?:
readonly
,
subscription
.
updatedAt
?:
updatedAt
,
subscription
.
timestamp
?:
timestamp
,
subscription
.
lastModified
?:
lastModified
,
topic
,
announcement
,
subscription
.
isDefault
,
subscription
.
open
,
subscription
.
alert
,
subscription
.
unread
,
subscription
.
userMentions
,
subscription
.
groupMentions
,
lastMessage
,
client
)
removeRoom
(
subscription
.
roomId
,
chatRooms
)
chatRooms
.
add
(
newRoom
)
saveChatRoomsInteractor
.
save
(
currentServer
,
sortRooms
(
chatRooms
))
}
}
private
fun
removeRoom
(
id
:
String
,
chatRooms
:
MutableList
<
ChatRoom
>
=
getChatRoomsInteractor
.
get
(
currentServer
).
toMutableList
())
{
synchronized
(
this
)
{
chatRooms
.
removeAll
{
chatRoom
->
chatRoom
.
id
==
id
}
}
saveChatRoomsInteractor
.
save
(
currentServer
,
sortRooms
(
chatRooms
))
}
}
}
\ No newline at end of file
app/src/main/java/chat/rocket/android/chatrooms/presentation/ChatRoomsView.kt
View file @
c247b15a
...
@@ -11,5 +11,5 @@ interface ChatRoomsView : LoadingView, MessageView {
...
@@ -11,5 +11,5 @@ interface ChatRoomsView : LoadingView, MessageView {
*
*
* @param dataSet The data set to show.
* @param dataSet The data set to show.
*/
*/
fun
showChatRooms
(
dataSet
:
Mutable
List
<
ChatRoom
>)
suspend
fun
updateChatRooms
(
newDataSet
:
List
<
ChatRoom
>)
}
}
\ No newline at end of file
app/src/main/java/chat/rocket/android/chatrooms/ui/ChatRoomsAdapter.kt
View file @
c247b15a
...
@@ -18,7 +18,14 @@ import chat.rocket.core.model.ChatRoom
...
@@ -18,7 +18,14 @@ import chat.rocket.core.model.ChatRoom
import
com.facebook.drawee.view.SimpleDraweeView
import
com.facebook.drawee.view.SimpleDraweeView
import
kotlinx.android.synthetic.main.item_chat.view.*
import
kotlinx.android.synthetic.main.item_chat.view.*
class
ChatRoomsAdapter
(
private
var
dataSet
:
MutableList
<
ChatRoom
>,
private
val
context
:
Context
)
:
RecyclerView
.
Adapter
<
ChatRoomsAdapter
.
ViewHolder
>()
{
class
ChatRoomsAdapter
(
private
val
context
:
Context
)
:
RecyclerView
.
Adapter
<
ChatRoomsAdapter
.
ViewHolder
>()
{
var
dataSet
:
MutableList
<
ChatRoom
>
=
ArrayList
()
fun
updateRooms
(
newRooms
:
List
<
ChatRoom
>)
{
dataSet
.
clear
()
dataSet
.
addAll
(
newRooms
)
}
override
fun
onCreateViewHolder
(
parent
:
ViewGroup
,
viewType
:
Int
):
ViewHolder
=
ViewHolder
(
parent
.
inflate
(
R
.
layout
.
item_chat
))
override
fun
onCreateViewHolder
(
parent
:
ViewGroup
,
viewType
:
Int
):
ViewHolder
=
ViewHolder
(
parent
.
inflate
(
R
.
layout
.
item_chat
))
...
@@ -72,6 +79,10 @@ class ChatRoomsAdapter(private var dataSet: MutableList<ChatRoom>, private val c
...
@@ -72,6 +79,10 @@ class ChatRoomsAdapter(private var dataSet: MutableList<ChatRoom>, private val c
}
}
}
}
override
fun
onBindViewHolder
(
holder
:
ViewHolder
,
position
:
Int
,
payloads
:
MutableList
<
Any
>?)
{
onBindViewHolder
(
holder
,
position
)
}
override
fun
getItemCount
():
Int
=
dataSet
.
size
override
fun
getItemCount
():
Int
=
dataSet
.
size
override
fun
getItemViewType
(
position
:
Int
):
Int
=
position
override
fun
getItemViewType
(
position
:
Int
):
Int
=
position
...
...
app/src/main/java/chat/rocket/android/chatrooms/ui/ChatRoomsFragment.kt
View file @
c247b15a
...
@@ -2,6 +2,8 @@ package chat.rocket.android.chatrooms.ui
...
@@ -2,6 +2,8 @@ package chat.rocket.android.chatrooms.ui
import
android.os.Bundle
import
android.os.Bundle
import
android.support.v4.app.Fragment
import
android.support.v4.app.Fragment
import
android.support.v7.util.DiffUtil
import
android.support.v7.widget.DefaultItemAnimator
import
android.support.v7.widget.LinearLayoutManager
import
android.support.v7.widget.LinearLayoutManager
import
android.view.LayoutInflater
import
android.view.LayoutInflater
import
android.view.View
import
android.view.View
...
@@ -14,6 +16,10 @@ import chat.rocket.android.widget.DividerItemDecoration
...
@@ -14,6 +16,10 @@ import chat.rocket.android.widget.DividerItemDecoration
import
chat.rocket.core.model.ChatRoom
import
chat.rocket.core.model.ChatRoom
import
dagger.android.support.AndroidSupportInjection
import
dagger.android.support.AndroidSupportInjection
import
kotlinx.android.synthetic.main.fragment_chat_rooms.*
import
kotlinx.android.synthetic.main.fragment_chat_rooms.*
import
kotlinx.coroutines.experimental.CommonPool
import
kotlinx.coroutines.experimental.android.UI
import
kotlinx.coroutines.experimental.async
import
kotlinx.coroutines.experimental.launch
import
javax.inject.Inject
import
javax.inject.Inject
class
ChatRoomsFragment
:
Fragment
(),
ChatRoomsView
{
class
ChatRoomsFragment
:
Fragment
(),
ChatRoomsView
{
...
@@ -32,7 +38,7 @@ class ChatRoomsFragment : Fragment(), ChatRoomsView {
...
@@ -32,7 +38,7 @@ class ChatRoomsFragment : Fragment(), ChatRoomsView {
override
fun
onViewCreated
(
view
:
View
,
savedInstanceState
:
Bundle
?)
{
override
fun
onViewCreated
(
view
:
View
,
savedInstanceState
:
Bundle
?)
{
super
.
onViewCreated
(
view
,
savedInstanceState
)
super
.
onViewCreated
(
view
,
savedInstanceState
)
presenter
.
chatRooms
()
floating_search_view
.
setOnQueryChangeListener
{
oldQuery
,
newQuery
->
floating_search_view
.
setOnQueryChangeListener
{
oldQuery
,
newQuery
->
floating_search_view
.
showProgress
()
floating_search_view
.
showProgress
()
presenter
.
chatRoomsByName
(
newQuery
)
presenter
.
chatRoomsByName
(
newQuery
)
...
@@ -41,14 +47,32 @@ class ChatRoomsFragment : Fragment(), ChatRoomsView {
...
@@ -41,14 +47,32 @@ class ChatRoomsFragment : Fragment(), ChatRoomsView {
floating_search_view
.
hideProgress
()
floating_search_view
.
hideProgress
()
}
}
}
}
}
override
fun
showChatRooms
(
dataSet
:
MutableList
<
ChatRoom
>)
{
floating_search_view
.
hideProgress
()
activity
?.
apply
{
activity
?.
apply
{
recycler_view
.
layoutManager
=
LinearLayoutManager
(
this
,
LinearLayoutManager
.
VERTICAL
,
false
)
recycler_view
.
layoutManager
=
LinearLayoutManager
(
this
,
LinearLayoutManager
.
VERTICAL
,
false
)
recycler_view
.
addItemDecoration
(
DividerItemDecoration
(
this
,
144
,
32
))
recycler_view
.
addItemDecoration
(
DividerItemDecoration
(
this
,
144
,
32
))
recycler_view
.
adapter
=
ChatRoomsAdapter
(
dataSet
,
this
)
recycler_view
.
adapter
=
ChatRoomsAdapter
(
this
)
recycler_view
.
itemAnimator
=
DefaultItemAnimator
()
}
presenter
.
loadChatRooms
()
}
/*override fun showChatRooms(dataSet: MutableList<ChatRoom>) {
floating_search_view.hideProgress()
}*/
override
suspend
fun
updateChatRooms
(
newDataSet
:
List
<
ChatRoom
>)
{
activity
.
apply
{
launch
(
UI
)
{
val
adapter
=
recycler_view
.
adapter
as
ChatRoomsAdapter
val
diff
=
async
(
CommonPool
)
{
DiffUtil
.
calculateDiff
(
RoomsDiffCallback
(
adapter
.
dataSet
,
newDataSet
))
}.
await
()
floating_search_view
.
hideProgress
()
adapter
.
updateRooms
(
newDataSet
)
diff
.
dispatchUpdatesTo
(
adapter
)
}
}
}
}
}
...
@@ -59,4 +83,27 @@ class ChatRoomsFragment : Fragment(), ChatRoomsView {
...
@@ -59,4 +83,27 @@ class ChatRoomsFragment : Fragment(), ChatRoomsView {
override
fun
showMessage
(
message
:
String
)
=
Toast
.
makeText
(
activity
,
message
,
Toast
.
LENGTH_SHORT
).
show
()
override
fun
showMessage
(
message
:
String
)
=
Toast
.
makeText
(
activity
,
message
,
Toast
.
LENGTH_SHORT
).
show
()
override
fun
showGenericErrorMessage
()
=
showMessage
(
getString
(
R
.
string
.
msg_generic_error
))
override
fun
showGenericErrorMessage
()
=
showMessage
(
getString
(
R
.
string
.
msg_generic_error
))
class
RoomsDiffCallback
(
private
val
oldRooms
:
List
<
ChatRoom
>,
private
val
newRooms
:
List
<
ChatRoom
>)
:
DiffUtil
.
Callback
()
{
override
fun
areItemsTheSame
(
oldItemPosition
:
Int
,
newItemPosition
:
Int
):
Boolean
{
return
oldRooms
[
oldItemPosition
].
id
==
newRooms
[
newItemPosition
].
id
}
override
fun
getOldListSize
():
Int
{
return
oldRooms
.
size
}
override
fun
getNewListSize
():
Int
{
return
newRooms
.
size
}
override
fun
areContentsTheSame
(
oldItemPosition
:
Int
,
newItemPosition
:
Int
):
Boolean
{
return
oldRooms
[
oldItemPosition
].
updatedAt
==
newRooms
[
newItemPosition
].
updatedAt
}
override
fun
getChangePayload
(
oldItemPosition
:
Int
,
newItemPosition
:
Int
):
Any
?
{
return
newRooms
[
newItemPosition
]
}
}
}
}
\ No newline at end of file
app/src/main/java/chat/rocket/android/chatrooms/ui/MainActivity.kt
View file @
c247b15a
...
@@ -15,11 +15,10 @@ class MainActivity : AppCompatActivity(), HasSupportFragmentInjector {
...
@@ -15,11 +15,10 @@ class MainActivity : AppCompatActivity(), HasSupportFragmentInjector {
@Inject
lateinit
var
fragmentDispatchingAndroidInjector
:
DispatchingAndroidInjector
<
Fragment
>
@Inject
lateinit
var
fragmentDispatchingAndroidInjector
:
DispatchingAndroidInjector
<
Fragment
>
override
fun
onCreate
(
savedInstanceState
:
Bundle
?)
{
override
fun
onCreate
(
savedInstanceState
:
Bundle
?)
{
AndroidInjection
.
inject
(
this
)
super
.
onCreate
(
savedInstanceState
)
super
.
onCreate
(
savedInstanceState
)
setContentView
(
R
.
layout
.
activity_main
)
setContentView
(
R
.
layout
.
activity_main
)
AndroidInjection
.
inject
(
this
)
addFragment
(
"ChatRoomsFragment"
,
R
.
id
.
fragment_container
)
{
addFragment
(
"ChatRoomsFragment"
,
R
.
id
.
fragment_container
)
{
ChatRoomsFragment
.
newInstance
()
ChatRoomsFragment
.
newInstance
()
}
}
...
...
app/src/main/java/chat/rocket/android/server/domain/SettingsRepository.kt
View file @
c247b15a
...
@@ -7,20 +7,6 @@ interface SettingsRepository {
...
@@ -7,20 +7,6 @@ interface SettingsRepository {
fun
get
(
url
:
String
):
Map
<
String
,
Value
<
Any
>>?
fun
get
(
url
:
String
):
Map
<
String
,
Value
<
Any
>>?
}
}
fun
Map
<
String
,
Value
<
Any
>>.
googleEnabled
():
Boolean
=
(
this
[
ACCOUNT_GOOGLE
]
as
Value
<
Boolean
>?)
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
facebookEnabled
():
Boolean
=
(
this
[
ACCOUNT_FACEBOOK
]
as
Value
<
Boolean
>?)
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
githubEnabled
():
Boolean
=
(
this
[
ACCOUNT_GITHUB
]
as
Value
<
Boolean
>?)
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
linkedinEnabled
():
Boolean
=
(
this
[
ACCOUNT_LINKEDIN
]
as
Value
<
Boolean
>?)
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
meteorEnabled
():
Boolean
=
(
this
[
ACCOUNT_METEOR
]
as
Value
<
Boolean
>?)
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
twitterEnabled
():
Boolean
=
(
this
[
ACCOUNT_TWITTER
]
as
Value
<
Boolean
>?)
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
gitlabEnabled
():
Boolean
=
(
this
[
ACCOUNT_GITLAB
]
as
Value
<
Boolean
>?)
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
wordpressEnabled
():
Boolean
=
(
this
[
ACCOUNT_WORDPRESS
]
as
Value
<
Boolean
>?)
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
registrationEnabled
():
Boolean
{
val
value
=
this
[
ACCOUNT_REGISTRATION
]
as
Value
<
String
>?
return
value
?.
value
==
"Public"
}
const
val
ACCOUNT_FACEBOOK
=
"Accounts_OAuth_Facebook"
const
val
ACCOUNT_FACEBOOK
=
"Accounts_OAuth_Facebook"
const
val
ACCOUNT_GITHUB
=
"Accounts_OAuth_Github"
const
val
ACCOUNT_GITHUB
=
"Accounts_OAuth_Github"
const
val
ACCOUNT_GITLAB
=
"Accounts_OAuth_Gitlab"
const
val
ACCOUNT_GITLAB
=
"Accounts_OAuth_Gitlab"
...
@@ -46,3 +32,22 @@ const val HIDE_USER_LEAVE = "Message_HideType_ul"
...
@@ -46,3 +32,22 @@ const val HIDE_USER_LEAVE = "Message_HideType_ul"
const
val
HIDE_TYPE_AU
=
"Message_HideType_au"
const
val
HIDE_TYPE_AU
=
"Message_HideType_au"
const
val
HIDE_TYPE_RU
=
"Message_HideType_ru"
const
val
HIDE_TYPE_RU
=
"Message_HideType_ru"
const
val
HIDE_MUTE_UNMUTE
=
"Message_HideType_mute_unmute"
const
val
HIDE_MUTE_UNMUTE
=
"Message_HideType_mute_unmute"
/*
* Extension functions for Public Settings.
*
* If you need to access a Setting, add a const val key above, add it to the filter on
* ServerPresenter.kt and a extension function to access it
*/
fun
Map
<
String
,
Value
<
Any
>>.
googleEnabled
():
Boolean
=
this
[
ACCOUNT_GOOGLE
]
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
facebookEnabled
():
Boolean
=
this
[
ACCOUNT_FACEBOOK
]
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
githubEnabled
():
Boolean
=
this
[
ACCOUNT_GITHUB
]
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
linkedinEnabled
():
Boolean
=
this
[
ACCOUNT_LINKEDIN
]
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
meteorEnabled
():
Boolean
=
this
[
ACCOUNT_METEOR
]
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
twitterEnabled
():
Boolean
=
this
[
ACCOUNT_TWITTER
]
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
gitlabEnabled
():
Boolean
=
this
[
ACCOUNT_GITLAB
]
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
wordpressEnabled
():
Boolean
=
this
[
ACCOUNT_WORDPRESS
]
?.
value
==
true
fun
Map
<
String
,
Value
<
Any
>>.
registrationEnabled
():
Boolean
{
val
value
=
this
[
ACCOUNT_REGISTRATION
]
return
value
?.
value
==
"Public"
}
\ No newline at end of file
app/src/main/java/chat/rocket/android/server/infraestructure/RocketChatClientFactory.kt
View file @
c247b15a
...
@@ -4,8 +4,11 @@ import chat.rocket.android.authentication.infraestructure.AuthTokenRepository
...
@@ -4,8 +4,11 @@ import chat.rocket.android.authentication.infraestructure.AuthTokenRepository
import
chat.rocket.common.util.PlatformLogger
import
chat.rocket.common.util.PlatformLogger
import
chat.rocket.core.RocketChatClient
import
chat.rocket.core.RocketChatClient
import
okhttp3.OkHttpClient
import
okhttp3.OkHttpClient
import
timber.log.Timber
import
javax.inject.Inject
import
javax.inject.Inject
import
javax.inject.Singleton
@Singleton
class
RocketChatClientFactory
@Inject
constructor
(
val
okHttpClient
:
OkHttpClient
,
class
RocketChatClientFactory
@Inject
constructor
(
val
okHttpClient
:
OkHttpClient
,
val
repository
:
AuthTokenRepository
,
val
repository
:
AuthTokenRepository
,
val
logger
:
PlatformLogger
)
{
val
logger
:
PlatformLogger
)
{
...
@@ -13,6 +16,7 @@ class RocketChatClientFactory @Inject constructor(val okHttpClient: OkHttpClient
...
@@ -13,6 +16,7 @@ class RocketChatClientFactory @Inject constructor(val okHttpClient: OkHttpClient
fun
create
(
url
:
String
):
RocketChatClient
{
fun
create
(
url
:
String
):
RocketChatClient
{
cache
[
url
]
?.
let
{
cache
[
url
]
?.
let
{
Timber
.
d
(
"Returning CACHED client for: $url"
)
return
it
return
it
}
}
...
@@ -23,6 +27,7 @@ class RocketChatClientFactory @Inject constructor(val okHttpClient: OkHttpClient
...
@@ -23,6 +27,7 @@ class RocketChatClientFactory @Inject constructor(val okHttpClient: OkHttpClient
platformLogger
=
logger
platformLogger
=
logger
}
}
Timber
.
d
(
"Returning NEW client for: $url"
)
cache
.
put
(
url
,
client
)
cache
.
put
(
url
,
client
)
return
client
return
client
}
}
...
...
app/src/main/java/chat/rocket/android/util/Extensions.kt
View file @
c247b15a
dependencies.gradle
View file @
c247b15a
import
org.gradle.internal.jvm.Jvm
ext
{
ext
{
versions
=
[
versions
=
[
java
:
JavaVersion
.
VERSION_1_8
,
java
:
JavaVersion
.
VERSION_1_8
,
compileSdk
:
27
,
compileSdk
:
27
,
targetSdk
:
27
,
targetSdk
:
27
,
buildTools
:
'27.0.
0
'
,
buildTools
:
'27.0.
3
'
,
kotlin
:
'1.2.10'
,
kotlin
:
'1.2.10'
,
coroutine
:
'0.21'
,
coroutine
:
'0.21'
,
dokka
:
'0.9.15'
,
dokka
:
'0.9.15'
,
...
@@ -65,6 +63,7 @@ ext {
...
@@ -65,6 +63,7 @@ ext {
moshi
:
"com.squareup.moshi:moshi:${versions.moshi}"
,
moshi
:
"com.squareup.moshi:moshi:${versions.moshi}"
,
moshiKotlin
:
"com.squareup.moshi:moshi-kotlin:${versions.moshi}"
,
moshiKotlin
:
"com.squareup.moshi:moshi-kotlin:${versions.moshi}"
,
kotshi
:
"se.ansman.kotshi:api:${versions.kotshi}"
,
okhttp
:
"com.squareup.okhttp3:okhttp:${versions.okhttp}"
,
okhttp
:
"com.squareup.okhttp3:okhttp:${versions.okhttp}"
,
okhttpLogger
:
"com.squareup.okhttp3:logging-interceptor:${versions.okhttp}"
,
okhttpLogger
:
"com.squareup.okhttp3:logging-interceptor:${versions.okhttp}"
,
...
@@ -89,7 +88,6 @@ ext {
...
@@ -89,7 +88,6 @@ ext {
playServicesGcm
:
"com.google.android.gms:play-services-gcm:${versions.playServices}"
,
playServicesGcm
:
"com.google.android.gms:play-services-gcm:${versions.playServices}"
,
// For testing
// For testing
toolsJar
:
files
(
Jvm
.
current
().
getToolsJar
()),
junit
:
"junit:junit:$versions.junit"
,
junit
:
"junit:junit:$versions.junit"
,
expressoCore
:
"com.android.support.test.espresso:espresso-core:${versions.expresso}"
,
expressoCore
:
"com.android.support.test.espresso:espresso-core:${versions.expresso}"
,
roomTest
:
"android.arch.persistence.room:testing:${versions.room}"
,
roomTest
:
"android.arch.persistence.room:testing:${versions.room}"
,
...
...
player/build.gradle
View file @
c247b15a
...
@@ -4,6 +4,7 @@ apply plugin: 'kotlin-android-extensions'
...
@@ -4,6 +4,7 @@ apply plugin: 'kotlin-android-extensions'
android
{
android
{
compileSdkVersion
versions
.
compileSdk
compileSdkVersion
versions
.
compileSdk
buildToolsVersion
versions
.
buildTools
defaultConfig
{
defaultConfig
{
minSdkVersion
21
minSdkVersion
21
...
...
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