diff --git a/.envrc b/.envrc
deleted file mode 100644
index 8f390c3..0000000
--- a/.envrc
+++ /dev/null
@@ -1 +0,0 @@
-use_flake
\ No newline at end of file
diff --git a/.github/workflows/android.yml b/.github/workflows/android.yml
new file mode 100644
index 0000000..984a7ce
--- /dev/null
+++ b/.github/workflows/android.yml
@@ -0,0 +1,26 @@
+name: Android CI
+
+on:
+ push:
+ branches: [ app_dev ]
+ pull_request:
+ branches: [ app_dev ]
+
+jobs:
+ build:
+
+ runs-on: ubuntu-latest
+
+ steps:
+ - uses: actions/checkout@v2
+ - name: set up JDK 11
+ uses: actions/setup-java@v2
+ with:
+ java-version: '11'
+ distribution: 'temurin'
+ cache: gradle
+
+ - name: Grant execute permission for gradlew
+ run: chmod +x ./ClimateGoApp/gradlew
+ - name: Build with Gradle
+ run: cd ClimateGoApp && ./gradlew build
diff --git a/.gitignore b/.gitignore
index 91555ba..fb2a675 100644
--- a/.gitignore
+++ b/.gitignore
@@ -444,4 +444,6 @@ obj/
# End of https://www.toptal.com/developers/gitignore/api/platformio,c,cmake,c++,intellij,android,androidstudio,clion+all,java
-.direnv
\ No newline at end of file
+
+### only on app_dev
+firmware/
diff --git a/.vscode/settings.json b/.vscode/settings.json
deleted file mode 100644
index c9594a6..0000000
--- a/.vscode/settings.json
+++ /dev/null
@@ -1,3 +0,0 @@
-{
- "cmake.sourceDirectory": "/home/clara/repositorys/climate-go/firmware"
-}
\ No newline at end of file
diff --git a/ClimateGoApp/.gitignore b/ClimateGoApp/.gitignore
new file mode 100644
index 0000000..aa724b7
--- /dev/null
+++ b/ClimateGoApp/.gitignore
@@ -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
diff --git a/ClimateGoApp/app/.gitignore b/ClimateGoApp/app/.gitignore
new file mode 100644
index 0000000..42afabf
--- /dev/null
+++ b/ClimateGoApp/app/.gitignore
@@ -0,0 +1 @@
+/build
\ No newline at end of file
diff --git a/ClimateGoApp/app/build.gradle b/ClimateGoApp/app/build.gradle
new file mode 100644
index 0000000..45d8b9c
--- /dev/null
+++ b/ClimateGoApp/app/build.gradle
@@ -0,0 +1,44 @@
+plugins {
+ id 'com.android.application'
+}
+
+android {
+ compileSdk 32
+
+ defaultConfig {
+ applicationId "de.cdaut.climategoapp"
+ minSdk 23
+ targetSdk 32
+ versionCode 1
+ versionName "1.0"
+
+ testInstrumentationRunner "androidx.test.runner.AndroidJUnitRunner"
+ }
+
+ buildTypes {
+ release {
+ minifyEnabled false
+ proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro'
+ }
+ }
+ compileOptions {
+ sourceCompatibility JavaVersion.VERSION_1_8
+ targetCompatibility JavaVersion.VERSION_1_8
+ }
+ buildFeatures {
+ viewBinding true
+ }
+}
+
+dependencies {
+
+ implementation 'androidx.appcompat:appcompat:1.3.0'
+ implementation 'com.google.android.material:material:1.5.0'
+ implementation 'androidx.constraintlayout:constraintlayout:2.0.4'
+ implementation 'androidx.navigation:navigation-fragment:2.3.5'
+ implementation 'androidx.navigation:navigation-ui:2.3.5'
+ implementation 'com.google.android.material:material:1.6.0-alpha03'
+ testImplementation 'junit:junit:4.13.2'
+ androidTestImplementation 'androidx.test.ext:junit:1.1.3'
+ androidTestImplementation 'androidx.test.espresso:espresso-core:3.4.0'
+}
\ No newline at end of file
diff --git a/ClimateGoApp/app/proguard-rules.pro b/ClimateGoApp/app/proguard-rules.pro
new file mode 100644
index 0000000..481bb43
--- /dev/null
+++ b/ClimateGoApp/app/proguard-rules.pro
@@ -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
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/androidTest/java/de/cdaut/climategoapp/ExampleInstrumentedTest.java b/ClimateGoApp/app/src/androidTest/java/de/cdaut/climategoapp/ExampleInstrumentedTest.java
new file mode 100644
index 0000000..2fc3f8a
--- /dev/null
+++ b/ClimateGoApp/app/src/androidTest/java/de/cdaut/climategoapp/ExampleInstrumentedTest.java
@@ -0,0 +1,26 @@
+package de.cdaut.climategoapp;
+
+import android.content.Context;
+
+import androidx.test.platform.app.InstrumentationRegistry;
+import androidx.test.ext.junit.runners.AndroidJUnit4;
+
+import org.junit.Test;
+import org.junit.runner.RunWith;
+
+import static org.junit.Assert.*;
+
+/**
+ * Instrumented test, which will execute on an Android device.
+ *
+ * @see Testing documentation
+ */
+@RunWith(AndroidJUnit4.class)
+public class ExampleInstrumentedTest {
+ @Test
+ public void useAppContext() {
+ // Context of the app under test.
+ Context appContext = InstrumentationRegistry.getInstrumentation().getTargetContext();
+ assertEquals("de.cdaut.climategoapp", appContext.getPackageName());
+ }
+}
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/debug/logo-playstore.png b/ClimateGoApp/app/src/debug/logo-playstore.png
new file mode 100644
index 0000000..0bad5cf
Binary files /dev/null and b/ClimateGoApp/app/src/debug/logo-playstore.png differ
diff --git a/ClimateGoApp/app/src/debug/res/drawable/logo_foreground.xml b/ClimateGoApp/app/src/debug/res/drawable/logo_foreground.xml
new file mode 100644
index 0000000..0761fda
--- /dev/null
+++ b/ClimateGoApp/app/src/debug/res/drawable/logo_foreground.xml
@@ -0,0 +1,39 @@
+
+
+
+
+
+
+
+
+
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-anydpi-v26/logo.xml b/ClimateGoApp/app/src/debug/res/mipmap-anydpi-v26/logo.xml
new file mode 100644
index 0000000..afa7595
--- /dev/null
+++ b/ClimateGoApp/app/src/debug/res/mipmap-anydpi-v26/logo.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-anydpi-v26/logo_round.xml b/ClimateGoApp/app/src/debug/res/mipmap-anydpi-v26/logo_round.xml
new file mode 100644
index 0000000..afa7595
--- /dev/null
+++ b/ClimateGoApp/app/src/debug/res/mipmap-anydpi-v26/logo_round.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-hdpi/logo.png b/ClimateGoApp/app/src/debug/res/mipmap-hdpi/logo.png
new file mode 100644
index 0000000..94f599f
Binary files /dev/null and b/ClimateGoApp/app/src/debug/res/mipmap-hdpi/logo.png differ
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-hdpi/logo_round.png b/ClimateGoApp/app/src/debug/res/mipmap-hdpi/logo_round.png
new file mode 100644
index 0000000..67b1537
Binary files /dev/null and b/ClimateGoApp/app/src/debug/res/mipmap-hdpi/logo_round.png differ
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-mdpi/logo.png b/ClimateGoApp/app/src/debug/res/mipmap-mdpi/logo.png
new file mode 100644
index 0000000..86f888b
Binary files /dev/null and b/ClimateGoApp/app/src/debug/res/mipmap-mdpi/logo.png differ
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-mdpi/logo_round.png b/ClimateGoApp/app/src/debug/res/mipmap-mdpi/logo_round.png
new file mode 100644
index 0000000..f3747e6
Binary files /dev/null and b/ClimateGoApp/app/src/debug/res/mipmap-mdpi/logo_round.png differ
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-xhdpi/logo.png b/ClimateGoApp/app/src/debug/res/mipmap-xhdpi/logo.png
new file mode 100644
index 0000000..1e361dc
Binary files /dev/null and b/ClimateGoApp/app/src/debug/res/mipmap-xhdpi/logo.png differ
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-xhdpi/logo_round.png b/ClimateGoApp/app/src/debug/res/mipmap-xhdpi/logo_round.png
new file mode 100644
index 0000000..1cbe2b9
Binary files /dev/null and b/ClimateGoApp/app/src/debug/res/mipmap-xhdpi/logo_round.png differ
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-xxhdpi/logo.png b/ClimateGoApp/app/src/debug/res/mipmap-xxhdpi/logo.png
new file mode 100644
index 0000000..4dc422b
Binary files /dev/null and b/ClimateGoApp/app/src/debug/res/mipmap-xxhdpi/logo.png differ
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-xxhdpi/logo_round.png b/ClimateGoApp/app/src/debug/res/mipmap-xxhdpi/logo_round.png
new file mode 100644
index 0000000..e2cb13c
Binary files /dev/null and b/ClimateGoApp/app/src/debug/res/mipmap-xxhdpi/logo_round.png differ
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-xxxhdpi/logo.png b/ClimateGoApp/app/src/debug/res/mipmap-xxxhdpi/logo.png
new file mode 100644
index 0000000..4c7d03b
Binary files /dev/null and b/ClimateGoApp/app/src/debug/res/mipmap-xxxhdpi/logo.png differ
diff --git a/ClimateGoApp/app/src/debug/res/mipmap-xxxhdpi/logo_round.png b/ClimateGoApp/app/src/debug/res/mipmap-xxxhdpi/logo_round.png
new file mode 100644
index 0000000..2a38f5a
Binary files /dev/null and b/ClimateGoApp/app/src/debug/res/mipmap-xxxhdpi/logo_round.png differ
diff --git a/ClimateGoApp/app/src/debug/res/values/logo_background.xml b/ClimateGoApp/app/src/debug/res/values/logo_background.xml
new file mode 100644
index 0000000..eee1f15
--- /dev/null
+++ b/ClimateGoApp/app/src/debug/res/values/logo_background.xml
@@ -0,0 +1,4 @@
+
+
+ #F3F3F3
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/AndroidManifest.xml b/ClimateGoApp/app/src/main/AndroidManifest.xml
new file mode 100644
index 0000000..7372be3
--- /dev/null
+++ b/ClimateGoApp/app/src/main/AndroidManifest.xml
@@ -0,0 +1,38 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/DebugFragment.java b/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/DebugFragment.java
new file mode 100644
index 0000000..021733d
--- /dev/null
+++ b/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/DebugFragment.java
@@ -0,0 +1,63 @@
+package de.cdaut.climategoapp;
+
+import static android.app.Activity.RESULT_OK;
+
+import android.bluetooth.BluetoothAdapter;
+import android.content.Intent;
+import android.os.Bundle;
+import android.view.LayoutInflater;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.Toast;
+
+
+import androidx.activity.result.ActivityResultLauncher;
+import androidx.activity.result.contract.ActivityResultContracts;
+import androidx.annotation.NonNull;
+import androidx.fragment.app.Fragment;
+
+import de.cdaut.climategoapp.databinding.FragmentDebugBinding;
+
+public class DebugFragment extends Fragment {
+
+ private FragmentDebugBinding binding;
+
+ //this is the Launcher that will make the request to
+ // enable Bluetooth and handle the result callback
+ private final ActivityResultLauncher mBtEnable = registerForActivityResult(
+ new ActivityResultContracts.StartActivityForResult(),
+ result -> {
+ if (result.getResultCode() != RESULT_OK) {
+ //make an error toast if the user denys enabling bluetooth
+ Toast.makeText(
+ getActivity().getApplicationContext(),
+ R.string.bt_required,
+ Toast.LENGTH_LONG
+ ).show();
+ }
+ }
+ );
+
+ @Override
+ public View onCreateView(
+ @NonNull LayoutInflater inflater, ViewGroup container,
+ Bundle savedInstanceState
+ ) {
+
+ binding = FragmentDebugBinding.inflate(inflater, container, false);
+
+ this.binding.buttonTest.setOnClickListener(view -> {
+ //make request to enable bluetooth
+ mBtEnable.launch(new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE));
+ });
+
+ return binding.getRoot();
+
+ }
+
+ @Override
+ public void onDestroyView() {
+ super.onDestroyView();
+ binding = null;
+ }
+}
diff --git a/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/HomeFragment.java b/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/HomeFragment.java
new file mode 100644
index 0000000..7f47487
--- /dev/null
+++ b/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/HomeFragment.java
@@ -0,0 +1,40 @@
+package de.cdaut.climategoapp;
+
+import android.os.Bundle;
+import android.view.LayoutInflater;
+import android.view.View;
+import android.view.ViewGroup;
+
+import androidx.annotation.NonNull;
+import androidx.fragment.app.Fragment;
+
+import de.cdaut.climategoapp.databinding.FragmentHomeBinding;
+
+public class HomeFragment extends Fragment {
+
+ private FragmentHomeBinding binding;
+
+ @Override
+ public View onCreateView(
+ @NonNull LayoutInflater inflater, ViewGroup container,
+ Bundle savedInstanceState
+ ) {
+
+ binding = FragmentHomeBinding.inflate(inflater, container, false);
+
+ return binding.getRoot();
+
+ }
+
+ @Override
+ public void onViewCreated(@NonNull View view, Bundle savedInstanceState) {
+ super.onViewCreated(view, savedInstanceState);
+ }
+
+ @Override
+ public void onDestroyView() {
+ super.onDestroyView();
+ binding = null;
+ }
+
+}
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/activities/HomeActivity.java b/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/activities/HomeActivity.java
new file mode 100644
index 0000000..cc155ce
--- /dev/null
+++ b/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/activities/HomeActivity.java
@@ -0,0 +1,136 @@
+package de.cdaut.climategoapp.activities;
+
+import android.os.Bundle;
+
+
+import androidx.annotation.NonNull;
+import androidx.appcompat.app.ActionBarDrawerToggle;
+import androidx.appcompat.app.AppCompatActivity;
+
+import androidx.drawerlayout.widget.DrawerLayout;
+import androidx.fragment.app.Fragment;
+import androidx.navigation.NavController;
+import androidx.navigation.Navigation;
+import androidx.navigation.ui.AppBarConfiguration;
+import androidx.navigation.ui.NavigationUI;
+
+import de.cdaut.climategoapp.DebugFragment;
+import de.cdaut.climategoapp.HomeFragment;
+import de.cdaut.climategoapp.R;
+import de.cdaut.climategoapp.databinding.ActivityHomeBinding;
+
+import android.view.Menu;
+import android.view.MenuItem;
+
+import com.google.android.material.navigation.NavigationView;
+
+public class HomeActivity extends AppCompatActivity implements NavigationView.OnNavigationItemSelectedListener {
+
+ private AppBarConfiguration appBarConfiguration;
+ private ActivityHomeBinding binding;
+ public DrawerLayout drawerLayout;
+ public ActionBarDrawerToggle actionBarDrawerToggle;
+
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+
+ binding = ActivityHomeBinding.inflate(getLayoutInflater());
+ setContentView(binding.getRoot());
+
+ setSupportActionBar(binding.toolbar);
+
+ // drawer layout instance to toggle the menu icon to open
+ // drawer and back button to close drawer
+ drawerLayout = findViewById(R.id.home_drawer_layout);
+ actionBarDrawerToggle = new ActionBarDrawerToggle(this,
+ drawerLayout,
+ R.string.nav_open,
+ R.string.nav_close);
+
+ // pass the Open and Close toggle for the drawer layout listener
+ // to toggle the button
+ drawerLayout.addDrawerListener(actionBarDrawerToggle);
+ actionBarDrawerToggle.syncState();
+
+ // to make the Navigation drawer icon always appear on the action bar
+ getSupportActionBar().setDisplayHomeAsUpEnabled(true);
+
+ //add the Home Fragment to the Fragment container
+ this.getSupportFragmentManager()
+ .beginTransaction()
+ .replace(R.id.home_act_fragment_container, new HomeFragment())
+ .commit();
+
+ setNavigationViewListener();
+ }
+
+ @Override
+ public boolean onCreateOptionsMenu(Menu menu) {
+ // Inflate the menu; this adds items to the action bar if it is present.
+ getMenuInflater().inflate(R.menu.menu_main, menu);
+ return true;
+ }
+
+ @Override
+ public boolean onOptionsItemSelected(MenuItem item) {
+ // Handle action bar item clicks here. The action bar will
+ // automatically handle clicks on the Home/Up button, so long
+ // as you specify a parent activity in AndroidManifest.xml.
+ int id = item.getItemId();
+
+ if (actionBarDrawerToggle.onOptionsItemSelected(item)) {
+ return true;
+ }
+
+ if (id == R.id.action_settings) {
+ return true;
+ }
+
+ return super.onOptionsItemSelected(item);
+ }
+
+ @Override
+ public boolean onSupportNavigateUp() {
+ NavController navController = Navigation.findNavController(this,
+ R.id.nav_host_fragment_content_nav
+ );
+ return NavigationUI.navigateUp(navController, appBarConfiguration)
+ || super.onSupportNavigateUp();
+ }
+
+ @Override
+ public boolean onNavigationItemSelected(@NonNull MenuItem item) {
+
+ Fragment targetFragment;
+
+ //determine which fragment to switch to
+ //TODO: switch this to some better switch value like a tag
+ switch (item.getItemId()) {
+ case R.id.nav_main:
+ targetFragment = new HomeFragment();
+ break;
+ case R.id.nav_debug:
+ targetFragment = new DebugFragment();
+ break;
+ default:
+ throw new IllegalAccessError("Illegal activity met in nav drawer");
+ }
+
+ //switch to the appropriate Fragment
+ this.getSupportFragmentManager()
+ .beginTransaction()
+ .replace(R.id.home_act_fragment_container, targetFragment)
+ .commit();
+
+ //close the nav drawer after switching fragments
+ this.drawerLayout.closeDrawers();
+ return false;
+ }
+
+ private void setNavigationViewListener() {
+ NavigationView navigationView = findViewById(R.id.nav_drawer);
+ navigationView.setNavigationItemSelectedListener(this);
+ }
+
+}
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/sensor/SensorDebugUtils.java b/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/sensor/SensorDebugUtils.java
new file mode 100644
index 0000000..9f4cf3e
--- /dev/null
+++ b/ClimateGoApp/app/src/main/java/de/cdaut/climategoapp/sensor/SensorDebugUtils.java
@@ -0,0 +1,18 @@
+package de.cdaut.climategoapp.sensor;
+
+import java.util.ArrayList;
+import java.util.List;
+
+public final class SensorDebugUtils {
+ private SensorDebugUtils() {
+ throw new IllegalAccessError("Utility Class");
+ }
+
+ public static List readSensorData() {
+ ArrayList data = new ArrayList<>();
+ data.add("Test");
+ data.add("a");
+ data.add("b");
+ return data;
+ }
+}
diff --git a/ClimateGoApp/app/src/main/logo-playstore.png b/ClimateGoApp/app/src/main/logo-playstore.png
new file mode 100644
index 0000000..1834bf4
Binary files /dev/null and b/ClimateGoApp/app/src/main/logo-playstore.png differ
diff --git a/ClimateGoApp/app/src/main/res/drawable-v24/ic_launcher_foreground.xml b/ClimateGoApp/app/src/main/res/drawable-v24/ic_launcher_foreground.xml
new file mode 100644
index 0000000..2b068d1
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/drawable-v24/ic_launcher_foreground.xml
@@ -0,0 +1,30 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/drawable/ic_launcher_background.xml b/ClimateGoApp/app/src/main/res/drawable/ic_launcher_background.xml
new file mode 100644
index 0000000..07d5da9
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/drawable/ic_launcher_background.xml
@@ -0,0 +1,170 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/ClimateGoApp/app/src/main/res/drawable/logo_foreground.xml b/ClimateGoApp/app/src/main/res/drawable/logo_foreground.xml
new file mode 100644
index 0000000..0761fda
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/drawable/logo_foreground.xml
@@ -0,0 +1,39 @@
+
+
+
+
+
+
+
+
+
diff --git a/ClimateGoApp/app/src/main/res/layout/activity_home.xml b/ClimateGoApp/app/src/main/res/layout/activity_home.xml
new file mode 100644
index 0000000..f0951c6
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/layout/activity_home.xml
@@ -0,0 +1,41 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/layout/content_nav.xml b/ClimateGoApp/app/src/main/res/layout/content_nav.xml
new file mode 100644
index 0000000..482b09b
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/layout/content_nav.xml
@@ -0,0 +1,19 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/layout/fragment_debug.xml b/ClimateGoApp/app/src/main/res/layout/fragment_debug.xml
new file mode 100644
index 0000000..e66b45b
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/layout/fragment_debug.xml
@@ -0,0 +1,28 @@
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/layout/fragment_home.xml b/ClimateGoApp/app/src/main/res/layout/fragment_home.xml
new file mode 100644
index 0000000..3f99881
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/layout/fragment_home.xml
@@ -0,0 +1,18 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/menu/menu_main.xml b/ClimateGoApp/app/src/main/res/menu/menu_main.xml
new file mode 100644
index 0000000..18bbeb1
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/menu/menu_main.xml
@@ -0,0 +1,10 @@
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/menu/navigation_menu.xml b/ClimateGoApp/app/src/main/res/menu/navigation_menu.xml
new file mode 100644
index 0000000..04a3c16
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/menu/navigation_menu.xml
@@ -0,0 +1,17 @@
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml b/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml
new file mode 100644
index 0000000..eca70cf
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml b/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml
new file mode 100644
index 0000000..eca70cf
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/logo.xml b/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/logo.xml
new file mode 100644
index 0000000..afa7595
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/logo.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/logo_round.xml b/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/logo_round.xml
new file mode 100644
index 0000000..afa7595
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/mipmap-anydpi-v26/logo_round.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/mipmap-hdpi/ic_launcher.webp b/ClimateGoApp/app/src/main/res/mipmap-hdpi/ic_launcher.webp
new file mode 100644
index 0000000..c209e78
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-hdpi/ic_launcher.webp differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp b/ClimateGoApp/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp
new file mode 100644
index 0000000..b2dfe3d
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-hdpi/logo.png b/ClimateGoApp/app/src/main/res/mipmap-hdpi/logo.png
new file mode 100644
index 0000000..a829e3f
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-hdpi/logo.png differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-hdpi/logo_round.png b/ClimateGoApp/app/src/main/res/mipmap-hdpi/logo_round.png
new file mode 100644
index 0000000..9583924
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-hdpi/logo_round.png differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-mdpi/ic_launcher.webp b/ClimateGoApp/app/src/main/res/mipmap-mdpi/ic_launcher.webp
new file mode 100644
index 0000000..4f0f1d6
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-mdpi/ic_launcher.webp differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp b/ClimateGoApp/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp
new file mode 100644
index 0000000..62b611d
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-mdpi/logo.png b/ClimateGoApp/app/src/main/res/mipmap-mdpi/logo.png
new file mode 100644
index 0000000..56108a8
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-mdpi/logo.png differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-mdpi/logo_round.png b/ClimateGoApp/app/src/main/res/mipmap-mdpi/logo_round.png
new file mode 100644
index 0000000..bbf8976
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-mdpi/logo_round.png differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xhdpi/ic_launcher.webp b/ClimateGoApp/app/src/main/res/mipmap-xhdpi/ic_launcher.webp
new file mode 100644
index 0000000..948a307
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xhdpi/ic_launcher.webp differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp b/ClimateGoApp/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp
new file mode 100644
index 0000000..1b9a695
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xhdpi/logo.png b/ClimateGoApp/app/src/main/res/mipmap-xhdpi/logo.png
new file mode 100644
index 0000000..0092fd0
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xhdpi/logo.png differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xhdpi/logo_round.png b/ClimateGoApp/app/src/main/res/mipmap-xhdpi/logo_round.png
new file mode 100644
index 0000000..10f6261
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xhdpi/logo_round.png differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp b/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp
new file mode 100644
index 0000000..28d4b77
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp b/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp
new file mode 100644
index 0000000..9287f50
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/logo.png b/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/logo.png
new file mode 100644
index 0000000..ec3b268
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/logo.png differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/logo_round.png b/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/logo_round.png
new file mode 100644
index 0000000..ee171e9
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xxhdpi/logo_round.png differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp b/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp
new file mode 100644
index 0000000..aa7d642
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp b/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp
new file mode 100644
index 0000000..9126ae3
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/logo.png b/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/logo.png
new file mode 100644
index 0000000..a78349d
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/logo.png differ
diff --git a/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/logo_round.png b/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/logo_round.png
new file mode 100644
index 0000000..1f74ca9
Binary files /dev/null and b/ClimateGoApp/app/src/main/res/mipmap-xxxhdpi/logo_round.png differ
diff --git a/ClimateGoApp/app/src/main/res/navigation/nav_graph.xml b/ClimateGoApp/app/src/main/res/navigation/nav_graph.xml
new file mode 100644
index 0000000..7e4f480
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/navigation/nav_graph.xml
@@ -0,0 +1,23 @@
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/values-land/dimens.xml b/ClimateGoApp/app/src/main/res/values-land/dimens.xml
new file mode 100644
index 0000000..22d7f00
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/values-land/dimens.xml
@@ -0,0 +1,3 @@
+
+ 48dp
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/values-night/themes.xml b/ClimateGoApp/app/src/main/res/values-night/themes.xml
new file mode 100644
index 0000000..9d0d973
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/values-night/themes.xml
@@ -0,0 +1,16 @@
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/values-w1240dp/dimens.xml b/ClimateGoApp/app/src/main/res/values-w1240dp/dimens.xml
new file mode 100644
index 0000000..d73f4a3
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/values-w1240dp/dimens.xml
@@ -0,0 +1,3 @@
+
+ 200dp
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/values-w600dp/dimens.xml b/ClimateGoApp/app/src/main/res/values-w600dp/dimens.xml
new file mode 100644
index 0000000..22d7f00
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/values-w600dp/dimens.xml
@@ -0,0 +1,3 @@
+
+ 48dp
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/values/colors.xml b/ClimateGoApp/app/src/main/res/values/colors.xml
new file mode 100644
index 0000000..f8c6127
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/values/colors.xml
@@ -0,0 +1,10 @@
+
+
+ #FFBB86FC
+ #FF6200EE
+ #FF3700B3
+ #FF03DAC5
+ #FF018786
+ #FF000000
+ #FFFFFFFF
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/values/dimens.xml b/ClimateGoApp/app/src/main/res/values/dimens.xml
new file mode 100644
index 0000000..125df87
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/values/dimens.xml
@@ -0,0 +1,3 @@
+
+ 16dp
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/values/logo_background.xml b/ClimateGoApp/app/src/main/res/values/logo_background.xml
new file mode 100644
index 0000000..8f355a4
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/values/logo_background.xml
@@ -0,0 +1,4 @@
+
+
+ #F0F0F0
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/values/strings.xml b/ClimateGoApp/app/src/main/res/values/strings.xml
new file mode 100644
index 0000000..e43380c
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/values/strings.xml
@@ -0,0 +1,13 @@
+
+ ClimateGoApp
+ Settings
+
+ Main Fragment
+ Debug Fragment
+ Enable Bluetooth
+ Main
+ Debug view
+ Open
+ Close
+ Bluetooth is required to connect to the sensor
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/main/res/values/themes.xml b/ClimateGoApp/app/src/main/res/values/themes.xml
new file mode 100644
index 0000000..c67b03b
--- /dev/null
+++ b/ClimateGoApp/app/src/main/res/values/themes.xml
@@ -0,0 +1,25 @@
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/ClimateGoApp/app/src/test/java/de/cdaut/climategoapp/ExampleUnitTest.java b/ClimateGoApp/app/src/test/java/de/cdaut/climategoapp/ExampleUnitTest.java
new file mode 100644
index 0000000..1e3ad80
--- /dev/null
+++ b/ClimateGoApp/app/src/test/java/de/cdaut/climategoapp/ExampleUnitTest.java
@@ -0,0 +1,17 @@
+package de.cdaut.climategoapp;
+
+import org.junit.Test;
+
+import static org.junit.Assert.*;
+
+/**
+ * Example local unit test, which will execute on the development machine (host).
+ *
+ * @see Testing documentation
+ */
+public class ExampleUnitTest {
+ @Test
+ public void addition_isCorrect() {
+ assertEquals(4, 2 + 2);
+ }
+}
\ No newline at end of file
diff --git a/ClimateGoApp/build.gradle b/ClimateGoApp/build.gradle
new file mode 100644
index 0000000..2fcc7ef
--- /dev/null
+++ b/ClimateGoApp/build.gradle
@@ -0,0 +1,9 @@
+// Top-level build file where you can add configuration options common to all sub-projects/modules.
+plugins {
+ id 'com.android.application' version '7.1.2' apply false
+ id 'com.android.library' version '7.1.2' apply false
+}
+
+task clean(type: Delete) {
+ delete rootProject.buildDir
+}
\ No newline at end of file
diff --git a/ClimateGoApp/gradle.properties b/ClimateGoApp/gradle.properties
new file mode 100644
index 0000000..dab7c28
--- /dev/null
+++ b/ClimateGoApp/gradle.properties
@@ -0,0 +1,21 @@
+# 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
+# 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
\ No newline at end of file
diff --git a/ClimateGoApp/gradle/wrapper/gradle-wrapper.jar b/ClimateGoApp/gradle/wrapper/gradle-wrapper.jar
new file mode 100644
index 0000000..e708b1c
Binary files /dev/null and b/ClimateGoApp/gradle/wrapper/gradle-wrapper.jar differ
diff --git a/ClimateGoApp/gradle/wrapper/gradle-wrapper.properties b/ClimateGoApp/gradle/wrapper/gradle-wrapper.properties
new file mode 100644
index 0000000..f4c6ed3
--- /dev/null
+++ b/ClimateGoApp/gradle/wrapper/gradle-wrapper.properties
@@ -0,0 +1,6 @@
+#Fri Mar 18 09:22:56 CET 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
diff --git a/ClimateGoApp/gradlew b/ClimateGoApp/gradlew
new file mode 100755
index 0000000..4f906e0
--- /dev/null
+++ b/ClimateGoApp/gradlew
@@ -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" "$@"
diff --git a/ClimateGoApp/gradlew.bat b/ClimateGoApp/gradlew.bat
new file mode 100644
index 0000000..ac1b06f
--- /dev/null
+++ b/ClimateGoApp/gradlew.bat
@@ -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
diff --git a/ClimateGoApp/settings.gradle b/ClimateGoApp/settings.gradle
new file mode 100644
index 0000000..434615f
--- /dev/null
+++ b/ClimateGoApp/settings.gradle
@@ -0,0 +1,16 @@
+pluginManagement {
+ repositories {
+ gradlePluginPortal()
+ google()
+ mavenCentral()
+ }
+}
+dependencyResolutionManagement {
+ repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
+ repositories {
+ google()
+ mavenCentral()
+ }
+}
+rootProject.name = "ClimateGoApp"
+include ':app'
diff --git a/README.md b/README.md
index d636e83..f1c2bd9 100644
--- a/README.md
+++ b/README.md
@@ -1,20 +1,20 @@
-# Climate GO
-Climate GO is a fully open source open hardware Sensor pack, to track and analyze personal air quality data. Its goal is to provide a way to monitor ones own air quality and motivate people to avoid polluted places and protect the environment.
+# Climate GO
+Climate GO is a fully open source open hardware Sensor pack, to track and analyze personal air quality data. It's goal is to provide a way to monitor ones own air quality and motivate people to avoid polluted places and protect the environment.
## Paradigms
This project is intended to be open source, open hardware and open data oriented. It is of central importance to make this available to anyone who whishes to build a climate go device and to ensure no personal data is collected and stored. This is especially important because the climate data collected will be correlated with GPS information and could thus be used to construct a movement profile if not handled with uttermost care.
-## Technical information
+## Technical information
### Stack
The sensor pack itself is based around the ESP32 microprocessor and contains several sensors:
- BMP280 air pressure and temperature monitoring sensor
-- Nova SDS011 particulate matter sensor
+- [name] particulate matter sensor
- [name] CO2 sensor
-- MISC 2714 NO2 sensor
+- [name] NO2 sensor
A custom PCB/housing is yet to be designed and manufactured. Data collection is made possible by an Android App, that will connect to the sensor pack via Bluetooth low energy. It is imperative to design the sensor pack to be lightweight and consume as little as possible energy to ensure comfort in transporting the sensor pack (it is intended to be clipped to e.g. a backpack) and long battery life.
## Outlook
It might be interesting to add more types of sensors, to collect more information and provide a broader picture of personal air quality. However this will increase cost and power consumption of the sensor and must thus be considered carefully.
-It would also be interesting to "gamify" the idea, by providing users the opportunity to collect awards and complete quests related to personal air quality, increasing the motivation to protect the environment and b healthy even more.
+It would also be interesting to "gamify" the idea, by providing users the opportunity to collect awards and complete quests related to personal air quality, increasing the motivation to protect the environment and b healthy even more.
\ No newline at end of file
diff --git a/firmware/.gitignore b/firmware/.gitignore
deleted file mode 100644
index 89cc49c..0000000
--- a/firmware/.gitignore
+++ /dev/null
@@ -1,5 +0,0 @@
-.pio
-.vscode/.browse.c_cpp.db*
-.vscode/c_cpp_properties.json
-.vscode/launch.json
-.vscode/ipch
diff --git a/firmware/.vscode/extensions.json b/firmware/.vscode/extensions.json
deleted file mode 100644
index 080e70d..0000000
--- a/firmware/.vscode/extensions.json
+++ /dev/null
@@ -1,10 +0,0 @@
-{
- // See http://go.microsoft.com/fwlink/?LinkId=827846
- // for the documentation about the extensions.json format
- "recommendations": [
- "platformio.platformio-ide"
- ],
- "unwantedRecommendations": [
- "ms-vscode.cpptools-extension-pack"
- ]
-}
diff --git a/flake.lock b/flake.lock
deleted file mode 100644
index 1796f3c..0000000
--- a/flake.lock
+++ /dev/null
@@ -1,27 +0,0 @@
-{
- "nodes": {
- "nixpkgs": {
- "locked": {
- "lastModified": 1728241625,
- "narHash": "sha256-yumd4fBc/hi8a9QgA9IT8vlQuLZ2oqhkJXHPKxH/tRw=",
- "owner": "nixos",
- "repo": "nixpkgs",
- "rev": "c31898adf5a8ed202ce5bea9f347b1c6871f32d1",
- "type": "github"
- },
- "original": {
- "owner": "nixos",
- "ref": "nixos-unstable",
- "repo": "nixpkgs",
- "type": "github"
- }
- },
- "root": {
- "inputs": {
- "nixpkgs": "nixpkgs"
- }
- }
- },
- "root": "root",
- "version": 7
-}
diff --git a/flake.nix b/flake.nix
deleted file mode 100644
index 8d9655b..0000000
--- a/flake.nix
+++ /dev/null
@@ -1,25 +0,0 @@
-{
- description = "A Nix-flake-based PlatformIO development environment";
-
- inputs.nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
-
- outputs = { self, nixpkgs }:
- let
- supportedSystems = [ "x86_64-linux" "aarch64-linux" "x86_64-darwin" "aarch64-darwin" ];
- forEachSupportedSystem = f: nixpkgs.lib.genAttrs supportedSystems (system: f {
- pkgs = import nixpkgs { inherit system; };
- });
- in
- {
- devShells = forEachSupportedSystem ({ pkgs }: {
- default = pkgs.mkShell {
- packages = with pkgs; [
- platformio-core
- openocd
- python3
- platformio
- ];
- };
- });
- };
-}