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
36f40fd8
Unverified
Commit
36f40fd8
authored
Apr 25, 2019
by
Filipe de Lima Brito
Committed by
GitHub
Apr 25, 2019
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch 'develop' into issue-profile
parents
e3107279
cc3624f4
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
73 additions
and
7 deletions
+73
-7
LoginOptionsFragment.kt
...id/authentication/loginoptions/ui/LoginOptionsFragment.kt
+71
-7
ChatRoomFragment.kt
.../java/chat/rocket/android/chatroom/ui/ChatRoomFragment.kt
+2
-0
No files found.
app/src/main/java/chat/rocket/android/authentication/loginoptions/ui/LoginOptionsFragment.kt
View file @
36f40fd8
package
chat.rocket.android.authentication.loginoptions.ui
package
chat.rocket.android.authentication.loginoptions.ui
import
android.animation.Animator
import
android.animation.AnimatorListenerAdapter
import
android.animation.ValueAnimator
import
android.app.Activity
import
android.app.Activity
import
android.content.Intent
import
android.content.Intent
import
android.graphics.PorterDuff
import
android.graphics.PorterDuff
...
@@ -7,10 +10,13 @@ import android.os.Bundle
...
@@ -7,10 +10,13 @@ import android.os.Bundle
import
android.view.LayoutInflater
import
android.view.LayoutInflater
import
android.view.View
import
android.view.View
import
android.view.ViewGroup
import
android.view.ViewGroup
import
android.view.animation.AlphaAnimation
import
android.view.animation.Animation
import
android.widget.Button
import
android.widget.Button
import
android.widget.LinearLayout
import
android.widget.LinearLayout
import
androidx.appcompat.view.ContextThemeWrapper
import
androidx.appcompat.view.ContextThemeWrapper
import
androidx.core.view.isVisible
import
androidx.core.view.isVisible
import
androidx.core.view.marginTop
import
androidx.fragment.app.Fragment
import
androidx.fragment.app.Fragment
import
chat.rocket.android.R
import
chat.rocket.android.R
import
chat.rocket.android.analytics.AnalyticsManager
import
chat.rocket.android.analytics.AnalyticsManager
...
@@ -28,6 +34,7 @@ import chat.rocket.android.webview.sso.ui.ssoWebViewIntent
...
@@ -28,6 +34,7 @@ import chat.rocket.android.webview.sso.ui.ssoWebViewIntent
import
dagger.android.support.AndroidSupportInjection
import
dagger.android.support.AndroidSupportInjection
import
kotlinx.android.synthetic.main.app_bar.*
import
kotlinx.android.synthetic.main.app_bar.*
import
kotlinx.android.synthetic.main.fragment_authentication_login_options.*
import
kotlinx.android.synthetic.main.fragment_authentication_login_options.*
import
timber.log.Timber
import
javax.inject.Inject
import
javax.inject.Inject
private
const
val
SERVER_NAME
=
"server_name"
private
const
val
SERVER_NAME
=
"server_name"
...
@@ -61,6 +68,8 @@ internal const val REQUEST_CODE_FOR_OAUTH = 1
...
@@ -61,6 +68,8 @@ internal const val REQUEST_CODE_FOR_OAUTH = 1
internal
const
val
REQUEST_CODE_FOR_CAS
=
2
internal
const
val
REQUEST_CODE_FOR_CAS
=
2
internal
const
val
REQUEST_CODE_FOR_SAML
=
3
internal
const
val
REQUEST_CODE_FOR_SAML
=
3
private
const
val
DEFAULT_ANIMATION_DURATION
=
400L
fun
newInstance
(
fun
newInstance
(
serverName
:
String
,
serverName
:
String
,
state
:
String
?
=
null
,
state
:
String
?
=
null
,
...
@@ -238,7 +247,6 @@ class LoginOptionsFragment : Fragment(), LoginOptionsView {
...
@@ -238,7 +247,6 @@ class LoginOptionsFragment : Fragment(), LoginOptionsView {
enableLoginByLinkedin
()
enableLoginByLinkedin
()
}
}
if
(
gitlabOauthUrl
!=
null
&&
state
!=
null
)
{
if
(
gitlabOauthUrl
!=
null
&&
state
!=
null
)
{
setupGitlabButtonListener
(
gitlabOauthUrl
.
toString
(),
state
.
toString
())
setupGitlabButtonListener
(
gitlabOauthUrl
.
toString
(),
state
.
toString
())
enableLoginByGitlab
()
enableLoginByGitlab
()
...
@@ -390,11 +398,11 @@ class LoginOptionsFragment : Fragment(), LoginOptionsView {
...
@@ -390,11 +398,11 @@ class LoginOptionsFragment : Fragment(), LoginOptionsView {
var
isAccountsCollapsed
=
true
var
isAccountsCollapsed
=
true
button_expand_collapse_accounts
.
setOnClickListener
{
button_expand_collapse_accounts
.
setOnClickListener
{
isAccountsCollapsed
=
if
(
isAccountsCollapsed
)
{
isAccountsCollapsed
=
if
(
isAccountsCollapsed
)
{
button_expand_collapse_accounts
.
rotateBy
(
180F
,
400
)
button_expand_collapse_accounts
.
rotateBy
(
180F
,
DEFAULT_ANIMATION_DURATION
)
expandAccountsView
()
expandAccountsView
()
false
false
}
else
{
}
else
{
button_expand_collapse_accounts
.
rotateBy
(
180F
,
400
)
button_expand_collapse_accounts
.
rotateBy
(
180F
,
DEFAULT_ANIMATION_DURATION
)
collapseAccountsView
()
collapseAccountsView
()
true
true
}
}
...
@@ -532,17 +540,73 @@ class LoginOptionsFragment : Fragment(), LoginOptionsView {
...
@@ -532,17 +540,73 @@ class LoginOptionsFragment : Fragment(), LoginOptionsView {
}
}
private
fun
expandAccountsView
()
{
private
fun
expandAccountsView
()
{
(
0
..
accounts_container
.
childCount
)
val
buttons
=
(
0
..
accounts_container
.
childCount
)
.
mapNotNull
{
accounts_container
.
getChildAt
(
it
)
as
?
Button
}
.
mapNotNull
{
accounts_container
.
getChildAt
(
it
)
as
?
Button
}
.
filter
{
it
.
isClickable
&&
!
it
.
isVisible
}
.
filter
{
it
.
isClickable
&&
!
it
.
isVisible
}
.
forEach
{
it
.
isVisible
=
true
}
val
optionHeight
=
accounts_container
.
getChildAt
(
1
).
height
+
accounts_container
.
getChildAt
(
1
).
marginTop
val
collapsedHeight
=
accounts_container
.
height
val
expandedHeight
=
collapsedHeight
+
optionHeight
*
buttons
.
size
with
(
ValueAnimator
.
ofInt
(
collapsedHeight
,
expandedHeight
))
{
addUpdateListener
{
val
params
=
accounts_container
.
layoutParams
params
.
height
=
animatedValue
as
Int
accounts_container
.
layoutParams
=
params
}
addListener
(
object
:
AnimatorListenerAdapter
()
{
override
fun
onAnimationStart
(
animator
:
Animator
)
{
buttons
.
forEach
{
it
.
isVisible
=
true
val
anim
=
AlphaAnimation
(
0.0f
,
1.0f
)
anim
.
duration
=
DEFAULT_ANIMATION_DURATION
it
.
startAnimation
(
anim
)
}
}
})
setDuration
(
DEFAULT_ANIMATION_DURATION
).
start
()
}
}
}
private
fun
collapseAccountsView
()
{
private
fun
collapseAccountsView
()
{
(
0
..
accounts_container
.
childCount
)
val
buttons
=
(
0
..
accounts_container
.
childCount
)
.
mapNotNull
{
accounts_container
.
getChildAt
(
it
)
as
?
Button
}
.
mapNotNull
{
accounts_container
.
getChildAt
(
it
)
as
?
Button
}
.
filter
{
it
.
isClickable
&&
it
.
isVisible
}
.
filter
{
it
.
isClickable
&&
it
.
isVisible
}
.
drop
(
3
)
.
drop
(
3
)
.
forEach
{
it
.
isVisible
=
false
}
val
optionHeight
=
accounts_container
.
getChildAt
(
1
).
height
+
accounts_container
.
getChildAt
(
1
).
marginTop
val
expandedHeight
=
accounts_container
.
height
val
collapsedHeight
=
expandedHeight
-
optionHeight
*
buttons
.
size
with
(
ValueAnimator
.
ofInt
(
expandedHeight
,
collapsedHeight
))
{
addUpdateListener
{
val
params
=
accounts_container
.
layoutParams
params
.
height
=
animatedValue
as
Int
accounts_container
.
layoutParams
=
params
}
addListener
(
object
:
AnimatorListenerAdapter
()
{
override
fun
onAnimationStart
(
animator
:
Animator
)
{
buttons
.
forEach
{
val
anim
=
AlphaAnimation
(
1.0f
,
0.0f
)
anim
.
duration
=
DEFAULT_ANIMATION_DURATION
anim
.
setAnimationListener
(
object
:
Animation
.
AnimationListener
{
override
fun
onAnimationStart
(
animation
:
Animation
)
{
Timber
.
d
(
"Animation starts: $animation"
)
}
override
fun
onAnimationEnd
(
animation
:
Animation
)
{
it
.
isVisible
=
false
}
override
fun
onAnimationRepeat
(
animation
:
Animation
)
{
Timber
.
d
(
"Animation repeats: $animation"
)
}
})
it
.
startAnimation
(
anim
)
}
}
})
setDuration
(
DEFAULT_ANIMATION_DURATION
).
start
()
}
}
}
}
}
app/src/main/java/chat/rocket/android/chatroom/ui/ChatRoomFragment.kt
View file @
36f40fd8
...
@@ -71,6 +71,7 @@ import chat.rocket.android.helper.AndroidPermissionsHelper.hasCameraPermission
...
@@ -71,6 +71,7 @@ import chat.rocket.android.helper.AndroidPermissionsHelper.hasCameraPermission
import
chat.rocket.android.helper.AndroidPermissionsHelper.hasWriteExternalStoragePermission
import
chat.rocket.android.helper.AndroidPermissionsHelper.hasWriteExternalStoragePermission
import
chat.rocket.android.util.extension.asObservable
import
chat.rocket.android.util.extension.asObservable
import
chat.rocket.android.util.extension.createImageFile
import
chat.rocket.android.util.extension.createImageFile
import
chat.rocket.android.util.extension.orFalse
import
chat.rocket.android.util.extensions.circularRevealOrUnreveal
import
chat.rocket.android.util.extensions.circularRevealOrUnreveal
import
chat.rocket.android.util.extensions.clearLightStatusBar
import
chat.rocket.android.util.extensions.clearLightStatusBar
import
chat.rocket.android.util.extensions.fadeIn
import
chat.rocket.android.util.extensions.fadeIn
...
@@ -463,6 +464,7 @@ class ChatRoomFragment : Fragment(), ChatRoomView, EmojiKeyboardListener, EmojiR
...
@@ -463,6 +464,7 @@ class ChatRoomFragment : Fragment(), ChatRoomView, EmojiKeyboardListener, EmojiR
setupToolbar
(
roomUiModel
.
name
.
toString
())
setupToolbar
(
roomUiModel
.
name
.
toString
())
setupMessageComposer
(
roomUiModel
)
setupMessageComposer
(
roomUiModel
)
isBroadcastChannel
=
roomUiModel
.
broadcast
isBroadcastChannel
=
roomUiModel
.
broadcast
isFavorite
=
roomUiModel
.
favorite
.
orFalse
()
if
(
isBroadcastChannel
&&
!
roomUiModel
.
canModerate
)
{
if
(
isBroadcastChannel
&&
!
roomUiModel
.
canModerate
)
{
disableMenu
=
true
disableMenu
=
true
activity
?.
invalidateOptionsMenu
()
activity
?.
invalidateOptionsMenu
()
...
...
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