Second commit
This commit is contained in:
parent
4a71378e39
commit
ec8f6bbf54
@ -7,6 +7,8 @@
|
|||||||
<entry key="app/src/main/res/layout/activity_login.xml" value="0.37083333333333335" />
|
<entry key="app/src/main/res/layout/activity_login.xml" value="0.37083333333333335" />
|
||||||
<entry key="app/src/main/res/layout/activity_main.xml" value="0.35625" />
|
<entry key="app/src/main/res/layout/activity_main.xml" value="0.35625" />
|
||||||
<entry key="app/src/main/res/layout/activity_sign_up.xml" value="0.4375" />
|
<entry key="app/src/main/res/layout/activity_sign_up.xml" value="0.4375" />
|
||||||
|
<entry key="app/src/main/res/layout/user_layout.xml" value="0.25" />
|
||||||
|
<entry key="app/src/main/res/menu/main_menu.xml" value="0.4375" />
|
||||||
</map>
|
</map>
|
||||||
</option>
|
</option>
|
||||||
</component>
|
</component>
|
||||||
|
@ -1,5 +1,8 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
<project version="4">
|
<project version="4">
|
||||||
|
<component name="GitSharedSettings">
|
||||||
|
<option name="synchronizeBranchProtectionRules" value="false" />
|
||||||
|
</component>
|
||||||
<component name="VcsDirectoryMappings">
|
<component name="VcsDirectoryMappings">
|
||||||
<mapping directory="$PROJECT_DIR$" vcs="Git" />
|
<mapping directory="$PROJECT_DIR$" vcs="Git" />
|
||||||
</component>
|
</component>
|
||||||
|
@ -42,6 +42,7 @@ dependencies {
|
|||||||
implementation 'com.google.android.material:material:1.6.1'
|
implementation 'com.google.android.material:material:1.6.1'
|
||||||
implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
|
implementation 'androidx.constraintlayout:constraintlayout:2.1.4'
|
||||||
implementation 'com.google.firebase:firebase-auth:19.2.0'
|
implementation 'com.google.firebase:firebase-auth:19.2.0'
|
||||||
|
implementation 'com.google.firebase:firebase-database-ktx:20.1.0'
|
||||||
testImplementation 'junit:junit:4.13.2'
|
testImplementation 'junit:junit:4.13.2'
|
||||||
androidTestImplementation 'androidx.test.ext:junit:1.1.3'
|
androidTestImplementation 'androidx.test.ext:junit:1.1.3'
|
||||||
androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0'
|
androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0'
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
{
|
{
|
||||||
"project_info": {
|
"project_info": {
|
||||||
"project_number": "233851758467",
|
"project_number": "233851758467",
|
||||||
|
"firebase_url": "https://chatapplication-4eb49-default-rtdb.europe-west1.firebasedatabase.app",
|
||||||
"project_id": "chatapplication-4eb49",
|
"project_id": "chatapplication-4eb49",
|
||||||
"storage_bucket": "chatapplication-4eb49.appspot.com"
|
"storage_bucket": "chatapplication-4eb49.appspot.com"
|
||||||
},
|
},
|
||||||
|
@ -14,8 +14,12 @@
|
|||||||
android:theme="@style/Theme.ChatApplication"
|
android:theme="@style/Theme.ChatApplication"
|
||||||
tools:targetApi="31">
|
tools:targetApi="31">
|
||||||
<activity
|
<activity
|
||||||
android:name=".SignUp"
|
android:name=".ChatActivity"
|
||||||
android:exported="false" />
|
android:exported="false" />
|
||||||
|
<activity
|
||||||
|
android:name=".SignUp"
|
||||||
|
android:exported="false"
|
||||||
|
android:parentActivityName=".LogIn" />
|
||||||
<activity
|
<activity
|
||||||
android:name=".LogIn"
|
android:name=".LogIn"
|
||||||
android:exported="true">
|
android:exported="true">
|
||||||
|
11
app/src/main/java/com/lsm/chatapplication/ChatActivity.kt
Normal file
11
app/src/main/java/com/lsm/chatapplication/ChatActivity.kt
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
package com.lsm.chatapplication
|
||||||
|
|
||||||
|
import androidx.appcompat.app.AppCompatActivity
|
||||||
|
import android.os.Bundle
|
||||||
|
|
||||||
|
class ChatActivity : AppCompatActivity() {
|
||||||
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
|
super.onCreate(savedInstanceState)
|
||||||
|
setContentView(R.layout.activity_chat)
|
||||||
|
}
|
||||||
|
}
|
@ -3,6 +3,7 @@ package com.lsm.chatapplication
|
|||||||
import android.content.Intent
|
import android.content.Intent
|
||||||
import androidx.appcompat.app.AppCompatActivity
|
import androidx.appcompat.app.AppCompatActivity
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
|
import android.widget.Toast
|
||||||
import com.google.firebase.auth.FirebaseAuth
|
import com.google.firebase.auth.FirebaseAuth
|
||||||
import com.lsm.chatapplication.databinding.ActivityLogInBinding
|
import com.lsm.chatapplication.databinding.ActivityLogInBinding
|
||||||
|
|
||||||
@ -17,6 +18,8 @@ class LogIn : AppCompatActivity() {
|
|||||||
val view = binding.root
|
val view = binding.root
|
||||||
setContentView(view)
|
setContentView(view)
|
||||||
|
|
||||||
|
// supportActionBar?.hide()
|
||||||
|
|
||||||
mAuth = FirebaseAuth.getInstance()
|
mAuth = FirebaseAuth.getInstance()
|
||||||
|
|
||||||
binding.logInBtn.setOnClickListener{
|
binding.logInBtn.setOnClickListener{
|
||||||
@ -31,6 +34,17 @@ class LogIn : AppCompatActivity() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
private fun logIn(email: String, password: String){
|
private fun logIn(email: String, password: String){
|
||||||
|
mAuth.signInWithEmailAndPassword(email, password)
|
||||||
|
.addOnCompleteListener(this) { task ->
|
||||||
|
if (task.isSuccessful) {
|
||||||
|
// Move to home
|
||||||
|
val intent = Intent(this@LogIn, MainActivity::class.java)
|
||||||
|
finish()
|
||||||
|
startActivity(intent)
|
||||||
|
} else {
|
||||||
|
// Logging error message
|
||||||
|
Toast.makeText(this@LogIn,"User doest not exits",Toast.LENGTH_SHORT).show()
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,11 +1,82 @@
|
|||||||
package com.lsm.chatapplication
|
package com.lsm.chatapplication
|
||||||
|
|
||||||
|
import android.content.Intent
|
||||||
import androidx.appcompat.app.AppCompatActivity
|
import androidx.appcompat.app.AppCompatActivity
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
|
import android.view.Menu
|
||||||
|
import android.view.MenuItem
|
||||||
|
import androidx.recyclerview.widget.LinearLayoutManager
|
||||||
|
import com.google.firebase.auth.FirebaseAuth
|
||||||
|
import com.google.firebase.database.DataSnapshot
|
||||||
|
import com.google.firebase.database.DatabaseError
|
||||||
|
import com.google.firebase.database.ValueEventListener
|
||||||
|
import com.google.firebase.database.ktx.database
|
||||||
|
import com.google.firebase.ktx.Firebase
|
||||||
|
import com.lsm.chatapplication.databinding.ActivityMainBinding
|
||||||
|
|
||||||
class MainActivity : AppCompatActivity() {
|
class MainActivity : AppCompatActivity() {
|
||||||
|
private lateinit var binding: ActivityMainBinding
|
||||||
|
private lateinit var userList: ArrayList<User>
|
||||||
|
private lateinit var adapter: UserAdapter
|
||||||
|
private lateinit var mAuth: FirebaseAuth
|
||||||
|
|
||||||
override fun onCreate(savedInstanceState: Bundle?) {
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
super.onCreate(savedInstanceState)
|
super.onCreate(savedInstanceState)
|
||||||
setContentView(R.layout.activity_main)
|
binding = ActivityMainBinding.inflate(layoutInflater)
|
||||||
|
setContentView(binding.root)
|
||||||
|
|
||||||
|
mAuth = FirebaseAuth.getInstance()
|
||||||
|
|
||||||
|
userList = ArrayList()
|
||||||
|
adapter = UserAdapter()
|
||||||
|
// adapter.submitList(userList)
|
||||||
|
|
||||||
|
binding.userRecyclerView.layoutManager = LinearLayoutManager(this)
|
||||||
|
binding.userRecyclerView.adapter = adapter
|
||||||
|
|
||||||
|
readUsersFromDatabase()
|
||||||
|
}
|
||||||
|
|
||||||
|
private fun readUsersFromDatabase(){
|
||||||
|
val mDbRef = Firebase.database("https://chatapplication-4eb49-default-rtdb.europe-west1.firebasedatabase.app/").reference
|
||||||
|
mDbRef.child("user").addValueEventListener(object: ValueEventListener{
|
||||||
|
override fun onDataChange(snapshot: DataSnapshot) {
|
||||||
|
|
||||||
|
userList.clear()
|
||||||
|
// for(postSnapshot in snapshot.children){
|
||||||
|
// val currentUser = postSnapshot.getValue(User::class.java)
|
||||||
|
// userList.add(currentUser!!)
|
||||||
|
// }
|
||||||
|
snapshot.children.forEach {
|
||||||
|
val currentUser = it.getValue(User::class.java)
|
||||||
|
userList.add(currentUser!!)
|
||||||
|
}
|
||||||
|
userList.removeAll(
|
||||||
|
userList.filter{it.uid == mAuth.currentUser?.uid}.toSet()
|
||||||
|
)
|
||||||
|
// userList.removeIf{it.uid == mAuth.currentUser?.uid}
|
||||||
|
adapter.submitList(userList)
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onCancelled(error: DatabaseError) {
|
||||||
|
TODO("Not yet implemented")
|
||||||
|
}
|
||||||
|
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onCreateOptionsMenu(menu: Menu): Boolean {
|
||||||
|
menuInflater.inflate(R.menu.main_menu,menu)
|
||||||
|
return super.onCreateOptionsMenu(menu)
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onOptionsItemSelected(item: MenuItem): Boolean {
|
||||||
|
if(item.itemId == R.id.Logout){
|
||||||
|
mAuth.signOut()
|
||||||
|
finish()
|
||||||
|
val intent = Intent(this, LogIn::class.java)
|
||||||
|
startActivity(intent)
|
||||||
|
}
|
||||||
|
return true
|
||||||
}
|
}
|
||||||
}
|
}
|
@ -1,13 +1,20 @@
|
|||||||
package com.lsm.chatapplication
|
package com.lsm.chatapplication
|
||||||
|
|
||||||
|
import android.content.Intent
|
||||||
import androidx.appcompat.app.AppCompatActivity
|
import androidx.appcompat.app.AppCompatActivity
|
||||||
import android.os.Bundle
|
import android.os.Bundle
|
||||||
|
import android.widget.Toast
|
||||||
import com.google.firebase.auth.FirebaseAuth
|
import com.google.firebase.auth.FirebaseAuth
|
||||||
|
import com.google.firebase.database.DatabaseReference
|
||||||
|
import com.google.firebase.database.FirebaseDatabase
|
||||||
|
import com.google.firebase.database.ktx.database
|
||||||
|
import com.google.firebase.ktx.Firebase
|
||||||
import com.lsm.chatapplication.databinding.ActivitySignUpBinding
|
import com.lsm.chatapplication.databinding.ActivitySignUpBinding
|
||||||
|
|
||||||
class SignUp : AppCompatActivity() {
|
class SignUp : AppCompatActivity() {
|
||||||
private lateinit var binding: ActivitySignUpBinding
|
private lateinit var binding: ActivitySignUpBinding
|
||||||
private lateinit var mAuth: FirebaseAuth
|
private lateinit var mAuth: FirebaseAuth
|
||||||
|
// private lateinit var mDbRef: DatabaseReference
|
||||||
|
|
||||||
override fun onCreate(savedInstanceState: Bundle?) {
|
override fun onCreate(savedInstanceState: Bundle?) {
|
||||||
super.onCreate(savedInstanceState)
|
super.onCreate(savedInstanceState)
|
||||||
@ -15,16 +22,37 @@ class SignUp : AppCompatActivity() {
|
|||||||
val view = binding.root
|
val view = binding.root
|
||||||
setContentView(view)
|
setContentView(view)
|
||||||
|
|
||||||
|
// supportActionBar?.hide()
|
||||||
|
|
||||||
mAuth = FirebaseAuth.getInstance()
|
mAuth = FirebaseAuth.getInstance()
|
||||||
|
// mDbRef = Firebase.database("https://chatapplication-4eb49-default-rtdb.europe-west1.firebasedatabase.app/").reference
|
||||||
|
|
||||||
binding.signUpBtn.setOnClickListener{
|
binding.signUpBtn.setOnClickListener{
|
||||||
val usrName = binding.edtUserName.text.toString()
|
val usrName = binding.edtUserName.text.toString()
|
||||||
val email = binding.edtEmail.text.toString()
|
val email = binding.edtEmail.text.toString()
|
||||||
val password = binding.edtPassword.text.toString()
|
val password = binding.edtPassword.text.toString()
|
||||||
signUp(email,password)
|
signUp(usrName, email,password)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
private fun signUp(name:String, email: String, password: String){
|
||||||
|
mAuth.createUserWithEmailAndPassword(email, password)
|
||||||
|
.addOnCompleteListener(this) { task ->
|
||||||
|
if (task.isSuccessful) {
|
||||||
|
// Jumping to home
|
||||||
|
addUserToDatabase(name, email, mAuth.currentUser?.uid!!)
|
||||||
|
val intent = Intent(this@SignUp,MainActivity::class.java)
|
||||||
|
finish()
|
||||||
|
startActivity(intent)
|
||||||
|
} else {
|
||||||
|
// Account creation error message
|
||||||
|
Toast.makeText(this@SignUp,task.exception?.toString(),Toast.LENGTH_LONG).show()
|
||||||
|
//Toast.makeText(this@SignUp,"Some error occurred",Toast.LENGTH_SHORT).show()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
private fun signUp(email: String, password: String){
|
|
||||||
|
|
||||||
|
private fun addUserToDatabase(name: String, email: String, uid: String){
|
||||||
|
val mDbRef = Firebase.database("https://chatapplication-4eb49-default-rtdb.europe-west1.firebasedatabase.app/").reference
|
||||||
|
mDbRef.child("user").child(uid).setValue(User(name,email,uid))
|
||||||
}
|
}
|
||||||
}
|
}
|
17
app/src/main/java/com/lsm/chatapplication/User.kt
Normal file
17
app/src/main/java/com/lsm/chatapplication/User.kt
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
package com.lsm.chatapplication
|
||||||
|
|
||||||
|
class User (var name: String?, var email: String?, var uid: String?){
|
||||||
|
|
||||||
|
constructor() : this(null,null,null) {}
|
||||||
|
|
||||||
|
override fun equals(other: Any?): Boolean {
|
||||||
|
return super.equals(other)
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun hashCode(): Int {
|
||||||
|
var result = name?.hashCode() ?: 0
|
||||||
|
result = 31 * result + (email?.hashCode() ?: 0)
|
||||||
|
result = 31 * result + (uid?.hashCode() ?: 0)
|
||||||
|
return result
|
||||||
|
}
|
||||||
|
}
|
53
app/src/main/java/com/lsm/chatapplication/UserAdapter.kt
Normal file
53
app/src/main/java/com/lsm/chatapplication/UserAdapter.kt
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
package com.lsm.chatapplication
|
||||||
|
|
||||||
|
import android.view.LayoutInflater
|
||||||
|
import android.view.View
|
||||||
|
import android.view.ViewGroup
|
||||||
|
import androidx.recyclerview.widget.DiffUtil
|
||||||
|
import androidx.recyclerview.widget.ListAdapter
|
||||||
|
import androidx.recyclerview.widget.RecyclerView
|
||||||
|
import com.lsm.chatapplication.databinding.UserLayoutBinding
|
||||||
|
|
||||||
|
//class UserAdapter(val userList: ArrayList<User>):
|
||||||
|
// RecyclerView.Adapter<UserAdapter.UserViewHolder>() {
|
||||||
|
//
|
||||||
|
// class UserViewHolder(val binding: UserLayoutBinding): RecyclerView.ViewHolder(binding.root)
|
||||||
|
//
|
||||||
|
// override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): UserViewHolder {
|
||||||
|
// return UserViewHolder(UserLayoutBinding.inflate(LayoutInflater.from(parent.context), parent, false))
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// override fun onBindViewHolder(holder: UserViewHolder, position: Int) {
|
||||||
|
// val currentUser = userList[position]
|
||||||
|
// holder.binding.userName.text = currentUser.name
|
||||||
|
// }
|
||||||
|
//
|
||||||
|
// override fun getItemCount(): Int {
|
||||||
|
// return userList.size
|
||||||
|
// }
|
||||||
|
//}
|
||||||
|
class UserAdapter():
|
||||||
|
ListAdapter<User,UserAdapter.UserViewHolder>(TaskDiffCallBack()){
|
||||||
|
|
||||||
|
class TaskDiffCallBack: DiffUtil.ItemCallback<User>() {
|
||||||
|
override fun areItemsTheSame(oldItem: User, newItem: User): Boolean {
|
||||||
|
return oldItem.uid == newItem.uid
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun areContentsTheSame(oldItem: User, newItem: User): Boolean {
|
||||||
|
return oldItem == newItem
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class UserViewHolder(val binding: UserLayoutBinding): RecyclerView.ViewHolder(binding.root)
|
||||||
|
|
||||||
|
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): UserViewHolder {
|
||||||
|
return UserViewHolder(UserLayoutBinding.inflate(LayoutInflater.from(parent.context), parent, false))
|
||||||
|
}
|
||||||
|
|
||||||
|
override fun onBindViewHolder(holder: UserViewHolder, position: Int) {
|
||||||
|
val currentUser = getItem(position)
|
||||||
|
holder.binding.userName.text = currentUser.name
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
9
app/src/main/res/layout/activity_chat.xml
Normal file
9
app/src/main/res/layout/activity_chat.xml
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
xmlns:tools="http://schemas.android.com/tools"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
tools:context=".ChatActivity">
|
||||||
|
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
@ -6,4 +6,13 @@
|
|||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
tools:context=".MainActivity">
|
tools:context=".MainActivity">
|
||||||
|
|
||||||
|
<androidx.recyclerview.widget.RecyclerView
|
||||||
|
android:id="@+id/user_recycler_view"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
tools:listitem="@layout/user_layout"
|
||||||
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toTopOf="parent" />
|
||||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
42
app/src/main/res/layout/user_layout.xml
Normal file
42
app/src/main/res/layout/user_layout.xml
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
|
|
||||||
|
<androidx.cardview.widget.CardView
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginBottom="8dp"
|
||||||
|
app:cardBackgroundColor="@color/white"
|
||||||
|
app:cardCornerRadius="10dp"
|
||||||
|
app:cardElevation="4dp"
|
||||||
|
app:contentPadding="10dp"
|
||||||
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toTopOf="parent">
|
||||||
|
|
||||||
|
<androidx.constraintlayout.widget.ConstraintLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<TextView
|
||||||
|
android:id="@+id/user_name"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_marginStart="24dp"
|
||||||
|
android:layout_marginTop="8dp"
|
||||||
|
android:layout_marginBottom="8dp"
|
||||||
|
android:text="TextView"
|
||||||
|
android:textSize="20sp"
|
||||||
|
android:textStyle="bold"
|
||||||
|
app:layout_constraintBottom_toBottomOf="parent"
|
||||||
|
app:layout_constraintEnd_toEndOf="parent"
|
||||||
|
app:layout_constraintHorizontal_bias="0.0"
|
||||||
|
app:layout_constraintStart_toStartOf="parent"
|
||||||
|
app:layout_constraintTop_toTopOf="parent" />
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
||||||
|
|
||||||
|
</androidx.cardview.widget.CardView>
|
||||||
|
</androidx.constraintlayout.widget.ConstraintLayout>
|
7
app/src/main/res/menu/main_menu.xml
Normal file
7
app/src/main/res/menu/main_menu.xml
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<menu xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
|
||||||
|
<item
|
||||||
|
android:id="@+id/Logout"
|
||||||
|
android:title="@string/logout_menu" />
|
||||||
|
</menu>
|
@ -6,4 +6,5 @@
|
|||||||
<string name="user_name_hint">User Name</string>
|
<string name="user_name_hint">User Name</string>
|
||||||
<string name="sign_up_btn_text">Create new account</string>
|
<string name="sign_up_btn_text">Create new account</string>
|
||||||
<string name="options_separator_text">Or</string>
|
<string name="options_separator_text">Or</string>
|
||||||
|
<string name="logout_menu">Log Out</string>
|
||||||
</resources>
|
</resources>
|
@ -1,7 +1,7 @@
|
|||||||
// Top-level build file where you can add configuration options common to all sub-projects/modules.
|
// Top-level build file where you can add configuration options common to all sub-projects/modules.
|
||||||
buildscript {
|
buildscript {
|
||||||
dependencies {
|
dependencies {
|
||||||
classpath 'com.google.gms:google-services:4.3.13'
|
classpath 'com.google.gms:google-services:4.3.14'
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user