package com.juraj.fancyloginscreen import android.content.Context import android.net.Uri import android.os.Bundle import android.view.ViewGroup.LayoutParams.MATCH_PARENT import android.widget.FrameLayout import android.widget.Toast import androidx.activity.ComponentActivity import androidx.activity.compose.setContent import androidx.compose.foundation.layout.* import androidx.compose.foundation.text.KeyboardActions import androidx.compose.foundation.text.KeyboardOptions import androidx.compose.material.* import androidx.compose.material.icons.Icons import androidx.compose.material.icons.filled.Lock import androidx.compose.material.icons.filled.Person import androidx.compose.runtime.* import androidx.compose.ui.Alignment import androidx.compose.ui.Modifier import androidx.compose.ui.focus.FocusRequester import androidx.compose.ui.focus.focusOrder import androidx.compose.ui.graphics.Color import androidx.compose.ui.graphics.vector.ImageVector import androidx.compose.ui.platform.LocalContext import androidx.compose.ui.platform.LocalFocusManager import androidx.compose.ui.res.painterResource import androidx.compose.ui.text.input.ImeAction import androidx.compose.ui.text.input.KeyboardType import androidx.compose.ui.text.input.PasswordVisualTransformation import androidx.compose.ui.text.input.VisualTransformation import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import androidx.compose.ui.viewinterop.AndroidView import com.google.accompanist.insets.ProvideWindowInsets import com.google.accompanist.insets.navigationBarsWithImePadding import com.google.android.exoplayer2.ExoPlayer import com.google.android.exoplayer2.MediaItem import com.google.android.exoplayer2.Player import com.google.android.exoplayer2.ui.AspectRatioFrameLayout.RESIZE_MODE_ZOOM import com.google.android.exoplayer2.ui.StyledPlayerView import com.juraj.fancyloginscreen.ui.theme.FancyLoginScreenTheme import com.juraj.fancyloginscreen.ui.theme.Shapes class MainActivity : ComponentActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContent { FancyLoginScreenTheme { // A surface container using the 'background' color from the theme Surface( modifier = Modifier.fillMaxSize(), color = MaterialTheme.colors.background ) { Login(getVideoUri()) } } } } private fun Context.doLogin() { Toast.makeText( this, "Something went wrong, try again later!", Toast.LENGTH_SHORT ).show() } private fun Context.buildExoPlayer(uri: Uri) = ExoPlayer.Builder(this).build().apply { setMediaItem(MediaItem.fromUri(uri)) repeatMode = Player.REPEAT_MODE_ALL playWhenReady = true prepare() } private fun Context.buildPlayerView(exoPlayer: ExoPlayer) = StyledPlayerView(this).apply { player = exoPlayer layoutParams = FrameLayout.LayoutParams(MATCH_PARENT, MATCH_PARENT) useController = false resizeMode = RESIZE_MODE_ZOOM } @Composable fun Login(videoUri: Uri) { val context = LocalContext.current val passwordFocusRequester = FocusRequester() val focusManager = LocalFocusManager.current val exoPlayer = remember { context.buildExoPlayer(videoUri) } DisposableEffect( AndroidView( factory = { it.buildPlayerView(exoPlayer) }, modifier = Modifier.fillMaxSize() ) ) { onDispose { exoPlayer.release() } } ProvideWindowInsets { Column( Modifier .navigationBarsWithImePadding() .padding(24.dp) .fillMaxSize(), verticalArrangement = Arrangement.spacedBy(16.dp, alignment = Alignment.Bottom), horizontalAlignment = Alignment.CenterHorizontally ) { Icon( painter = painterResource(id = R.drawable.logo), null, Modifier.size(80.dp), tint = Color.White ) TextInput(InputType.Name, keyboardActions = KeyboardActions(onNext = { passwordFocusRequester.requestFocus() })) TextInput(InputType.Password, keyboardActions = KeyboardActions(onDone = { focusManager.clearFocus() context.doLogin() }), focusRequester = passwordFocusRequester) Button(onClick = { context.doLogin() }, modifier = Modifier.fillMaxWidth()) { Text("SIGN IN", Modifier.padding(vertical = 8.dp)) } Divider( color = Color.White.copy(alpha = 0.3f), thickness = 1.dp, modifier = Modifier.padding(top = 48.dp) ) Row(verticalAlignment = Alignment.CenterVertically) { Text("Don't have an account?", color = Color.White) TextButton(onClick = {}) { Text("SING UP") } } } } } sealed class InputType( val label: String, val icon: ImageVector, val keyboardOptions: KeyboardOptions, val visualTransformation: VisualTransformation ) { object Name : InputType( label = "Username", icon = Icons.Default.Person, keyboardOptions = KeyboardOptions(imeAction = ImeAction.Next), visualTransformation = VisualTransformation.None ) object Password : InputType( label = "Password", icon = Icons.Default.Lock, keyboardOptions = KeyboardOptions( imeAction = ImeAction.Done, keyboardType = KeyboardType.Password ), visualTransformation = PasswordVisualTransformation() ) } @Composable fun TextInput( inputType: InputType, focusRequester: FocusRequester? = null, keyboardActions: KeyboardActions ) { var value by remember { mutableStateOf("") } TextField( value = value, onValueChange = { value = it }, modifier = Modifier .fillMaxWidth() .focusOrder(focusRequester ?: FocusRequester()), leadingIcon = { Icon(imageVector = inputType.icon, null) }, label = { Text(text = inputType.label) }, shape = Shapes.small, colors = TextFieldDefaults.textFieldColors( backgroundColor = Color.White, focusedIndicatorColor = Color.Transparent, unfocusedIndicatorColor = Color.Transparent, disabledIndicatorColor = Color.Transparent ), singleLine = true, keyboardOptions = inputType.keyboardOptions, visualTransformation = inputType.visualTransformation, keyboardActions = keyboardActions ) }
Write, Run & Share Kotlin code online using OneCompiler’s Kotlin online compiler for free. It’s a modern and fast online playground for Kotlin, supporting the latest version and ideal for learning, experimenting, and sharing code instantly.
Kotlin is a statically typed, modern programming language developed by JetBrains. It runs on the JVM and is fully interoperable with Java. Kotlin is concise, expressive, and safe, and it’s officially supported by Google for Android app development.
The following is a simple Kotlin program that prints a greeting:
fun main() {
println("Hello, OneCompiler!")
}
OneCompiler’s Kotlin editor supports stdin. You can provide input using the I/O tab. Here's a sample program that reads a line of input and prints a greeting:
fun main() {
print("Enter your name: ")
val name = readLine()
println("Hello, $name")
}
val name: String = "OneCompiler" // Immutable
var age: Int = 25 // Mutable
Kotlin supports type inference, so explicit types are optional:
val city = "Hyderabad"
var count = 10
val score = 85
if (score >= 50) {
println("Pass")
} else {
println("Fail")
}
for (i in 1..5) {
println(i)
}
var i = 1
while (i <= 5) {
println(i)
i++
}
var j = 1
do {
println(j)
j++
} while (j <= 5)
fun add(a: Int, b: Int): Int {
return a + b
}
fun greet(name: String) = "Hello, $name"
val items = listOf("apple", "banana", "cherry")
for (item in items) {
println(item)
}
This guide provides a quick reference to Kotlin programming syntax and features. Start coding in Kotlin using OneCompiler’s Kotlin online compiler today!