@ -0,0 +1,15 @@ | |||||
*.iml | |||||
.gradle | |||||
/local.properties | |||||
/.idea/caches | |||||
/.idea/libraries | |||||
/.idea/modules.xml | |||||
/.idea/workspace.xml | |||||
/.idea/navEditor.xml | |||||
/.idea/assetWizardSettings.xml | |||||
.DS_Store | |||||
/build | |||||
/captures | |||||
.externalNativeBuild | |||||
.cxx | |||||
local.properties |
@ -0,0 +1,3 @@ | |||||
# Default ignored files | |||||
/shelf/ | |||||
/workspace.xml |
@ -0,0 +1 @@ | |||||
acaPendulum2.0 |
@ -0,0 +1,6 @@ | |||||
<?xml version="1.0" encoding="UTF-8"?> | |||||
<project version="4"> | |||||
<component name="CompilerConfiguration"> | |||||
<bytecodeTargetLevel target="11" /> | |||||
</component> | |||||
</project> |
@ -0,0 +1,20 @@ | |||||
<?xml version="1.0" encoding="UTF-8"?> | |||||
<project version="4"> | |||||
<component name="GradleMigrationSettings" migrationVersion="1" /> | |||||
<component name="GradleSettings"> | |||||
<option name="linkedExternalProjectsSettings"> | |||||
<GradleProjectSettings> | |||||
<option name="testRunner" value="GRADLE" /> | |||||
<option name="distributionType" value="DEFAULT_WRAPPED" /> | |||||
<option name="externalProjectPath" value="$PROJECT_DIR$" /> | |||||
<option name="modules"> | |||||
<set> | |||||
<option value="$PROJECT_DIR$" /> | |||||
<option value="$PROJECT_DIR$/app" /> | |||||
</set> | |||||
</option> | |||||
<option name="resolveModulePerSourceSet" value="false" /> | |||||
</GradleProjectSettings> | |||||
</option> | |||||
</component> | |||||
</project> |
@ -0,0 +1,24 @@ | |||||
<?xml version="1.0" encoding="UTF-8"?> | |||||
<project version="4"> | |||||
<component name="DesignSurface"> | |||||
<option name="filePathToZoomLevelMap"> | |||||
<map> | |||||
<entry key="..\:/Users/Feyzu/AndroidStudioProjects/acaPendulum20/app/src/main/res/drawable-v24/vd_vector.xml" value="0.545" /> | |||||
<entry key="..\:/Users/Feyzu/AndroidStudioProjects/acaPendulum20/app/src/main/res/layout/activity_main.xml" value="0.29713114754098363" /> | |||||
<entry key="..\:/Users/Feyzu/AndroidStudioProjects/acaPendulum20/app/src/main/res/layout/custom_row.xml" value="0.384375" /> | |||||
<entry key="..\:/Users/Feyzu/AndroidStudioProjects/acaPendulum20/app/src/main/res/layout/fragment_add.xml" value="0.45416666666666666" /> | |||||
<entry key="..\:/Users/Feyzu/AndroidStudioProjects/acaPendulum20/app/src/main/res/layout/fragment_list.xml" value="0.45416666666666666" /> | |||||
<entry key="..\:/Users/Feyzu/AndroidStudioProjects/acaPendulum20/app/src/main/res/layout/fragment_pendulum.xml" value="0.49130434782608695" /> | |||||
<entry key="..\:/Users/Feyzu/AndroidStudioProjects/acaPendulum20/app/src/main/res/layout/fragment_pendulum2.xml" value="0.5541666666666667" /> | |||||
<entry key="..\:/Users/Feyzu/AndroidStudioProjects/acaPendulum20/app/src/main/res/layout/fragment_update.xml" value="0.33" /> | |||||
<entry key="..\:/Users/Feyzu/AndroidStudioProjects/acaPendulum20/app/src/main/res/menu/delete_menu.xml" value="0.5541666666666667" /> | |||||
</map> | |||||
</option> | |||||
</component> | |||||
<component name="ProjectRootManager" version="2" languageLevel="JDK_11" default="true" project-jdk-name="11" project-jdk-type="JavaSDK"> | |||||
<output url="file://$PROJECT_DIR$/build/classes" /> | |||||
</component> | |||||
<component name="ProjectType"> | |||||
<option name="id" value="Android" /> | |||||
</component> | |||||
</project> |
@ -0,0 +1 @@ | |||||
/build |
@ -0,0 +1,84 @@ | |||||
plugins { | |||||
id 'com.android.application' | |||||
id 'kotlin-android' | |||||
id 'kotlin-android-extensions' | |||||
id 'kotlin-kapt' | |||||
id 'org.jetbrains.kotlin.android' | |||||
//id 'android.navigation.safeargs.kotlin' | |||||
id 'androidx.navigation.safeargs' | |||||
} | |||||
android { | |||||
compileSdk 31 | |||||
defaultConfig { | |||||
applicationId "com.example.acapendulum20" | |||||
minSdk 26 | |||||
targetSdk 31 | |||||
versionCode 1 | |||||
versionName "1.0" | |||||
testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner" | |||||
} | |||||
buildTypes { | |||||
release { | |||||
minifyEnabled false | |||||
proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' | |||||
} | |||||
} | |||||
packagingOptions { | |||||
exclude 'META-INF/atomicfu.kotlin_module' | |||||
} | |||||
compileOptions { | |||||
sourceCompatibility JavaVersion.VERSION_1_8 | |||||
targetCompatibility JavaVersion.VERSION_1_8 | |||||
} | |||||
kotlinOptions { | |||||
jvmTarget = '1.8' | |||||
} | |||||
buildFeatures { | |||||
viewBinding = true | |||||
} | |||||
} | |||||
dependencies { | |||||
implementation fileTree(dir: "libs", include: ["*.jar"]) | |||||
implementation 'androidx.core:core-ktx:1.7.0' | |||||
//implementation "org.jetbrians.kotlin:kotlin-stdlib:$kotlin_version" | |||||
implementation 'androidx.appcompat:appcompat:1.4.1' | |||||
implementation 'com.google.android.material:material:1.5.0' | |||||
implementation 'androidx.constraintlayout:constraintlayout:2.1.3' | |||||
implementation 'androidx.legacy:legacy-support-v4:1.0.0' | |||||
testImplementation 'junit:junit:4.13.2' | |||||
androidTestImplementation 'androidx.test.ext:junit:1.1.3' | |||||
androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0' | |||||
// Navigation Component | |||||
implementation 'androidx.navigation:navigation-fragment-ktx:2.4.2' | |||||
implementation 'androidx.navigation:navigation-ui-ktx:2.4.2' | |||||
// Room components | |||||
implementation "androidx.room:room-runtime:2.4.2" | |||||
kapt "androidx.room:room-compiler:2.4.2" | |||||
implementation "androidx.room:room-ktx:2.4.2" | |||||
androidTestImplementation "androidx.room:room-testing:2.4.2" | |||||
// Lifecycle components | |||||
implementation "androidx.lifecycle:lifecycle-extensions:2.2.0" | |||||
implementation "androidx.lifecycle:lifecycle-common-java8:2.4.1" | |||||
implementation "androidx.lifecycle:lifecycle-viewmodel-ktx:2.4.1" | |||||
// Kotlin components | |||||
implementation "org.jetbrains.kotlin:kotlin-stdlib-jdk7:1.6.20" | |||||
api "org.jetbrains.kotlinx:kotlinx-coroutines-core:1.4.1" | |||||
api "org.jetbrains.kotlinx:kotlinx-coroutines-android:1.5.2" | |||||
} |
@ -0,0 +1,21 @@ | |||||
# Add project specific ProGuard rules here. | |||||
# You can control the set of applied configuration files using the | |||||
# proguardFiles setting in build.gradle. | |||||
# | |||||
# For more details, see | |||||
# http://developer.android.com/guide/developing/tools/proguard.html | |||||
# If your project uses WebView with JS, uncomment the following | |||||
# and specify the fully qualified class name to the JavaScript interface | |||||
# class: | |||||
#-keepclassmembers class fqcn.of.javascript.interface.for.webview { | |||||
# public *; | |||||
#} | |||||
# Uncomment this to preserve the line number information for | |||||
# debugging stack traces. | |||||
#-keepattributes SourceFile,LineNumberTable | |||||
# If you keep the line number information, uncomment this to | |||||
# hide the original source file name. | |||||
#-renamesourcefileattribute SourceFile |
@ -0,0 +1,24 @@ | |||||
package com.example.acapendulum20 | |||||
import androidx.test.platform.app.InstrumentationRegistry | |||||
import androidx.test.ext.junit.runners.AndroidJUnit4 | |||||
import org.junit.Test | |||||
import org.junit.runner.RunWith | |||||
import org.junit.Assert.* | |||||
/** | |||||
* Instrumented test, which will execute on an Android device. | |||||
* | |||||
* See [testing documentation](http://d.android.com/tools/testing). | |||||
*/ | |||||
@RunWith(AndroidJUnit4::class) | |||||
class ExampleInstrumentedTest { | |||||
@Test | |||||
fun useAppContext() { | |||||
// Context of the app under test. | |||||
val appContext = InstrumentationRegistry.getInstrumentation().targetContext | |||||
assertEquals("com.example.acapendulum20", appContext.packageName) | |||||
} | |||||
} |
@ -0,0 +1,23 @@ | |||||
<?xml version="1.0" encoding="utf-8"?> | |||||
<manifest xmlns:android="http://schemas.android.com/apk/res/android" | |||||
package="com.example.acapendulum20"> | |||||
<application | |||||
android:allowBackup="true" | |||||
android:icon="@mipmap/ic_launcher" | |||||
android:label="@string/app_name" | |||||
android:roundIcon="@mipmap/ic_launcher_round" | |||||
android:supportsRtl="true" | |||||
android:theme="@style/Theme.AcaPendulum20"> | |||||
<activity | |||||
android:name=".MainActivity" | |||||
android:exported="true"> | |||||
<intent-filter> | |||||
<action android:name="android.intent.action.MAIN" /> | |||||
<category android:name="android.intent.category.LAUNCHER" /> | |||||
</intent-filter> | |||||
</activity> | |||||
</application> | |||||
</manifest> |
@ -0,0 +1,22 @@ | |||||
package com.example.acapendulum20 | |||||
import android.graphics.Canvas | |||||
import androidx.appcompat.app.AppCompatActivity | |||||
import android.os.Bundle | |||||
import androidx.navigation.findNavController | |||||
import androidx.navigation.ui.setupActionBarWithNavController | |||||
import kotlinx.android.synthetic.main.activity_main.* | |||||
class MainActivity : AppCompatActivity() { | |||||
override fun onCreate(savedInstanceState: Bundle?) { | |||||
super.onCreate(savedInstanceState) | |||||
setContentView(R.layout.activity_main) | |||||
setupActionBarWithNavController(findNavController(R.id.fragment)) | |||||
} | |||||
override fun onSupportNavigateUp(): Boolean { | |||||
val navController = findNavController(R.id.fragment) | |||||
return navController.navigateUp() || super.onSupportNavigateUp() | |||||
} | |||||
} |
@ -0,0 +1,32 @@ | |||||
package com.example.acapendulum20.canvas | |||||
import android.content.Context | |||||
import android.graphics.Canvas | |||||
import android.graphics.Paint | |||||
import android.util.AttributeSet | |||||
import android.view.View | |||||
class CanvasView @JvmOverloads constructor( | |||||
context: Context, attrs: AttributeSet? = null, defStyleAttr: Int = 0 | |||||
) : View(context, attrs, defStyleAttr) { | |||||
val paint: Paint = Paint() | |||||
override fun onDraw(canvas: Canvas?) { | |||||
super.onDraw(canvas) | |||||
paint.strokeWidth = 9f | |||||
canvas?.drawLine(455f,0f,500f, 630f,paint) | |||||
} | |||||
fun drawBob(canvas: Canvas?) { | |||||
paint.style = Paint.Style.STROKE | |||||
paint.strokeWidth = 10f | |||||
canvas?.drawCircle(500f, 700f, 70f, paint) | |||||
} | |||||
fun drawBob() { | |||||
println("hallo") | |||||
} | |||||
} |
@ -0,0 +1,25 @@ | |||||
package com.example.acapendulum20.data | |||||
import androidx.lifecycle.LiveData | |||||
import androidx.room.* | |||||
import com.example.acapendulum20.model.User | |||||
@Dao | |||||
interface UserDao { | |||||
@Insert(onConflict = OnConflictStrategy.IGNORE ) | |||||
suspend fun addUser(user: User) | |||||
@Update | |||||
suspend fun updateUser(user: User) | |||||
@Delete | |||||
suspend fun deleteUser(user: User) | |||||
@Query("DELETE FROM user_table") | |||||
suspend fun deleteAllUsers() | |||||
@Query("SELECT * FROM user_table ORDER BY id ASC") | |||||
fun readAllData(): LiveData<List<User>> | |||||
} |
@ -0,0 +1,33 @@ | |||||
package com.example.acapendulum20.data | |||||
import android.content.Context | |||||
import androidx.room.Database | |||||
import androidx.room.Room | |||||
import androidx.room.RoomDatabase | |||||
import com.example.acapendulum20.model.User | |||||
@Database(entities = [User::class], version = 1, exportSchema = false) | |||||
abstract class UserDatabase: RoomDatabase() { | |||||
abstract fun userDao(): UserDao | |||||
companion object { | |||||
@Volatile | |||||
private var INSTANCE: UserDatabase? = null | |||||
fun getDatabase(context: Context): UserDatabase{ | |||||
val tempInstance = INSTANCE | |||||
if(tempInstance != null){ | |||||
return tempInstance | |||||
} | |||||
synchronized(this){ | |||||
val instance = Room.databaseBuilder( | |||||
context.applicationContext, | |||||
UserDatabase::class.java, | |||||
"user_database" | |||||
).build() | |||||
INSTANCE = instance | |||||
return instance | |||||
} | |||||
} | |||||
} | |||||
} |
@ -0,0 +1,63 @@ | |||||
package com.example.acapendulum20.fragments.add | |||||
import android.os.Bundle | |||||
import android.text.Editable | |||||
import android.text.TextUtils | |||||
import androidx.fragment.app.Fragment | |||||
import android.view.LayoutInflater | |||||
import android.view.View | |||||
import android.view.ViewGroup | |||||
import android.widget.Toast | |||||
import androidx.lifecycle.ViewModelProvider | |||||
import androidx.navigation.fragment.findNavController | |||||
import com.example.acapendulum20.R | |||||
import com.example.acapendulum20.model.User | |||||
import com.example.acapendulum20.viewmodel.UserViewmodel | |||||
import kotlinx.android.synthetic.main.fragment_add.* | |||||
import kotlinx.android.synthetic.main.fragment_add.view.* | |||||
class AddFragment : Fragment() { | |||||
private lateinit var mUserViewModel: UserViewmodel | |||||
override fun onCreateView( | |||||
inflater: LayoutInflater, container: ViewGroup?, | |||||
savedInstanceState: Bundle? | |||||
): View? { | |||||
// Inflate the layout for this fragment | |||||
val view = inflater.inflate(R.layout.fragment_add, container, false) | |||||
mUserViewModel = ViewModelProvider(this).get(UserViewmodel::class.java) | |||||
view.add_btn.setOnClickListener{ | |||||
insertDataToDatabase() | |||||
} | |||||
return view | |||||
} | |||||
private fun insertDataToDatabase() { | |||||
val firstName = addFirstName_et.text.toString() | |||||
val lastName = addLastName_et.text.toString() | |||||
val age = addAge_et.text | |||||
val sex = addSex_et.text.toString() | |||||
val handiness = addHandiness_et.text.toString() | |||||
if(inputCheck(firstName, lastName, sex, handiness, age)){ | |||||
//Create User Objeect | |||||
val user = User(0, firstName, lastName,Integer.parseInt(age.toString()), sex, handiness) | |||||
//Add Data to Database | |||||
mUserViewModel.addUser(user) | |||||
Toast.makeText(requireContext(),"Successfully added!", Toast.LENGTH_LONG).show() | |||||
//Navigate Back | |||||
findNavController().navigate(R.id.action_addFragment_to_listFragment) | |||||
}else{ | |||||
Toast.makeText(requireContext(),"Please fill out all fields.", Toast.LENGTH_LONG).show() | |||||
} | |||||
} | |||||
private fun inputCheck(firstName: String, lastName: String, sex: String, handiness:String, age: Editable): Boolean{ | |||||
return !(TextUtils.isEmpty(firstName) && TextUtils.isEmpty(lastName) && TextUtils.isEmpty(sex) && TextUtils.isEmpty(handiness) && age.isEmpty()) | |||||
} | |||||
} |
@ -0,0 +1,48 @@ | |||||
package com.example.acapendulum20.fragments.list | |||||
import android.view.LayoutInflater | |||||
import android.view.View | |||||
import android.view.ViewGroup | |||||
import androidx.navigation.findNavController | |||||
import androidx.recyclerview.widget.RecyclerView | |||||
import com.example.acapendulum20.R | |||||
import com.example.acapendulum20.model.User | |||||
import kotlinx.android.synthetic.main.custom_row.view.* | |||||
class ListAdapter: RecyclerView.Adapter<ListAdapter.MyViewHolder>() { | |||||
private var userList = emptyList<User>() | |||||
class MyViewHolder(itemView: View): RecyclerView.ViewHolder(itemView) { | |||||
} | |||||
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): MyViewHolder { | |||||
return MyViewHolder(LayoutInflater.from(parent.context).inflate(R.layout.custom_row, parent, false)) | |||||
} | |||||
override fun getItemCount(): Int { | |||||
return userList.size | |||||
} | |||||
override fun onBindViewHolder(holder: MyViewHolder, position: Int) { | |||||
val currentItem = userList[position] | |||||
holder.itemView.id_txt.text = currentItem.id.toString() | |||||
holder.itemView.firstName_txt.text = currentItem.firstName | |||||
holder.itemView.lastName_txt.text = currentItem.lastName | |||||
holder.itemView.age_txt.text = currentItem.age.toString() | |||||
holder.itemView.sex_txt.text = currentItem.sex | |||||
holder.itemView.handiness_txt.text = currentItem.handiness | |||||
holder.itemView.rowLayout.setOnClickListener{ | |||||
val action = ListFragmentDirections.actionListFragmentToUpdateFragment(currentItem) | |||||
holder.itemView.findNavController().navigate(action) | |||||
} | |||||
} | |||||
fun setData(user: List<User>){ | |||||
this.userList = user | |||||
notifyDataSetChanged() | |||||
} | |||||
} |
@ -0,0 +1,77 @@ | |||||
package com.example.acapendulum20.fragments.list | |||||
import android.app.AlertDialog | |||||
import android.os.Bundle | |||||
import android.view.* | |||||
import android.widget.Toast | |||||
import androidx.fragment.app.Fragment | |||||
import androidx.lifecycle.Observer | |||||
import androidx.lifecycle.ViewModelProvider | |||||
import androidx.navigation.fragment.findNavController | |||||
import androidx.recyclerview.widget.LinearLayoutManager | |||||
import com.example.acapendulum20.R | |||||
import com.example.acapendulum20.viewmodel.UserViewmodel | |||||
import kotlinx.android.synthetic.main.fragment_list.view.* | |||||
class ListFragment : Fragment() { | |||||
private lateinit var mUserViewModel: UserViewmodel | |||||
override fun onCreateView( | |||||
inflater: LayoutInflater, container: ViewGroup?, | |||||
savedInstanceState: Bundle? | |||||
): View? { | |||||
// Inflate the layout for this fragment | |||||
val view = inflater.inflate(R.layout.fragment_list, container, false) | |||||
//Recylerview | |||||
val adapter = ListAdapter() | |||||
val recyclerView = view.recyclerview | |||||
recyclerView.adapter = adapter | |||||
recyclerView.layoutManager = LinearLayoutManager(requireContext()) | |||||
//UserViewModel | |||||
mUserViewModel = ViewModelProvider(this).get(UserViewmodel::class.java) | |||||
mUserViewModel.readAllData.observe(viewLifecycleOwner, Observer { user -> | |||||
adapter.setData(user) | |||||
}) | |||||
view.floatingActionButton.setOnClickListener { | |||||
findNavController().navigate(R.id.action_listFragment_to_addFragment) | |||||
} | |||||
// Add menu | |||||
setHasOptionsMenu(true) | |||||
return view | |||||
} | |||||
override fun onCreateOptionsMenu(menu: Menu, inflater: MenuInflater) { | |||||
inflater.inflate(R.menu.delete_menu, menu) | |||||
} | |||||
override fun onOptionsItemSelected(item: MenuItem): Boolean { | |||||
if (item.itemId == R.id.menu_delete) { | |||||
deleteAllUsers() | |||||
} | |||||
return super.onOptionsItemSelected(item) | |||||
} | |||||
private fun deleteAllUsers() { | |||||
val builder = AlertDialog.Builder(requireContext()) | |||||
builder.setPositiveButton("Yes") { _, _ -> | |||||
mUserViewModel.deleteAllUsers() | |||||
Toast.makeText( | |||||
requireContext(), | |||||
"Succesfully removed everything!", | |||||
Toast.LENGTH_SHORT | |||||
).show() | |||||
} | |||||
builder.setNegativeButton("No") { _, _ -> } | |||||
builder.setTitle("Delete everything?") | |||||
builder.setMessage("Are you sure you want to delete everything?") | |||||
builder.create().show() | |||||
} | |||||
} |
@ -0,0 +1,42 @@ | |||||
package com.example.acapendulum20.fragments.pendulum | |||||
import android.content.Context | |||||
import android.graphics.* | |||||
import android.graphics.drawable.Drawable | |||||
import android.os.Bundle | |||||
import android.util.AttributeSet | |||||
import android.view.LayoutInflater | |||||
import android.view.View | |||||
import android.view.ViewGroup | |||||
import android.widget.ImageView | |||||
import androidx.core.content.res.ResourcesCompat | |||||
import androidx.fragment.app.Fragment | |||||
import androidx.lifecycle.ViewModelProvider | |||||
import androidx.navigation.fragment.findNavController | |||||
import com.example.acapendulum20.R | |||||
import com.example.acapendulum20.canvas.CanvasView | |||||
import com.example.acapendulum20.viewmodel.UserViewmodel | |||||
import kotlinx.android.synthetic.main.fragment_pendulum.* | |||||
import kotlinx.android.synthetic.main.fragment_pendulum.view.* | |||||
import kotlinx.android.synthetic.main.fragment_update.view.* | |||||
class PendulumFragment : Fragment() { | |||||
private lateinit var mCanvasView: CanvasView | |||||
override fun onCreateView( | |||||
inflater: LayoutInflater, container: ViewGroup?, | |||||
savedInstanceState: Bundle? | |||||
): View? { | |||||
// Inflate the layout for this fragment | |||||
val view = inflater.inflate(R.layout.fragment_pendulum, container, false) | |||||
//activate the magnet | |||||
view.activate_btn.setOnClickListener{ | |||||
mCanvasView.drawBob() | |||||
} | |||||
return view | |||||
} | |||||
} |
@ -0,0 +1,103 @@ | |||||
package com.example.acapendulum20.fragments.update | |||||
import android.app.AlertDialog | |||||
import android.os.Bundle | |||||
import android.text.Editable | |||||
import android.text.TextUtils | |||||
import android.view.* | |||||
import androidx.fragment.app.Fragment | |||||
import android.widget.Toast | |||||
import androidx.lifecycle.ViewModelProvider | |||||
import androidx.navigation.fragment.findNavController | |||||
import androidx.navigation.fragment.navArgs | |||||
import com.example.acapendulum20.R | |||||
import com.example.acapendulum20.model.User | |||||
import com.example.acapendulum20.viewmodel.UserViewmodel | |||||
import kotlinx.android.synthetic.main.fragment_update.* | |||||
import kotlinx.android.synthetic.main.fragment_update.view.* | |||||
class UpdateFragment : Fragment() { | |||||
private val args by navArgs<UpdateFragmentArgs>() | |||||
private lateinit var mUserViewModel: UserViewmodel | |||||
override fun onCreateView( | |||||
inflater: LayoutInflater, container: ViewGroup?, | |||||
savedInstanceState: Bundle? | |||||
): View? { | |||||
// Inflate the layout for this fragment | |||||
val view = inflater.inflate(R.layout.fragment_update, container, false) | |||||
mUserViewModel = ViewModelProvider(this).get(UserViewmodel::class.java) | |||||
view.updateFirstName_et.setText(args.currentUser.firstName) | |||||
view.updateLastName_et.setText(args.currentUser.lastName) | |||||
view.updateAge_et.setText(args.currentUser.age.toString()) | |||||
view.updateSex_et.setText(args.currentUser.sex) | |||||
view.updateHandiness_et.setText(args.currentUser.handiness) | |||||
//navigate to fragment_pendulum | |||||
view.startTest_btn.setOnClickListener{ | |||||
findNavController().navigate(R.id.action_updateFragment_to_pendulumFragment) | |||||
} | |||||
//navigate to fragment_update | |||||
view.update_btn.setOnClickListener{ | |||||
updateItem() | |||||
} | |||||
//Add menu | |||||
setHasOptionsMenu(true) | |||||
return view | |||||
} | |||||
private fun updateItem(){ | |||||
val firstName = updateFirstName_et.text.toString() | |||||
val lastName = updateLastName_et.text.toString() | |||||
val age = Integer.parseInt(updateAge_et.text.toString()) | |||||
val sex = updateSex_et.text.toString() | |||||
val handiness = updateHandiness_et.text.toString() | |||||
if(inputCheck(firstName, lastName, sex, handiness, updateAge_et.text)){ | |||||
// Create User Object | |||||
val updatedUser = User(args.currentUser.id, firstName, lastName, age, sex, handiness) | |||||
// update current User | |||||
mUserViewModel.updateUser(updatedUser) | |||||
Toast.makeText(requireContext(), "Updated Successfully!", Toast.LENGTH_SHORT).show() | |||||
// Navigate Back | |||||
findNavController().navigate(R.id.action_updateFragment_to_listFragment) | |||||
}else{ | |||||
Toast.makeText(requireContext(), "Please fill out all fields!", Toast.LENGTH_SHORT).show() | |||||
} | |||||
} | |||||
private fun inputCheck(firstName: String, lastName: String, sex: String, handiness:String, age: Editable): Boolean{ | |||||
return !(TextUtils.isEmpty(firstName) && TextUtils.isEmpty(lastName) && TextUtils.isEmpty(sex) && TextUtils.isEmpty(handiness) && age.isEmpty()) | |||||
} | |||||
override fun onCreateOptionsMenu(menu: Menu, inflater: MenuInflater) { | |||||
inflater.inflate(R.menu.delete_menu, menu) | |||||
} | |||||
override fun onOptionsItemSelected(item: MenuItem): Boolean { | |||||
if(item.itemId == R.id.menu_delete){ | |||||
deleteUser() | |||||
} | |||||
return super.onOptionsItemSelected(item) | |||||
} | |||||
private fun deleteUser() { | |||||
val builder = AlertDialog.Builder(requireContext()) | |||||
builder.setPositiveButton("Yes") { _, _ -> | |||||
mUserViewModel.deleteUser(args.currentUser) | |||||
Toast.makeText(requireContext(), "Succesfully removed : ${args.currentUser.firstName}", Toast.LENGTH_SHORT).show() | |||||
findNavController().navigate(R.id.action_updateFragment_to_listFragment) | |||||
} | |||||
builder.setNegativeButton("No") { _, _ ->} | |||||
builder.setTitle("Delete ${args.currentUser.firstName}?") | |||||
builder.setMessage("Are you sure you want to delete ${args.currentUser.firstName}?") | |||||
builder.create().show() | |||||
} | |||||
} |
@ -0,0 +1,19 @@ | |||||
package com.example.acapendulum20.model | |||||
import android.os.Parcelable | |||||
import androidx.room.Entity | |||||
import androidx.room.PrimaryKey | |||||
import kotlinx.android.parcel.Parcelize | |||||
@Parcelize | |||||
@Entity(tableName = "user_table") | |||||
data class User ( | |||||
@PrimaryKey(autoGenerate = true) | |||||
val id: Int, | |||||
val firstName: String, | |||||
val lastName: String, | |||||
val age: Int, | |||||
val sex: String, | |||||
val handiness: String, | |||||
): Parcelable |
@ -0,0 +1,26 @@ | |||||
package com.example.acapendulum20.repository | |||||
import androidx.lifecycle.LiveData | |||||
import com.example.acapendulum20.data.UserDao | |||||
import com.example.acapendulum20.model.User | |||||
class UserRepository(private val userDao: UserDao) { | |||||
val readAllData: LiveData<List<User>> = userDao.readAllData() | |||||
suspend fun addUser(user: User){ | |||||
userDao.addUser(user) | |||||
} | |||||
suspend fun updateUser(user: User){ | |||||
userDao.updateUser(user) | |||||
} | |||||
suspend fun deleteUser(user: User){ | |||||
userDao.deleteUser(user) | |||||
} | |||||
suspend fun deleteAllUser(){ | |||||
userDao.deleteAllUsers() | |||||
} | |||||
} |
@ -0,0 +1,47 @@ | |||||
package com.example.acapendulum20.viewmodel | |||||
import android.app.Application | |||||
import androidx.lifecycle.AndroidViewModel | |||||
import androidx.lifecycle.LiveData | |||||
import androidx.lifecycle.viewModelScope | |||||
import com.example.acapendulum20.data.UserDatabase | |||||
import com.example.acapendulum20.repository.UserRepository | |||||
import com.example.acapendulum20.model.User | |||||
import kotlinx.coroutines.Dispatchers | |||||
import kotlinx.coroutines.launch | |||||
class UserViewmodel(application: Application): AndroidViewModel(application) { | |||||
val readAllData: LiveData<List<User>> | |||||
private val repository: UserRepository | |||||
init{ | |||||
val userDao = UserDatabase.getDatabase(application).userDao() | |||||
repository = UserRepository(userDao) | |||||
readAllData = repository.readAllData | |||||
} | |||||
fun addUser(user: User){ | |||||
viewModelScope.launch(Dispatchers.IO){ | |||||
repository.addUser(user) | |||||
} | |||||
} | |||||
fun updateUser(user: User){ | |||||
viewModelScope.launch(Dispatchers.IO) { | |||||
repository.updateUser(user) | |||||
} | |||||
} | |||||
fun deleteUser(user: User){ | |||||
viewModelScope.launch(Dispatchers.IO) { | |||||
repository.deleteUser(user) | |||||
} | |||||
} | |||||
fun deleteAllUsers(){ | |||||
viewModelScope.launch(Dispatchers.IO) { | |||||
repository.deleteAllUser() | |||||
} | |||||
} | |||||
} |
@ -0,0 +1,30 @@ | |||||
<vector xmlns:android="http://schemas.android.com/apk/res/android" | |||||
xmlns:aapt="http://schemas.android.com/aapt" | |||||
android:width="108dp" | |||||
android:height="108dp" | |||||
android:viewportWidth="108" | |||||
android:viewportHeight="108"> | |||||
<path android:pathData="M31,63.928c0,0 6.4,-11 12.1,-13.1c7.2,-2.6 26,-1.4 26,-1.4l38.1,38.1L107,108.928l-32,-1L31,63.928z"> | |||||
<aapt:attr name="android:fillColor"> | |||||
<gradient | |||||
android:endX="85.84757" | |||||
android:endY="92.4963" | |||||
android:startX="42.9492" | |||||
android:startY="49.59793" | |||||
android:type="linear"> | |||||
<item | |||||
android:color="#44000000" | |||||
android:offset="0.0" /> | |||||
<item | |||||
android:color="#00000000" | |||||
android:offset="1.0" /> | |||||
</gradient> | |||||
</aapt:attr> | |||||
</path> | |||||
<path | |||||
android:fillColor="#FFFFFF" | |||||
android:fillType="nonZero" | |||||
android:pathData="M65.3,45.828l3.8,-6.6c0.2,-0.4 0.1,-0.9 -0.3,-1.1c-0.4,-0.2 -0.9,-0.1 -1.1,0.3l-3.9,6.7c-6.3,-2.8 -13.4,-2.8 -19.7,0l-3.9,-6.7c-0.2,-0.4 -0.7,-0.5 -1.1,-0.3C38.8,38.328 38.7,38.828 38.9,39.228l3.8,6.6C36.2,49.428 31.7,56.028 31,63.928h46C76.3,56.028 71.8,49.428 65.3,45.828zM43.4,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2c-0.3,-0.7 -0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C45.3,56.528 44.5,57.328 43.4,57.328L43.4,57.328zM64.6,57.328c-0.8,0 -1.5,-0.5 -1.8,-1.2s-0.1,-1.5 0.4,-2.1c0.5,-0.5 1.4,-0.7 2.1,-0.4c0.7,0.3 1.2,1 1.2,1.8C66.5,56.528 65.6,57.328 64.6,57.328L64.6,57.328z" | |||||
android:strokeWidth="1" | |||||
android:strokeColor="#00000000" /> | |||||
</vector> |
@ -0,0 +1,10 @@ | |||||
<vector xmlns:android="http://schemas.android.com/apk/res/android" | |||||
android:width="24dp" | |||||
android:height="24dp" | |||||
android:viewportWidth="24" | |||||
android:viewportHeight="24" | |||||
android:tint="?attr/colorControlNormal"> | |||||
<path | |||||
android:fillColor="@android:color/white" | |||||
android:pathData="M19,13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z"/> | |||||
</vector> |
@ -0,0 +1,10 @@ | |||||
<vector xmlns:android="http://schemas.android.com/apk/res/android" | |||||
android:width="24dp" | |||||
android:height="24dp" | |||||
android:viewportWidth="24" | |||||
android:viewportHeight="24" | |||||
android:tint="?attr/colorControlNormal"> | |||||
<path | |||||
android:fillColor="@android:color/white" | |||||
android:pathData="M6,19c0,1.1 0.9,2 2,2h8c1.1,0 2,-0.9 2,-2V7H6v12zM19,4h-3.5l-1,-1h-5l-1,1H5v2h14V4z"/> | |||||
</vector> |
@ -0,0 +1,170 @@ | |||||
<?xml version="1.0" encoding="utf-8"?> | |||||
<vector xmlns:android="http://schemas.android.com/apk/res/android" | |||||
android:width="108dp" | |||||
android:height="108dp" | |||||
android:viewportWidth="108" | |||||
android:viewportHeight="108"> | |||||
<path | |||||
android:fillColor="#3DDC84" | |||||
android:pathData="M0,0h108v108h-108z" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M9,0L9,108" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M19,0L19,108" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M29,0L29,108" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M39,0L39,108" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M49,0L49,108" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M59,0L59,108" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M69,0L69,108" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M79,0L79,108" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M89,0L89,108" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M99,0L99,108" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M0,9L108,9" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M0,19L108,19" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M0,29L108,29" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M0,39L108,39" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M0,49L108,49" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M0,59L108,59" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M0,69L108,69" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M0,79L108,79" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M0,89L108,89" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M0,99L108,99" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M19,29L89,29" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M19,39L89,39" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M19,49L89,49" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M19,59L89,59" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M19,69L89,69" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M19,79L89,79" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M29,19L29,89" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M39,19L39,89" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M49,19L49,89" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M59,19L59,89" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M69,19L69,89" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
<path | |||||
android:fillColor="#00000000" | |||||
android:pathData="M79,19L79,89" | |||||
android:strokeWidth="0.8" | |||||
android:strokeColor="#33FFFFFF" /> | |||||
</vector> |
@ -0,0 +1,21 @@ | |||||
<?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=".MainActivity"> | |||||
<fragment | |||||
android:id="@+id/fragment" | |||||
android:name="androidx.navigation.fragment.NavHostFragment" | |||||
android:layout_width="409dp" | |||||
android:layout_height="729dp" | |||||
app:defaultNavHost="true" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintHorizontal_bias="0.5" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toTopOf="parent" | |||||
app:navGraph="@navigation/my_nav" /> | |||||
</androidx.constraintlayout.widget.ConstraintLayout> |
@ -0,0 +1,77 @@ | |||||
<?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="wrap_content" | |||||
android:padding="24sp" | |||||
android:id="@+id/rowLayout"> | |||||
<TextView | |||||
android:id="@+id/id_txt" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:text="1" | |||||
android:textSize="20sp" | |||||
android:textStyle="bold" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toTopOf="parent" /> | |||||
<TextView | |||||
android:id="@+id/firstName_txt" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginStart="15dp" | |||||
android:text="Max" | |||||
android:textSize="18sp" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintStart_toEndOf="@+id/id_txt" | |||||
app:layout_constraintTop_toTopOf="parent" /> | |||||
<TextView | |||||
android:id="@+id/lastName_txt" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginStart="6dp" | |||||
android:text="Mustermann" | |||||
android:textSize="18sp" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintStart_toEndOf="@+id/firstName_txt" | |||||
app:layout_constraintTop_toTopOf="parent" /> | |||||
<TextView | |||||
android:id="@+id/age_txt" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginStart="6dp" | |||||
android:text="(30)" | |||||
android:textSize="18sp" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintStart_toEndOf="@+id/lastName_txt" | |||||
app:layout_constraintTop_toTopOf="parent" /> | |||||
<TextView | |||||
android:id="@+id/sex_txt" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginStart="6dp" | |||||
android:text="Male" | |||||
android:textSize="18sp" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintStart_toEndOf="@+id/age_txt" | |||||
app:layout_constraintTop_toTopOf="parent" /> | |||||
<TextView | |||||
android:id="@+id/handiness_txt" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginStart="6dp" | |||||
android:text="right" | |||||
android:textSize="18sp" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintStart_toEndOf="@+id/sex_txt" | |||||
app:layout_constraintTop_toTopOf="parent" /> | |||||
</androidx.constraintlayout.widget.ConstraintLayout> |
@ -0,0 +1,79 @@ | |||||
<?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" | |||||
android:padding="40dp" | |||||
tools:context=".fragments.add.AddFragment"> | |||||
<EditText | |||||
android:id="@+id/addFirstName_et" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:ems="10" | |||||
android:inputType="textPersonName" | |||||
android:hint="First Name" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toTopOf="parent" /> | |||||
<EditText | |||||
android:id="@+id/addLastName_et" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginTop="16dp" | |||||
android:ems="10" | |||||
android:inputType="textPersonName" | |||||
android:hint="Last Name" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toBottomOf="@+id/addFirstName_et" /> | |||||
<EditText | |||||
android:id="@+id/addAge_et" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginTop="16dp" | |||||
android:ems="10" | |||||
android:inputType="number" | |||||
android:hint="Age" | |||||
app:layout_constraintTop_toBottomOf="@+id/addLastName_et" | |||||
tools:layout_editor_absoluteX="100dp" /> | |||||
<EditText | |||||
android:id="@+id/addSex_et" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginTop="16dp" | |||||
android:ems="10" | |||||
android:inputType="textPersonName" | |||||
android:hint="Sex" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toBottomOf="@+id/addAge_et" /> | |||||
<EditText | |||||
android:id="@+id/addHandiness_et" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginTop="16dp" | |||||
android:ems="10" | |||||
android:inputType="textPersonName" | |||||
android:hint="Handiness" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toBottomOf="@+id/addSex_et" /> | |||||
<Button | |||||
android:id="@+id/add_btn" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginTop="24dp" | |||||
android:text="Add" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toBottomOf="@+id/addHandiness_et" /> | |||||
</androidx.constraintlayout.widget.ConstraintLayout> |
@ -0,0 +1,34 @@ | |||||
<?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=".fragments.list.ListFragment" | |||||
android:padding="24sp"> | |||||
<androidx.recyclerview.widget.RecyclerView | |||||
android:id="@+id/recyclerview" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="match_parent" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintHorizontal_bias="0.5" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toTopOf="parent" /> | |||||
<com.google.android.material.floatingactionbutton.FloatingActionButton | |||||
android:id="@+id/floatingActionButton" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginEnd="24dp" | |||||
android:layout_marginBottom="24dp" | |||||
android:clickable="true" | |||||
android:focusable="true" | |||||
android:tint="@android:color/white" | |||||
android:src="@drawable/ic_add" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintEnd_toEndOf="parent" /> | |||||
</androidx.constraintlayout.widget.ConstraintLayout> |
@ -0,0 +1,112 @@ | |||||
<?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" | |||||
android:padding="24dp" | |||||
tools:context=".fragments.pendulum.PendulumFragment"> | |||||
<TextView | |||||
android:id="@+id/textView4" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginBottom="20dp" | |||||
android:text="TextView" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" /> | |||||
<TextView | |||||
android:id="@+id/textView5" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginBottom="20dp" | |||||
android:text="TextView" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintStart_toEndOf="@+id/textView4" /> | |||||
<TextView | |||||
android:id="@+id/textView6" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginBottom="20dp" | |||||
android:text="TextView" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintStart_toEndOf="@+id/textView5" /> | |||||
<TextView | |||||
android:id="@+id/textView7" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginBottom="20dp" | |||||
android:text="TextView" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintStart_toEndOf="@+id/textView6" /> | |||||
<TextView | |||||
android:id="@+id/textView8" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:text="TextView" | |||||
app:layout_constraintBottom_toTopOf="@+id/textView4" | |||||
app:layout_constraintStart_toStartOf="parent" /> | |||||
<TextView | |||||
android:id="@+id/textView9" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:text="TextView" | |||||
app:layout_constraintBottom_toTopOf="@+id/textView5" | |||||
app:layout_constraintStart_toEndOf="@+id/textView8" /> | |||||
<view | |||||
class="com.example.acapendulum20.canvas.CanvasView" | |||||
android:layout_width="347dp" | |||||
android:layout_height="440dp" | |||||
app:layout_constraintBottom_toTopOf="@+id/activate_btn" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toTopOf="parent" | |||||
app:layout_constraintVertical_bias="0.139" /> | |||||
<TextView | |||||
android:id="@+id/textView10" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:text="TextView" | |||||
app:layout_constraintBottom_toTopOf="@+id/textView6" | |||||
app:layout_constraintStart_toEndOf="@+id/textView9" /> | |||||
<TextView | |||||
android:id="@+id/textView11" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:text="TextView" | |||||
app:layout_constraintBottom_toTopOf="@+id/textView7" | |||||
app:layout_constraintStart_toEndOf="@+id/textView10" /> | |||||
<Button | |||||
android:id="@+id/speichern_btn" | |||||
android:layout_width="wrap_content" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginBottom="18dp" | |||||
android:text="Speichern" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toEndOf="@+id/textView11" /> | |||||
<Button | |||||
android:id="@+id/activate_btn" | |||||
android:layout_width="109dp" | |||||
android:layout_height="86dp" | |||||
android:text="Activate" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintHorizontal_bias="0.506" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toTopOf="parent" | |||||
app:layout_constraintVertical_bias="0.77" /> | |||||
</androidx.constraintlayout.widget.ConstraintLayout> |
@ -0,0 +1,98 @@ | |||||
<?xml version="1.0" encoding="utf-8"?> | |||||
<androidx.constraintlayout.widget.ConstraintLayout | |||||
xmlns:android="http://schemas.android.com/apk/res/android" | |||||
xmlns:tools="http://schemas.android.com/tools" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="match_parent" | |||||
xmlns:app="http://schemas.android.com/apk/res-auto" | |||||
tools:context=".fragments.update.UpdateFragment" | |||||
android:padding="24dp"> | |||||
<EditText | |||||
android:id="@+id/updateFirstName_et" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:ems="10" | |||||
android:inputType="textPersonName" | |||||
android:hint="First Name" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toTopOf="parent" /> | |||||
<EditText | |||||
android:id="@+id/updateLastName_et" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginTop="16dp" | |||||
android:ems="10" | |||||
android:inputType="textPersonName" | |||||
android:hint="Last Name" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toBottomOf="@+id/updateFirstName_et" /> | |||||
<EditText | |||||
android:id="@+id/updateAge_et" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginTop="16dp" | |||||
android:ems="10" | |||||
android:inputType="number" | |||||
android:hint="Age" | |||||
app:layout_constraintTop_toBottomOf="@+id/updateLastName_et" | |||||
tools:layout_editor_absoluteX="100dp" /> | |||||
<EditText | |||||
android:id="@+id/updateSex_et" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginTop="16dp" | |||||
android:ems="10" | |||||
android:inputType="textPersonName" | |||||
android:hint="Sex" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toBottomOf="@+id/updateAge_et" /> | |||||
<EditText | |||||
android:id="@+id/updateHandiness_et" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginTop="16dp" | |||||
android:ems="10" | |||||
android:inputType="textPersonName" | |||||
android:hint="Handiness" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toBottomOf="@+id/updateSex_et" /> | |||||
<Button | |||||
android:id="@+id/update_btn" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:layout_marginTop="24dp" | |||||
android:text="Update" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toBottomOf="@+id/updateHandiness_et" /> | |||||
<Button | |||||
android:id="@+id/startTest_btn" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
android:text="Start Test" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toBottomOf="@+id/update_btn" /> | |||||
<androidx.recyclerview.widget.RecyclerView | |||||
android:id="@+id/testResultRecyclerview" | |||||
android:layout_width="match_parent" | |||||
android:layout_height="wrap_content" | |||||
app:layout_constraintBottom_toBottomOf="parent" | |||||
app:layout_constraintEnd_toEndOf="parent" | |||||
app:layout_constraintStart_toStartOf="parent" | |||||
app:layout_constraintTop_toBottomOf="@+id/startTest_btn" | |||||
app:layout_constraintVertical_bias="0.292" /> | |||||
</androidx.constraintlayout.widget.ConstraintLayout> |
@ -0,0 +1,11 @@ | |||||
<?xml version="1.0" encoding="utf-8"?> | |||||
<menu xmlns:android="http://schemas.android.com/apk/res/android" | |||||
xmlns:app="http://schemas.android.com/apk/res-auto"> | |||||
<item android:id="@+id/menu_delete" | |||||
android:title="Delete" | |||||
android:icon="@drawable/ic_baseline_delete_24" | |||||
android:iconTint="@color/white" | |||||
app:showAsAction="ifRoom"/> | |||||
</menu> |
@ -0,0 +1,5 @@ | |||||
<?xml version="1.0" encoding="utf-8"?> | |||||
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android"> | |||||
<background android:drawable="@drawable/ic_launcher_background" /> | |||||
<foreground android:drawable="@drawable/ic_launcher_foreground" /> | |||||
</adaptive-icon> |
@ -0,0 +1,5 @@ | |||||
<?xml version="1.0" encoding="utf-8"?> | |||||
<adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android"> | |||||
<background android:drawable="@drawable/ic_launcher_background" /> | |||||
<foreground android:drawable="@drawable/ic_launcher_foreground" /> | |||||
</adaptive-icon> |
@ -0,0 +1,53 @@ | |||||
<?xml version="1.0" encoding="utf-8"?> | |||||
<navigation 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:id="@+id/my_nav" | |||||
app:startDestination="@id/listFragment"> | |||||
<fragment | |||||
android:id="@+id/listFragment" | |||||
android:name="com.example.acapendulum20.fragments.list.ListFragment" | |||||
android:label="List" | |||||
tools:layout="@layout/fragment_list" > | |||||
<action | |||||
android:id="@+id/action_listFragment_to_addFragment" | |||||
app:destination="@id/addFragment" /> | |||||
<action | |||||
android:id="@+id/action_listFragment_to_updateFragment" | |||||
app:destination="@id/updateFragment" /> | |||||
</fragment> | |||||
<fragment | |||||
android:id="@+id/addFragment" | |||||
android:name="com.example.acapendulum20.fragments.add.AddFragment" | |||||
android:label="Add" | |||||
tools:layout="@layout/fragment_add" > | |||||
<action | |||||
android:id="@+id/action_addFragment_to_listFragment" | |||||
app:destination="@id/listFragment" /> | |||||
</fragment> | |||||
<fragment | |||||
android:id="@+id/updateFragment" | |||||
android:name="com.example.acapendulum20.fragments.update.UpdateFragment" | |||||
android:label="Update" | |||||
tools:layout="@layout/fragment_update" > | |||||
<action | |||||
android:id="@+id/action_updateFragment_to_listFragment" | |||||
app:destination="@id/listFragment" /> | |||||
<argument | |||||
android:name="currentUser" | |||||
app:argType="com.example.acapendulum20.model.User" /> | |||||
<action | |||||
android:id="@+id/action_updateFragment_to_pendulumFragment" | |||||
app:destination="@id/pendulumFragment" /> | |||||
</fragment> | |||||
<fragment | |||||
android:id="@+id/pendulumFragment" | |||||
android:name="com.example.acapendulum20.fragments.pendulum.PendulumFragment" | |||||
android:label="fragment_pendulum" | |||||
tools:layout="@layout/fragment_pendulum" > | |||||
<action | |||||
android:id="@+id/action_pendulumFragment_to_updateFragment" | |||||
app:destination="@id/updateFragment" /> | |||||
</fragment> | |||||
</navigation> |
@ -0,0 +1,16 @@ | |||||
<resources xmlns:tools="http://schemas.android.com/tools"> | |||||
<!-- Base application theme. --> | |||||
<style name="Theme.AcaPendulum20" parent="Theme.MaterialComponents.DayNight.DarkActionBar"> | |||||
<!-- Primary brand color. --> | |||||
<item name="colorPrimary">@color/purple_200</item> | |||||
<item name="colorPrimaryVariant">@color/purple_700</item> | |||||
<item name="colorOnPrimary">@color/black</item> | |||||
<!-- Secondary brand color. --> | |||||
<item name="colorSecondary">@color/teal_200</item> | |||||
<item name="colorSecondaryVariant">@color/teal_200</item> | |||||
<item name="colorOnSecondary">@color/black</item> | |||||
<!-- Status bar color. --> | |||||
<item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item> | |||||
<!-- Customize your theme here. --> | |||||
</style> | |||||
</resources> |
@ -0,0 +1,10 @@ | |||||
<?xml version="1.0" encoding="utf-8"?> | |||||
<resources> | |||||
<color name="purple_200">#FFBB86FC</color> | |||||
<color name="purple_500">#FF6200EE</color> | |||||
<color name="purple_700">#FF3700B3</color> | |||||
<color name="teal_200">#FF03DAC5</color> | |||||
<color name="teal_700">#FF018786</color> | |||||
<color name="black">#FF000000</color> | |||||
<color name="white">#FFFFFFFF</color> | |||||
</resources> |
@ -0,0 +1,6 @@ | |||||
<resources> | |||||
<string name="app_name">acaPendulum2.0</string> | |||||
<!-- TODO: Remove or change this placeholder text --> | |||||
<string name="hello_blank_fragment">Hello blank fragment</string> | |||||
<string name="textview">TextView</string> | |||||
</resources> |
@ -0,0 +1,16 @@ | |||||
<resources xmlns:tools="http://schemas.android.com/tools"> | |||||
<!-- Base application theme. --> | |||||
<style name="Theme.AcaPendulum20" parent="Theme.MaterialComponents.DayNight.DarkActionBar"> | |||||
<!-- Primary brand color. --> | |||||
<item name="colorPrimary">@color/purple_500</item> | |||||
<item name="colorPrimaryVariant">@color/purple_700</item> | |||||
<item name="colorOnPrimary">@color/white</item> | |||||
<!-- Secondary brand color. --> | |||||
<item name="colorSecondary">@color/teal_200</item> | |||||
<item name="colorSecondaryVariant">@color/teal_700</item> | |||||
<item name="colorOnSecondary">@color/black</item> | |||||
<!-- Status bar color. --> | |||||
<item name="android:statusBarColor" tools:targetApi="l">?attr/colorPrimaryVariant</item> | |||||
<!-- Customize your theme here. --> | |||||
</style> | |||||
</resources> |
@ -0,0 +1,17 @@ | |||||
package com.example.acapendulum20 | |||||
import org.junit.Test | |||||
import org.junit.Assert.* | |||||
/** | |||||
* Example local unit test, which will execute on the development machine (host). | |||||
* | |||||
* See [testing documentation](http://d.android.com/tools/testing). | |||||
*/ | |||||
class ExampleUnitTest { | |||||
@Test | |||||
fun addition_isCorrect() { | |||||
assertEquals(4, 2 + 2) | |||||
} | |||||
} |
@ -0,0 +1,21 @@ | |||||
// Top-level build file where you can add configuration options common to all sub-projects/modules. | |||||
buildscript { | |||||
repositories { | |||||
google() | |||||
} | |||||
dependencies { | |||||
classpath("androidx.navigation:navigation-safe-args-gradle-plugin:2.4.2") | |||||
} | |||||
} | |||||
plugins { | |||||
id 'com.android.application' version '7.1.3' apply false | |||||
id 'com.android.library' version '7.1.3' apply false | |||||
id 'org.jetbrains.kotlin.android' version '1.6.21' apply false | |||||
} | |||||
task clean(type: Delete) { | |||||
delete rootProject.buildDir | |||||
} | |||||
@ -0,0 +1,23 @@ | |||||
# Project-wide Gradle settings. | |||||
# IDE (e.g. Android Studio) users: | |||||
# Gradle settings configured through the IDE *will override* | |||||
# any settings specified in this file. | |||||
# For more details on how to configure your build environment visit | |||||
# http://www.gradle.org/docs/current/userguide/build_environment.html | |||||
# Specifies the JVM arguments used for the daemon process. | |||||
# The setting is particularly useful for tweaking memory settings. | |||||
org.gradle.jvmargs=-Xmx2048m -Dfile.encoding=UTF-8 | |||||
# When configured, Gradle will run in incubating parallel mode. | |||||
# This option should only be used with decoupled projects. More details, visit | |||||
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects | |||||
# org.gradle.parallel=true | |||||
# AndroidX package structure to make it clearer which packages are bundled with the | |||||
# Android operating system, and which are packaged with your app"s APK | |||||
# https://developer.android.com/topic/libraries/support-library/androidx-rn | |||||
android.useAndroidX=true | |||||
# Kotlin code style for this project: "official" or "obsolete": | |||||
kotlin.code.style=official | |||||
# Enables namespacing of each library's R class so that its R class includes only the | |||||
# resources declared in the library itself and none from the library's dependencies, | |||||
# thereby reducing the size of the R class for that library | |||||
android.nonTransitiveRClass=true |
@ -0,0 +1,6 @@ | |||||
#Tue Apr 19 09:09:32 CEST 2022 | |||||
distributionBase=GRADLE_USER_HOME | |||||
distributionUrl=https\://services.gradle.org/distributions/gradle-7.2-bin.zip | |||||
distributionPath=wrapper/dists | |||||
zipStorePath=wrapper/dists | |||||
zipStoreBase=GRADLE_USER_HOME |
@ -0,0 +1,185 @@ | |||||
#!/usr/bin/env sh | |||||
# | |||||
# Copyright 2015 the original author or authors. | |||||
# | |||||
# Licensed under the Apache License, Version 2.0 (the "License"); | |||||
# you may not use this file except in compliance with the License. | |||||
# You may obtain a copy of the License at | |||||
# | |||||
# https://www.apache.org/licenses/LICENSE-2.0 | |||||
# | |||||
# Unless required by applicable law or agreed to in writing, software | |||||
# distributed under the License is distributed on an "AS IS" BASIS, | |||||
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |||||
# See the License for the specific language governing permissions and | |||||
# limitations under the License. | |||||
# | |||||
############################################################################## | |||||
## | |||||
## Gradle start up script for UN*X | |||||
## | |||||
############################################################################## | |||||
# Attempt to set APP_HOME | |||||
# Resolve links: $0 may be a link | |||||
PRG="$0" | |||||
# Need this for relative symlinks. | |||||
while [ -h "$PRG" ] ; do | |||||
ls=`ls -ld "$PRG"` | |||||
link=`expr "$ls" : '.*-> \(.*\)$'` | |||||
if expr "$link" : '/.*' > /dev/null; then | |||||
PRG="$link" | |||||
else | |||||
PRG=`dirname "$PRG"`"/$link" | |||||
fi | |||||
done | |||||
SAVED="`pwd`" | |||||
cd "`dirname \"$PRG\"`/" >/dev/null | |||||
APP_HOME="`pwd -P`" | |||||
cd "$SAVED" >/dev/null | |||||
APP_NAME="Gradle" | |||||
APP_BASE_NAME=`basename "$0"` | |||||
# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | |||||
DEFAULT_JVM_OPTS='"-Xmx64m" "-Xms64m"' | |||||
# Use the maximum available, or set MAX_FD != -1 to use that value. | |||||
MAX_FD="maximum" | |||||
warn () { | |||||
echo "$*" | |||||
} | |||||
die () { | |||||
echo | |||||
echo "$*" | |||||
echo | |||||
exit 1 | |||||
} | |||||
# OS specific support (must be 'true' or 'false'). | |||||
cygwin=false | |||||
msys=false | |||||
darwin=false | |||||
nonstop=false | |||||
case "`uname`" in | |||||
CYGWIN* ) | |||||
cygwin=true | |||||
;; | |||||
Darwin* ) | |||||
darwin=true | |||||
;; | |||||
MINGW* ) | |||||
msys=true | |||||
;; | |||||
NONSTOP* ) | |||||
nonstop=true | |||||
;; | |||||
esac | |||||
CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar | |||||
# Determine the Java command to use to start the JVM. | |||||
if [ -n "$JAVA_HOME" ] ; then | |||||
if [ -x "$JAVA_HOME/jre/sh/java" ] ; then | |||||
# IBM's JDK on AIX uses strange locations for the executables | |||||
JAVACMD="$JAVA_HOME/jre/sh/java" | |||||
else | |||||
JAVACMD="$JAVA_HOME/bin/java" | |||||
fi | |||||
if [ ! -x "$JAVACMD" ] ; then | |||||
die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME | |||||
Please set the JAVA_HOME variable in your environment to match the | |||||
location of your Java installation." | |||||
fi | |||||
else | |||||
JAVACMD="java" | |||||
which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | |||||
Please set the JAVA_HOME variable in your environment to match the | |||||
location of your Java installation." | |||||
fi | |||||
# Increase the maximum file descriptors if we can. | |||||
if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then | |||||
MAX_FD_LIMIT=`ulimit -H -n` | |||||
if [ $? -eq 0 ] ; then | |||||
if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then | |||||
MAX_FD="$MAX_FD_LIMIT" | |||||
fi | |||||
ulimit -n $MAX_FD | |||||
if [ $? -ne 0 ] ; then | |||||
warn "Could not set maximum file descriptor limit: $MAX_FD" | |||||
fi | |||||
else | |||||
warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" | |||||
fi | |||||
fi | |||||
# For Darwin, add options to specify how the application appears in the dock | |||||
if $darwin; then | |||||
GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" | |||||
fi | |||||
# For Cygwin or MSYS, switch paths to Windows format before running java | |||||
if [ "$cygwin" = "true" -o "$msys" = "true" ] ; then | |||||
APP_HOME=`cygpath --path --mixed "$APP_HOME"` | |||||
CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` | |||||
JAVACMD=`cygpath --unix "$JAVACMD"` | |||||
# We build the pattern for arguments to be converted via cygpath | |||||
ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` | |||||
SEP="" | |||||
for dir in $ROOTDIRSRAW ; do | |||||
ROOTDIRS="$ROOTDIRS$SEP$dir" | |||||
SEP="|" | |||||
done | |||||
OURCYGPATTERN="(^($ROOTDIRS))" | |||||
# Add a user-defined pattern to the cygpath arguments | |||||
if [ "$GRADLE_CYGPATTERN" != "" ] ; then | |||||
OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" | |||||
fi | |||||
# Now convert the arguments - kludge to limit ourselves to /bin/sh | |||||
i=0 | |||||
for arg in "$@" ; do | |||||
CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` | |||||
CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option | |||||
if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition | |||||
eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` | |||||
else | |||||
eval `echo args$i`="\"$arg\"" | |||||
fi | |||||
i=`expr $i + 1` | |||||
done | |||||
case $i in | |||||
0) set -- ;; | |||||
1) set -- "$args0" ;; | |||||
2) set -- "$args0" "$args1" ;; | |||||
3) set -- "$args0" "$args1" "$args2" ;; | |||||
4) set -- "$args0" "$args1" "$args2" "$args3" ;; | |||||
5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; | |||||
6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; | |||||
7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; | |||||
8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; | |||||
9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; | |||||
esac | |||||
fi | |||||
# Escape application args | |||||
save () { | |||||
for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done | |||||
echo " " | |||||
} | |||||
APP_ARGS=`save "$@"` | |||||
# Collect all arguments for the java command, following the shell quoting and substitution rules | |||||
eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" | |||||
exec "$JAVACMD" "$@" |
@ -0,0 +1,89 @@ | |||||
@rem | |||||
@rem Copyright 2015 the original author or authors. | |||||
@rem | |||||
@rem Licensed under the Apache License, Version 2.0 (the "License"); | |||||
@rem you may not use this file except in compliance with the License. | |||||
@rem You may obtain a copy of the License at | |||||
@rem | |||||
@rem https://www.apache.org/licenses/LICENSE-2.0 | |||||
@rem | |||||
@rem Unless required by applicable law or agreed to in writing, software | |||||
@rem distributed under the License is distributed on an "AS IS" BASIS, | |||||
@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | |||||
@rem See the License for the specific language governing permissions and | |||||
@rem limitations under the License. | |||||
@rem | |||||
@if "%DEBUG%" == "" @echo off | |||||
@rem ########################################################################## | |||||
@rem | |||||
@rem Gradle startup script for Windows | |||||
@rem | |||||
@rem ########################################################################## | |||||
@rem Set local scope for the variables with windows NT shell | |||||
if "%OS%"=="Windows_NT" setlocal | |||||
set DIRNAME=%~dp0 | |||||
if "%DIRNAME%" == "" set DIRNAME=. | |||||
set APP_BASE_NAME=%~n0 | |||||
set APP_HOME=%DIRNAME% | |||||
@rem Resolve any "." and ".." in APP_HOME to make it shorter. | |||||
for %%i in ("%APP_HOME%") do set APP_HOME=%%~fi | |||||
@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. | |||||
set DEFAULT_JVM_OPTS="-Xmx64m" "-Xms64m" | |||||
@rem Find java.exe | |||||
if defined JAVA_HOME goto findJavaFromJavaHome | |||||
set JAVA_EXE=java.exe | |||||
%JAVA_EXE% -version >NUL 2>&1 | |||||
if "%ERRORLEVEL%" == "0" goto execute | |||||
echo. | |||||
echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. | |||||
echo. | |||||
echo Please set the JAVA_HOME variable in your environment to match the | |||||
echo location of your Java installation. | |||||
goto fail | |||||
:findJavaFromJavaHome | |||||
set JAVA_HOME=%JAVA_HOME:"=% | |||||
set JAVA_EXE=%JAVA_HOME%/bin/java.exe | |||||
if exist "%JAVA_EXE%" goto execute | |||||
echo. | |||||
echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% | |||||
echo. | |||||
echo Please set the JAVA_HOME variable in your environment to match the | |||||
echo location of your Java installation. | |||||
goto fail | |||||
:execute | |||||
@rem Setup the command line | |||||
set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar | |||||
@rem Execute Gradle | |||||
"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %* | |||||
:end | |||||
@rem End local scope for the variables with windows NT shell | |||||
if "%ERRORLEVEL%"=="0" goto mainEnd | |||||
:fail | |||||
rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of | |||||
rem the _cmd.exe /c_ return code! | |||||
if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 | |||||
exit /b 1 | |||||
:mainEnd | |||||
if "%OS%"=="Windows_NT" endlocal | |||||
:omega |
@ -0,0 +1,16 @@ | |||||
pluginManagement { | |||||
repositories { | |||||
gradlePluginPortal() | |||||
google() | |||||
mavenCentral() | |||||
} | |||||
} | |||||
dependencyResolutionManagement { | |||||
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS) | |||||
repositories { | |||||
google() | |||||
mavenCentral() | |||||
} | |||||
} | |||||
rootProject.name = "acaPendulum2.0" | |||||
include ':app' |