diff --git a/ToDoApp2/.gitignore b/ToDoApp2/.gitignore new file mode 100644 index 0000000..aa724b7 --- /dev/null +++ b/ToDoApp2/.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/ToDoApp2/app/.gitignore b/ToDoApp2/app/.gitignore new file mode 100644 index 0000000..42afabf --- /dev/null +++ b/ToDoApp2/app/.gitignore @@ -0,0 +1 @@ +/build \ No newline at end of file diff --git a/ToDoApp2/app/build.gradle.kts b/ToDoApp2/app/build.gradle.kts new file mode 100644 index 0000000..49a1bf3 --- /dev/null +++ b/ToDoApp2/app/build.gradle.kts @@ -0,0 +1,49 @@ +plugins { + alias(libs.plugins.android.application) +} + +android { + namespace = "com.example.todoapp2" + compileSdk = 34 + + defaultConfig { + applicationId = "com.example.todoapp2" + minSdk = 21 + targetSdk = 34 + versionCode = 1 + versionName = "1.0" + + testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner" + } + + buildTypes { + release { + isMinifyEnabled = false + proguardFiles( + getDefaultProguardFile("proguard-android-optimize.txt"), + "proguard-rules.pro" + ) + } + } + compileOptions { + sourceCompatibility = JavaVersion.VERSION_1_8 + targetCompatibility = JavaVersion.VERSION_1_8 + } +} + +dependencies { + + + + implementation(libs.appcompat) + implementation(libs.material) + implementation(libs.activity) + implementation(libs.constraintlayout) + testImplementation(libs.junit) + androidTestImplementation(libs.ext.junit) + androidTestImplementation(libs.espresso.core) + + implementation("androidx.lifecycle:lifecycle-livedata-ktx:2.6.0") + implementation("androidx.lifecycle:lifecycle-viewmodel-ktx:2.6.0") +} + diff --git a/ToDoApp2/app/proguard-rules.pro b/ToDoApp2/app/proguard-rules.pro new file mode 100644 index 0000000..481bb43 --- /dev/null +++ b/ToDoApp2/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/ToDoApp2/app/src/androidTest/java/com/example/todoapp2/ExampleInstrumentedTest.java b/ToDoApp2/app/src/androidTest/java/com/example/todoapp2/ExampleInstrumentedTest.java new file mode 100644 index 0000000..25689d9 --- /dev/null +++ b/ToDoApp2/app/src/androidTest/java/com/example/todoapp2/ExampleInstrumentedTest.java @@ -0,0 +1,26 @@ +package com.example.todoapp2; + +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("com.example.todoapp2", appContext.getPackageName()); + } +} \ No newline at end of file diff --git a/ToDoApp2/app/src/main/AndroidManifest.xml b/ToDoApp2/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..fbba558 --- /dev/null +++ b/ToDoApp2/app/src/main/AndroidManifest.xml @@ -0,0 +1,27 @@ + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/ToDoApp2/app/src/main/java/com/example/todoapp2/DatabaseHelper.java b/ToDoApp2/app/src/main/java/com/example/todoapp2/DatabaseHelper.java new file mode 100644 index 0000000..454ec59 --- /dev/null +++ b/ToDoApp2/app/src/main/java/com/example/todoapp2/DatabaseHelper.java @@ -0,0 +1,68 @@ +package com.example.todoapp2; + +import android.content.ContentValues; +import android.content.Context; +import android.database.Cursor; +import android.database.sqlite.SQLiteDatabase; +import android.database.sqlite.SQLiteOpenHelper; + +import java.util.ArrayList; +import java.util.List; + +public class DatabaseHelper extends SQLiteOpenHelper { + private static final String DATABASE_NAME = "todo.db"; + private static final int DATABASE_VERSION = 1; + + public DatabaseHelper(Context context) { + super(context, DATABASE_NAME, null, DATABASE_VERSION); //Inicjalizacja bazy danych + } + + @Override + public void onCreate(SQLiteDatabase db) { + String createTable = "CREATE TABLE tasks (id INTEGER PRIMARY KEY AUTOINCREMENT, task TEXT, deadline TEXT, priority TEXT)"; + db.execSQL(createTable); //Tworzenie tabeli w bazie danych + } + + @Override + public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { + db.execSQL("DROP TABLE IF EXISTS tasks"); //Usunięcie starej tabeli + onCreate(db); //Tworzenie nowej tabeli + } + + public boolean addTask(String task, String deadline, String priority) { + SQLiteDatabase db = this.getWritableDatabase(); + ContentValues contentValues = new ContentValues(); + contentValues.put("task", task); //Dodanie wartości task + contentValues.put("deadline", deadline); //Dodanie wartości deadline + contentValues.put("priority", priority); //Dodanie wartości priority + long result = db.insert("tasks", null, contentValues); //Wstawienie wiersza do tabeli + return result != -1; + } + + public boolean removeTask(String task) { + SQLiteDatabase db = this.getWritableDatabase(); + return db.delete("tasks", "task = ?", new String[]{task}) > 0; //Usunięcie wiersza z tabeli + } + + public List getAllTasks() { + List tasks = new ArrayList<>(); + SQLiteDatabase db = this.getReadableDatabase(); + Cursor cursor = db.rawQuery("SELECT * FROM tasks ORDER BY deadline ASC", null); //Pobranie wszystkich zadań z tabeli + if (cursor.moveToFirst()) { + do { + String task = cursor.getString(cursor.getColumnIndexOrThrow("task")); + String deadline = cursor.getString(cursor.getColumnIndexOrThrow("deadline")); + String priority = cursor.getString(cursor.getColumnIndexOrThrow("priority")); + tasks.add(task + " (Deadline: " + deadline + ", Priority: " + priority + ")"); //Dodanie zadania do listy + } while (cursor.moveToNext()); + } + cursor.close(); + return tasks; //Zwrócenie listy zadań + } + + public void removeExpiredTasks() { + SQLiteDatabase db = this.getWritableDatabase(); + String currentDate = new java.text.SimpleDateFormat("yyyy-MM-dd").format(new java.util.Date()); + db.delete("tasks", "deadline < ?", new String[]{currentDate}); //Usunięcie zadań z przeszłą datą + } +} diff --git a/ToDoApp2/app/src/main/java/com/example/todoapp2/HtmlActivity.java b/ToDoApp2/app/src/main/java/com/example/todoapp2/HtmlActivity.java new file mode 100644 index 0000000..144eb84 --- /dev/null +++ b/ToDoApp2/app/src/main/java/com/example/todoapp2/HtmlActivity.java @@ -0,0 +1,20 @@ +package com.example.todoapp2; + +import android.os.Bundle; +import android.webkit.WebView; + +import androidx.annotation.Nullable; +import androidx.appcompat.app.AppCompatActivity; + +public class HtmlActivity extends AppCompatActivity { + @Override + protected void onCreate(@Nullable Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_html); //Ustawienie widoku dla aktywności + + WebView webView = findViewById(R.id.web_view); //Referencja do WebView + String htmlData = getIntent().getStringExtra("html_data"); //Pobranie danych HTML z intent + assert htmlData != null; + webView.loadData(htmlData, "text/html", "UTF-8"); //Załadowanie danych HTML do WebView + } +} diff --git a/ToDoApp2/app/src/main/java/com/example/todoapp2/MainActivity.java b/ToDoApp2/app/src/main/java/com/example/todoapp2/MainActivity.java new file mode 100644 index 0000000..ea4412f --- /dev/null +++ b/ToDoApp2/app/src/main/java/com/example/todoapp2/MainActivity.java @@ -0,0 +1,147 @@ +package com.example.todoapp2; + +import android.app.DatePickerDialog; +import android.content.Context; +import android.content.Intent; +import android.os.Bundle; +import android.util.Log; +import android.widget.ArrayAdapter; +import android.widget.Button; +import android.widget.EditText; +import android.widget.ListView; +import android.widget.Spinner; +import android.widget.Toast; + +import androidx.activity.EdgeToEdge; +import androidx.appcompat.app.AppCompatActivity; +import androidx.lifecycle.ViewModelProvider; + +import java.util.Calendar; + +public class MainActivity extends AppCompatActivity { + private static final String TAG = "MainActivity"; + private ArrayAdapter itemsAdapter; + private EditText deadlineInput; + private Spinner priorityInput; + private TaskViewModel viewModel; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + EdgeToEdge.enable(this); + setContentView(R.layout.activity_main); + + viewModel = new ViewModelProvider(this).get(TaskViewModel.class); //Inicjalizacja ViewModel + + ListView list = findViewById(R.id.list); //Referencja do ListView + Button button = findViewById(R.id.button); //Referencja do przycisku dodawania zadań + Button buttonViewHtml = findViewById(R.id.button_view_html); //Referencja do przycisku wyświetlania zadań w HTML + deadlineInput = findViewById(R.id.edit_deadline); //Referencja do pola wyboru terminu + priorityInput = findViewById(R.id.edit_priority); //Referencja do spinnera wyboru priorytetu + + itemsAdapter = new ArrayAdapter<>(this, android.R.layout.simple_list_item_1); //Inicjalizacja adaptera dla ListView + list.setAdapter(itemsAdapter); //Ustawienie adaptera na ListView + + //Obserwacja zmian w LiveData + viewModel.getTasks().observe(this, tasks -> { + Log.d(TAG, "Tasks updated: " + tasks); //Logowanie zmian + itemsAdapter.clear(); //Czyszczenie adaptera + itemsAdapter.addAll(tasks); //Dodanie nowych danych do adaptera + itemsAdapter.notifyDataSetChanged(); //Powiadomienie adaptera o zmianach + }); + + //Listener dla pola wyboru terminu + deadlineInput.setOnClickListener(v -> { + showDatePickerDialog(); //Wyświetlenie DatePickerDialog + }); + + //Listener dla przycisku dodawania zadań + button.setOnClickListener(view -> { + Log.d(TAG, "Add button clicked"); //Logowanie kliknięcia przycisku + addItem(); //Dodanie nowego zadania + }); + + //Listener dla przycisku wyświetlania zadań w HTML + buttonViewHtml.setOnClickListener(v -> { + viewTasksInHtml(); //Wyświetlenie zadań w HTML + }); + + //Listener dla długiego kliknięcia na element ListView + list.setOnItemLongClickListener((parent, view, position, id) -> { + return remove(position); //Usunięcie zadania + }); + + ArrayAdapter adapter = ArrayAdapter.createFromResource(this, //Inicjalizacja adaptera dla spinnera + R.array.priority_levels, android.R.layout.simple_spinner_item); + adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item); + priorityInput.setAdapter(adapter); //Ustawienie adaptera na spinner + } + + private void showDatePickerDialog() { //Metoda wyświetlająca DatePickerDialog + final Calendar calendar = Calendar.getInstance(); + int year = calendar.get(Calendar.YEAR); + int month = calendar.get(Calendar.MONTH); + int day = calendar.get(Calendar.DAY_OF_MONTH); + + //Listener dla wyboru daty + DatePickerDialog datePickerDialog = new DatePickerDialog(this, (view, year1, month1, dayOfMonth) -> { + String date = year1 + "-" + (month1 + 1) + "-" + dayOfMonth; + deadlineInput.setText(date); //Ustawienie wybranej daty w polu tekstowym + }, year, month, day); + datePickerDialog.show(); //Wyświetlenie DatePickerDialog + } + + private boolean remove(int position) { //Metoda usuwająca zadanie + Context context = getApplicationContext(); + String item = itemsAdapter.getItem(position); //Pobranie elementu z adaptera + assert item != null; + String task = item.split(" \\(Deadline:")[0]; + if (viewModel.removeTask(task)) { //Usunięcie zadania z ViewModel + Toast.makeText(context, "Item removed", Toast.LENGTH_LONG).show(); //Wyświetlenie Toast z komunikatem + return true; + } else { + Toast.makeText(context, "Error removing item", Toast.LENGTH_LONG).show(); //Wyświetlenie Toast z błędem + return false; + } + } + + private void addItem() { //Metoda dodająca nowe zadanie + EditText taskInput = findViewById(R.id.edit_text); + String taskText = taskInput.getText().toString(); + String deadlineText = deadlineInput.getText().toString(); + String priorityText = priorityInput.getSelectedItem().toString(); + + Log.d(TAG, "Task: " + taskText + ", Deadline: " + deadlineText + ", Priority: " + priorityText); + + if (!(taskText.isEmpty() || deadlineText.isEmpty() || priorityText.isEmpty())) { //Sprawdzenie czy pola nie są puste + if (viewModel.addTask(taskText, deadlineText, priorityText)) { //Dodanie zadania do ViewModel + taskInput.setText(""); //Wyczyszczenie pola tekstowego + deadlineInput.setText(""); //Wyczyszczenie pola daty + priorityInput.setSelection(0); //Resetowanie spinnera + } else { + Toast.makeText(getApplicationContext(), "Error adding task", Toast.LENGTH_LONG).show(); //Wyświetlenie Toast z błędem + } + } else { + Toast.makeText(getApplicationContext(), "Please enter all fields", Toast.LENGTH_LONG).show(); //Wyświetlenie Toast z komunikatem o wypełnieniu wszystkich pól + } + } + + private void viewTasksInHtml() { //Metoda wyświetlająca zadania w HTML + StringBuilder htmlBuilder = new StringBuilder(); + htmlBuilder.append("

Task List

"); + for (int i = 0; i < itemsAdapter.getCount(); i++) { + String item = itemsAdapter.getItem(i); + assert item != null; + String[] parts = item.split(" \\(Deadline: "); + String task = parts[0]; + String deadline = parts[1].split(", Priority: ")[0]; + String priority = parts[1].split(", Priority: ")[1].replace(")", ""); + htmlBuilder.append(""); + } + htmlBuilder.append("
TaskDeadlinePriority
").append(task).append("").append(deadline).append("").append(priority).append("
"); + + Intent intent = new Intent(MainActivity.this, HtmlActivity.class); + intent.putExtra("html_data", htmlBuilder.toString()); //Przekazanie danych HTML do nowej aktywności + startActivity(intent); //Rozpoczęcie nowej aktywności + } +} diff --git a/ToDoApp2/app/src/main/java/com/example/todoapp2/TaskViewModel.java b/ToDoApp2/app/src/main/java/com/example/todoapp2/TaskViewModel.java new file mode 100644 index 0000000..45f7b0d --- /dev/null +++ b/ToDoApp2/app/src/main/java/com/example/todoapp2/TaskViewModel.java @@ -0,0 +1,52 @@ +package com.example.todoapp2; + +import android.app.Application; +import androidx.annotation.NonNull; +import androidx.lifecycle.AndroidViewModel; +import androidx.lifecycle.LiveData; +import androidx.lifecycle.MutableLiveData; + +import java.util.List; + +public class TaskViewModel extends AndroidViewModel { + private final MutableLiveData> tasks; + private final DatabaseHelper db; + + public TaskViewModel(@NonNull Application application) { + super(application); + db = new DatabaseHelper(application); //Inicjalizacja bazy danych + tasks = new MutableLiveData<>(); + removeExpiredTasks(); //Usuwanie przeterminowanych zadań + loadTasks(); //Załadowanie zadań z bazy danych + } + + private void loadTasks() { + tasks.postValue(db.getAllTasks()); //Ustawienie wartości LiveData na podstawie danych z bazy + } + + public LiveData> getTasks() { + return tasks; //Zwrócenie LiveData z zadaniami + } + + public boolean addTask(String task, String deadline, String priority) { + boolean result = db.addTask(task, deadline, priority); //Dodanie zadania do bazy danych + if (result) { + removeExpiredTasks(); //Usuwanie przeterminowanych zadań + loadTasks(); //Załadowanie zadań po dodaniu nowego + } + return result; + } + + public boolean removeTask(String task) { + boolean result = db.removeTask(task); //Usunięcie zadania z bazy danych + if (result) { + removeExpiredTasks(); //Usuwanie przeterminowanych zadań + loadTasks(); //Załadowanie zadań po usunięciu + } + return result; + } + + private void removeExpiredTasks() { + db.removeExpiredTasks(); //Usunięcie przeterminowanych zadań z bazy danych + } +} diff --git a/ToDoApp2/app/src/main/res/drawable-v24/ic_launcher_foreground.xml b/ToDoApp2/app/src/main/res/drawable-v24/ic_launcher_foreground.xml new file mode 100644 index 0000000..2b068d1 --- /dev/null +++ b/ToDoApp2/app/src/main/res/drawable-v24/ic_launcher_foreground.xml @@ -0,0 +1,30 @@ + + + + + + + + + + + \ No newline at end of file diff --git a/ToDoApp2/app/src/main/res/drawable/ic_launcher_background.xml b/ToDoApp2/app/src/main/res/drawable/ic_launcher_background.xml new file mode 100644 index 0000000..07d5da9 --- /dev/null +++ b/ToDoApp2/app/src/main/res/drawable/ic_launcher_background.xml @@ -0,0 +1,170 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/ToDoApp2/app/src/main/res/layout/activity_html.xml b/ToDoApp2/app/src/main/res/layout/activity_html.xml new file mode 100644 index 0000000..70dd264 --- /dev/null +++ b/ToDoApp2/app/src/main/res/layout/activity_html.xml @@ -0,0 +1,11 @@ + + + + + diff --git a/ToDoApp2/app/src/main/res/layout/activity_main.xml b/ToDoApp2/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000..7d1558a --- /dev/null +++ b/ToDoApp2/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,100 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/ToDoApp2/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml b/ToDoApp2/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml new file mode 100644 index 0000000..6f3b755 --- /dev/null +++ b/ToDoApp2/app/src/main/res/mipmap-anydpi-v26/ic_launcher.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/ToDoApp2/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml b/ToDoApp2/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml new file mode 100644 index 0000000..6f3b755 --- /dev/null +++ b/ToDoApp2/app/src/main/res/mipmap-anydpi-v26/ic_launcher_round.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/ToDoApp2/app/src/main/res/mipmap-hdpi/ic_launcher.webp b/ToDoApp2/app/src/main/res/mipmap-hdpi/ic_launcher.webp new file mode 100644 index 0000000..c209e78 Binary files /dev/null and b/ToDoApp2/app/src/main/res/mipmap-hdpi/ic_launcher.webp differ diff --git a/ToDoApp2/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp b/ToDoApp2/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp new file mode 100644 index 0000000..b2dfe3d Binary files /dev/null and b/ToDoApp2/app/src/main/res/mipmap-hdpi/ic_launcher_round.webp differ diff --git a/ToDoApp2/app/src/main/res/mipmap-mdpi/ic_launcher.webp b/ToDoApp2/app/src/main/res/mipmap-mdpi/ic_launcher.webp new file mode 100644 index 0000000..4f0f1d6 Binary files /dev/null and b/ToDoApp2/app/src/main/res/mipmap-mdpi/ic_launcher.webp differ diff --git a/ToDoApp2/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp b/ToDoApp2/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp new file mode 100644 index 0000000..62b611d Binary files /dev/null and b/ToDoApp2/app/src/main/res/mipmap-mdpi/ic_launcher_round.webp differ diff --git a/ToDoApp2/app/src/main/res/mipmap-xhdpi/ic_launcher.webp b/ToDoApp2/app/src/main/res/mipmap-xhdpi/ic_launcher.webp new file mode 100644 index 0000000..948a307 Binary files /dev/null and b/ToDoApp2/app/src/main/res/mipmap-xhdpi/ic_launcher.webp differ diff --git a/ToDoApp2/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp b/ToDoApp2/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp new file mode 100644 index 0000000..1b9a695 Binary files /dev/null and b/ToDoApp2/app/src/main/res/mipmap-xhdpi/ic_launcher_round.webp differ diff --git a/ToDoApp2/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp b/ToDoApp2/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp new file mode 100644 index 0000000..28d4b77 Binary files /dev/null and b/ToDoApp2/app/src/main/res/mipmap-xxhdpi/ic_launcher.webp differ diff --git a/ToDoApp2/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp b/ToDoApp2/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp new file mode 100644 index 0000000..9287f50 Binary files /dev/null and b/ToDoApp2/app/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp differ diff --git a/ToDoApp2/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp b/ToDoApp2/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp new file mode 100644 index 0000000..aa7d642 Binary files /dev/null and b/ToDoApp2/app/src/main/res/mipmap-xxxhdpi/ic_launcher.webp differ diff --git a/ToDoApp2/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp b/ToDoApp2/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp new file mode 100644 index 0000000..9126ae3 Binary files /dev/null and b/ToDoApp2/app/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp differ diff --git a/ToDoApp2/app/src/main/res/values-night/themes.xml b/ToDoApp2/app/src/main/res/values-night/themes.xml new file mode 100644 index 0000000..4838a33 --- /dev/null +++ b/ToDoApp2/app/src/main/res/values-night/themes.xml @@ -0,0 +1,7 @@ + + + + \ No newline at end of file diff --git a/ToDoApp2/app/src/main/res/values/colors.xml b/ToDoApp2/app/src/main/res/values/colors.xml new file mode 100644 index 0000000..57e3e12 --- /dev/null +++ b/ToDoApp2/app/src/main/res/values/colors.xml @@ -0,0 +1,9 @@ + + + #6200EE + #BB86FC + #3700B3 + #03DAC5 + #000000 + #FFFFFF + \ No newline at end of file diff --git a/ToDoApp2/app/src/main/res/values/strings.xml b/ToDoApp2/app/src/main/res/values/strings.xml new file mode 100644 index 0000000..0a3774b --- /dev/null +++ b/ToDoApp2/app/src/main/res/values/strings.xml @@ -0,0 +1,8 @@ + + ToDoApp + + Low + Medium + High + + \ No newline at end of file diff --git a/ToDoApp2/app/src/main/res/values/themes.xml b/ToDoApp2/app/src/main/res/values/themes.xml new file mode 100644 index 0000000..2675473 --- /dev/null +++ b/ToDoApp2/app/src/main/res/values/themes.xml @@ -0,0 +1,17 @@ + + + + +