diff --git a/android/app/src/main/AndroidManifest.xml b/android/app/src/main/AndroidManifest.xml index e3792160..6be7f747 100644 --- a/android/app/src/main/AndroidManifest.xml +++ b/android/app/src/main/AndroidManifest.xml @@ -65,13 +65,13 @@ - - - - - - - - + + + + + + + + diff --git a/android/app/src/main/kotlin/com/ccextractor/taskwarrior/MainActivity.kt b/android/app/src/main/kotlin/com/ccextractor/taskwarrior/MainActivity.kt deleted file mode 100644 index d2e8d9ba..00000000 --- a/android/app/src/main/kotlin/com/ccextractor/taskwarrior/MainActivity.kt +++ /dev/null @@ -1,5 +0,0 @@ -package com.ccextractor.taskwarrior - -import io.flutter.embedding.android.FlutterActivity - -class MainActivity: FlutterActivity() diff --git a/android/app/src/main/kotlin/com/example/taskwarrior/MainActivity.kt b/android/app/src/main/kotlin/com/ccextractor/taskwarriorflutter/MainActivity.kt similarity index 69% rename from android/app/src/main/kotlin/com/example/taskwarrior/MainActivity.kt rename to android/app/src/main/kotlin/com/ccextractor/taskwarriorflutter/MainActivity.kt index a72bf0d6..0316675c 100644 --- a/android/app/src/main/kotlin/com/example/taskwarrior/MainActivity.kt +++ b/android/app/src/main/kotlin/com/ccextractor/taskwarriorflutter/MainActivity.kt @@ -2,5 +2,4 @@ package com.ccextractor.taskwarriorflutter import io.flutter.embedding.android.FlutterActivity -class MainActivity: FlutterActivity() { -} +class MainActivity: FlutterActivity() diff --git a/android/app/src/main/kotlin/com/ccextractor/taskwarriorflutter/TaskWarriorWidgetProvider.kt b/android/app/src/main/kotlin/com/ccextractor/taskwarriorflutter/TaskWarriorWidgetProvider.kt new file mode 100644 index 00000000..5662cd2a --- /dev/null +++ b/android/app/src/main/kotlin/com/ccextractor/taskwarriorflutter/TaskWarriorWidgetProvider.kt @@ -0,0 +1,210 @@ +package com.ccextractor.taskwarriorflutter +import android.annotation.TargetApi +import android.appwidget.AppWidgetManager +import android.content.Context +import android.net.Uri +import android.widget.RemoteViews +import es.antonborri.home_widget.HomeWidgetBackgroundIntent +import es.antonborri.home_widget.HomeWidgetLaunchIntent +import es.antonborri.home_widget.HomeWidgetProvider +import es.antonborri.home_widget.HomeWidgetPlugin +import org.json.JSONException +import android.content.Intent +import android.widget.RemoteViewsService +import org.json.JSONObject +import org.json.JSONArray as OrgJSONArray +import android.os.Bundle +import android.app.PendingIntent +import android.appwidget.AppWidgetProvider +import android.os.Build + + +@TargetApi(Build.VERSION_CODES.CUPCAKE) +class TaskWarriorWidgetProvider : AppWidgetProvider() { + + override fun onReceive(context: Context, intent: Intent) { + // val myaction = intent.action + if (intent.action == "TASK_ACTION") { + val extras = intent.extras + if(extras!=null){ + val uuid = extras.getString("uuid")?:"" + val add_task = extras.getString("launchedFor") + val host = if(add_task == "ADD_TASK"){context.getString(R.string.app_widget_add_clicked_uri)}else{context.getString(R.string.app_widget_card_clicked_uri)} + val launchIntent = Intent(context, MainActivity::class.java).apply { + action = context.getString(R.string.app_widget_launch_action) + data = Uri.parse("$host?uuid=$uuid") + flags = Intent. FLAG_ACTIVITY_NEW_TASK + context?.startActivity(this) + } + // HomeWidgetLaunchIntent.getActivity(context, MainActivity::class.java, Uri.parse("TaskWarrior://taskView?taskId=$uuid")) + } + } + super.onReceive(context, intent) + } + fun getLayoutId(context: Context) : Int{ + val sharedPrefs = HomeWidgetPlugin.getData(context) + val theme = sharedPrefs.getString("themeMode", "") + val layoutId = if (theme.equals("dark")) { + R.layout.taskwarrior_layout_dark // Define a dark mode layout in your resources + } else { + R.layout.taskwarrior_layout + } + return layoutId + } + @TargetApi(Build.VERSION_CODES.DONUT) + override fun onUpdate(context: Context, appWidgetManager: AppWidgetManager, appWidgetIds: IntArray) { + appWidgetIds.forEach { widgetId -> + val sharedPrefs = HomeWidgetPlugin.getData(context) + val tasks = sharedPrefs.getString("tasks", "") + val intent = Intent(context, ListViewRemoteViewsService::class.java).apply { + putExtra("tasksJsonString", tasks) + data = Uri.parse(toUri(Intent.URI_INTENT_SCHEME)) + } + val views = RemoteViews(context.packageName, getLayoutId(context)).apply { + val pendingIntent: PendingIntent = HomeWidgetLaunchIntent.getActivity( + context, + MainActivity::class.java + ) + setOnClickPendingIntent(R.id.logo, pendingIntent) + val intent_for_add = Intent(context, TaskWarriorWidgetProvider::class.java).apply { + setAction("TASK_ACTION") + data=Uri.parse(toUri(Intent.URI_INTENT_SCHEME)) + putExtra("launchedFor", "ADD_TASK") + } + val pendingIntentAdd: PendingIntent = PendingIntent.getBroadcast( + context, + 0, // requestCode, can be any unique integer + intent_for_add, + PendingIntent.FLAG_MUTABLE or PendingIntent.FLAG_UPDATE_CURRENT or Intent.FILL_IN_COMPONENT // Use appropriate flags + ) + setOnClickPendingIntent(R.id.add_btn, pendingIntentAdd) + setRemoteAdapter(R.id.list_view, intent) + } + + val clickPendingIntent: PendingIntent = Intent( + context, + TaskWarriorWidgetProvider::class.java + ).run { + setAction("TASK_ACTION") + setIdentifier("uuid") + data = Uri.parse(toUri(Intent.URI_INTENT_SCHEME)) + + PendingIntent.getBroadcast( + context, + 0, + this, + PendingIntent.FLAG_MUTABLE or PendingIntent.FLAG_UPDATE_CURRENT or Intent.FILL_IN_COMPONENT + ) + } + + views.setPendingIntentTemplate(R.id.list_view, clickPendingIntent) + appWidgetManager.updateAppWidget(widgetId, views) + } + super.onUpdate(context, appWidgetManager, appWidgetIds) + } + } +class ListViewRemoteViewsFactory( + private val context: Context, + private val tasksJsonString: String? +) : RemoteViewsService.RemoteViewsFactory { + + private val tasks = mutableListOf() + + override fun onCreate() {} + + override fun onDataSetChanged() { + if (tasksJsonString != null) { + try { + val jsonArray = OrgJSONArray(tasksJsonString as String) + for (i in 0 until jsonArray.length()) { + tasks.add(Task.fromJson(jsonArray.getJSONObject(i))) + } + } catch (e: JSONException) { + e.printStackTrace() + } + } + } + + override fun onDestroy() {} + + override fun getCount(): Int = tasks.size + + fun getListItemLayoutId(): Int{ + val sharedPrefs = HomeWidgetPlugin.getData(context) + val theme = sharedPrefs.getString("themeMode", "") + val layoutId = if (theme.equals("dark")) { + R.layout.listitem_layout_dark // Define a dark mode layout in your resources + } else { + R.layout.listitem_layout + } + return layoutId + } + fun getListItemLayoutIdForR1(): Int{ + val sharedPrefs = HomeWidgetPlugin.getData(context) + val theme = sharedPrefs.getString("themeMode", "") + val layoutId = if (theme.equals("dark")) { + R.layout.no_tasks_found_li_dark // Define a dark mode layout in your resources + } else { + R.layout.no_tasks_found_li + } + return layoutId + } + fun getDotIdByPriority(p: String) : Int{ + println("PRIORITY: "+p) + if(p.equals("L")) return R.drawable.low_priority_dot + if(p.equals("M")) return R.drawable.mid_priority_dot + if(p.equals("H")) return R.drawable.high_priority_dot + return R.drawable.no_priority_dot + } + + override fun getViewAt(position: Int): RemoteViews { + val task = tasks[position] + if(task.uuid.equals("NO_TASK")) + return RemoteViews(context.packageName, getListItemLayoutIdForR1()).apply { + if(task.priority.equals("1")) + setTextViewText(R.id.tv, "No tasks added yet") + if(task.priority.equals("2")) + setTextViewText(R.id.tv, "Filters applied are hiding all tasks") + } + return RemoteViews(context.packageName, getListItemLayoutId()).apply { + setTextViewText(R.id.todo__title, task.title) + setImageViewResource(R.id.dot, getDotIdByPriority(task.priority)) + val a = Intent().apply { + + Bundle().also { extras -> + extras.putString("action", "show_task") + extras.putString("uuid", tasks[position].uuid) + putExtras(extras) + } + + } + setOnClickFillInIntent(R.id.list_item_container,a) + } + + } + override fun getLoadingView(): RemoteViews? = null + + override fun getViewTypeCount(): Int = 1 + + override fun getItemId(position: Int): Long = position.toLong() + + override fun hasStableIds(): Boolean = true +} +class ListViewRemoteViewsService : RemoteViewsService() { + + override fun onGetViewFactory(intent: Intent): RemoteViewsFactory { + val tasksJsonString = intent.getStringExtra("tasksJsonString") + return ListViewRemoteViewsFactory(applicationContext, tasksJsonString) + } +} +data class Task(val title: String, val urgencyLevel: String,val uuid:String, val priority: String) { + companion object { + fun fromJson(json: JSONObject): Task { + val title = json.optString("description", "") + val urgencyLevel = json.optString("urgency", "") + val uuid = json.optString("uuid","") + val priority = json.optString("priority", "") + return Task(title, urgencyLevel, uuid, priority) + } + } +} \ No newline at end of file diff --git a/android/app/src/main/kotlin/com/example/taskwarrior/TaskWarriorWidgetProvider.kt b/android/app/src/main/kotlin/com/example/taskwarrior/TaskWarriorWidgetProvider.kt deleted file mode 100644 index 0e04c4f5..00000000 --- a/android/app/src/main/kotlin/com/example/taskwarrior/TaskWarriorWidgetProvider.kt +++ /dev/null @@ -1,147 +0,0 @@ -package com.ccextractor.taskwarriorflutter -import android.util.Log -import android.appwidget.AppWidgetManager -import android.content.Context -import android.content.SharedPreferences -import android.graphics.BitmapFactory -import android.net.Uri -import android.view.View -import android.widget.RemoteViews -import es.antonborri.home_widget.HomeWidgetBackgroundIntent -import es.antonborri.home_widget.HomeWidgetLaunchIntent -import es.antonborri.home_widget.HomeWidgetProvider -import es.antonborri.home_widget.HomeWidgetPlugin -import android.content.BroadcastReceiver -import org.json.JSONException -import android.content.Intent -import android.widget.RemoteViewsService -import org.json.JSONObject -import org.json.JSONArray as OrgJSONArray -import com.ccextractor.taskwarriorflutter.MainActivity -import com.ccextractor.taskwarriorflutter.R -import android.os.Bundle -import android.app.PendingIntent -import android.appwidget.AppWidgetProvider - - -class TaskWarriorWidgetProvider : AppWidgetProvider() { - - override fun onReceive(context: Context, intent: Intent) { - // val myaction = intent.action - if (intent.action == "TASK_ACTION") { - val extras = intent.extras - if(extras!=null){ - val uuid = extras.getString("uuid")?:"" - val launchIntent = Intent(context, MainActivity::class.java).apply { - action = context.getString(R.string.app_widget_launch_action) - data = Uri.parse("${context.getString(R.string.app_widget_card_clicked_uri)}?uuid=$uuid") - flags = Intent. FLAG_ACTIVITY_NEW_TASK - context?.startActivity(this) - } - // HomeWidgetLaunchIntent.getActivity(context, MainActivity::class.java, Uri.parse("TaskWarrior://taskView?taskId=$uuid")) - } - } - super.onReceive(context, intent) - } - override fun onUpdate(context: Context, appWidgetManager: AppWidgetManager, appWidgetIds: IntArray) { - appWidgetIds.forEach { widgetId -> - val sharedPrefs = HomeWidgetPlugin.getData(context) - val tasks = sharedPrefs.getString("tasks", "") - val intent = Intent(context,ListViewRemoteViewsService::class.java).apply { - putExtra("tasksJsonString", tasks) - data = Uri.parse(toUri(Intent.URI_INTENT_SCHEME)) - } - val views = RemoteViews(context.packageName, R.layout.taskwarrior_layout).apply { - - val pendingIntent = HomeWidgetLaunchIntent.getActivity( - context, - MainActivity::class.java) - setOnClickPendingIntent(R.id.container_layout, pendingIntent) - setRemoteAdapter(R.id.list_view, intent) - - } - - val clickPendingIntent: PendingIntent = Intent( - context, - TaskWarriorWidgetProvider::class.java).run { - setAction("TASK_ACTION") - setIdentifier("uuid") - data = Uri.parse(toUri(Intent.URI_INTENT_SCHEME)) - - PendingIntent.getBroadcast(context,0,this,PendingIntent.FLAG_MUTABLE or PendingIntent.FLAG_UPDATE_CURRENT or Intent.FILL_IN_COMPONENT ) - } - views.setPendingIntentTemplate(R.id.list_view,clickPendingIntent) - appWidgetManager.updateAppWidget(widgetId, views) - } - super.onUpdate(context, appWidgetManager, appWidgetIds) - } - } -class ListViewRemoteViewsFactory( - private val context: Context, - private val tasksJsonString: String? -) : RemoteViewsService.RemoteViewsFactory { - - private val tasks = mutableListOf() - - override fun onCreate() {} - - override fun onDataSetChanged() { - if (tasksJsonString != null) { - try { - val jsonArray = OrgJSONArray(tasksJsonString as String) - for (i in 0 until jsonArray.length()) { - tasks.add(Task.fromJson(jsonArray.getJSONObject(i))) - } - } catch (e: JSONException) { - e.printStackTrace() - } - } - } - - override fun onDestroy() {} - - override fun getCount(): Int = tasks.size - - override fun getViewAt(position: Int): RemoteViews { - val task = tasks[position] - return RemoteViews(context.packageName, R.layout.listitem_layout).apply { - setTextViewText(R.id.title_textview, task.title) - setTextViewText(R.id.urgency_textview, task.urgencyLevel) - val a = Intent().apply { - - Bundle().also { extras -> - extras.putString("uuid", "${tasks[position].uuid}") - putExtras(extras) - } - - } - setOnClickFillInIntent(R.id.list_item_container,a) - - } - - } - override fun getLoadingView(): RemoteViews? = null - - override fun getViewTypeCount(): Int = 1 - - override fun getItemId(position: Int): Long = position.toLong() - - override fun hasStableIds(): Boolean = true -} -class ListViewRemoteViewsService : RemoteViewsService() { - - override fun onGetViewFactory(intent: Intent): RemoteViewsFactory { - val tasksJsonString = intent.getStringExtra("tasksJsonString") - return ListViewRemoteViewsFactory(applicationContext, tasksJsonString) - } -} -data class Task(val title: String, val urgencyLevel: String,val uuid:String) { - companion object { - fun fromJson(json: JSONObject): Task { - val title = json.optString("description", "") - val urgencyLevel = json.optString("urgency", "") - val uuid = json.optString("uuid","") - return Task(title, urgencyLevel,uuid) - } - } -} \ No newline at end of file diff --git a/android/app/src/main/res/drawable/add.xml b/android/app/src/main/res/drawable/add.xml new file mode 100644 index 00000000..c322ed1c --- /dev/null +++ b/android/app/src/main/res/drawable/add.xml @@ -0,0 +1,10 @@ + + + diff --git a/android/app/src/main/res/drawable/add_dark.xml b/android/app/src/main/res/drawable/add_dark.xml new file mode 100644 index 00000000..74251df6 --- /dev/null +++ b/android/app/src/main/res/drawable/add_dark.xml @@ -0,0 +1,10 @@ + + + diff --git a/android/app/src/main/res/drawable/bg_button_add.xml b/android/app/src/main/res/drawable/bg_button_add.xml new file mode 100644 index 00000000..79c8ede0 --- /dev/null +++ b/android/app/src/main/res/drawable/bg_button_add.xml @@ -0,0 +1,6 @@ + + + + + + diff --git a/android/app/src/main/res/drawable/bg_button_add_dark.xml b/android/app/src/main/res/drawable/bg_button_add_dark.xml new file mode 100644 index 00000000..4b97c721 --- /dev/null +++ b/android/app/src/main/res/drawable/bg_button_add_dark.xml @@ -0,0 +1,6 @@ + + + + + + diff --git a/android/app/src/main/res/drawable/border_style.xml b/android/app/src/main/res/drawable/border_style.xml index 34b6ad89..a760078d 100644 --- a/android/app/src/main/res/drawable/border_style.xml +++ b/android/app/src/main/res/drawable/border_style.xml @@ -1,7 +1,16 @@ - - - - - + + + + + + + + + + \ No newline at end of file diff --git a/android/app/src/main/res/drawable/border_style_dark.xml b/android/app/src/main/res/drawable/border_style_dark.xml new file mode 100644 index 00000000..b492555c --- /dev/null +++ b/android/app/src/main/res/drawable/border_style_dark.xml @@ -0,0 +1,16 @@ + + + + + + + + + + \ No newline at end of file diff --git a/android/app/src/main/res/drawable/down_btn_icon.xml b/android/app/src/main/res/drawable/down_btn_icon.xml new file mode 100644 index 00000000..bf9aa923 --- /dev/null +++ b/android/app/src/main/res/drawable/down_btn_icon.xml @@ -0,0 +1,10 @@ + + + diff --git a/android/app/src/main/res/drawable/down_btn_icon_dark.xml b/android/app/src/main/res/drawable/down_btn_icon_dark.xml new file mode 100644 index 00000000..4a2f4f6b --- /dev/null +++ b/android/app/src/main/res/drawable/down_btn_icon_dark.xml @@ -0,0 +1,10 @@ + + + diff --git a/android/app/src/main/res/drawable/high_priority_dot.xml b/android/app/src/main/res/drawable/high_priority_dot.xml new file mode 100644 index 00000000..2e6506e3 --- /dev/null +++ b/android/app/src/main/res/drawable/high_priority_dot.xml @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + + + + diff --git a/android/app/src/main/res/drawable/low_priority_dot.xml b/android/app/src/main/res/drawable/low_priority_dot.xml new file mode 100644 index 00000000..baf70648 --- /dev/null +++ b/android/app/src/main/res/drawable/low_priority_dot.xml @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + + + + diff --git a/android/app/src/main/res/drawable/mid_priority_dot.xml b/android/app/src/main/res/drawable/mid_priority_dot.xml new file mode 100644 index 00000000..6407db39 --- /dev/null +++ b/android/app/src/main/res/drawable/mid_priority_dot.xml @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + + + + diff --git a/android/app/src/main/res/drawable/no_priority_dot.xml b/android/app/src/main/res/drawable/no_priority_dot.xml new file mode 100644 index 00000000..e656e3d6 --- /dev/null +++ b/android/app/src/main/res/drawable/no_priority_dot.xml @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + + + + diff --git a/android/app/src/main/res/drawable/preview.png b/android/app/src/main/res/drawable/preview.png index 3eeeecd6..5f32f708 100644 Binary files a/android/app/src/main/res/drawable/preview.png and b/android/app/src/main/res/drawable/preview.png differ diff --git a/android/app/src/main/res/drawable/taskwarrior_widget_icon.png b/android/app/src/main/res/drawable/taskwarrior_widget_icon.png new file mode 100644 index 00000000..06fcb3df Binary files /dev/null and b/android/app/src/main/res/drawable/taskwarrior_widget_icon.png differ diff --git a/android/app/src/main/res/drawable/taskwarrior_widget_icon_dark.png b/android/app/src/main/res/drawable/taskwarrior_widget_icon_dark.png new file mode 100644 index 00000000..f28c15bf Binary files /dev/null and b/android/app/src/main/res/drawable/taskwarrior_widget_icon_dark.png differ diff --git a/android/app/src/main/res/layout/listitem_layout.xml b/android/app/src/main/res/layout/listitem_layout.xml index 8beba106..a64d2523 100644 --- a/android/app/src/main/res/layout/listitem_layout.xml +++ b/android/app/src/main/res/layout/listitem_layout.xml @@ -2,30 +2,25 @@ + android:layout_height="match_parent" + android:orientation="horizontal"> - - + - - - + android:scrollHorizontally="true" + android:ellipsize="end" + android:maxLines="1" + android:id="@+id/todo__title" + android:layout_width="fill_parent" + android:layout_height="match_parent" + android:gravity="center_vertical" + android:paddingHorizontal="5dp" + android:textColor="@color/fg"/> + \ No newline at end of file diff --git a/android/app/src/main/res/layout/listitem_layout_dark.xml b/android/app/src/main/res/layout/listitem_layout_dark.xml new file mode 100644 index 00000000..7c221b2c --- /dev/null +++ b/android/app/src/main/res/layout/listitem_layout_dark.xml @@ -0,0 +1,27 @@ + + + + + + + + \ No newline at end of file diff --git a/android/app/src/main/res/layout/no_tasks_found_li.xml b/android/app/src/main/res/layout/no_tasks_found_li.xml new file mode 100644 index 00000000..32246c84 --- /dev/null +++ b/android/app/src/main/res/layout/no_tasks_found_li.xml @@ -0,0 +1,15 @@ + + + + + \ No newline at end of file diff --git a/android/app/src/main/res/layout/no_tasks_found_li_dark.xml b/android/app/src/main/res/layout/no_tasks_found_li_dark.xml new file mode 100644 index 00000000..bbc37495 --- /dev/null +++ b/android/app/src/main/res/layout/no_tasks_found_li_dark.xml @@ -0,0 +1,15 @@ + + + + + \ No newline at end of file diff --git a/android/app/src/main/res/layout/taskwarrior_layout.xml b/android/app/src/main/res/layout/taskwarrior_layout.xml index 63137f09..7f40a80b 100644 --- a/android/app/src/main/res/layout/taskwarrior_layout.xml +++ b/android/app/src/main/res/layout/taskwarrior_layout.xml @@ -1,43 +1,66 @@ - - - - - - - - - - - + > + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/android/app/src/main/res/layout/taskwarrior_layout_dark.xml b/android/app/src/main/res/layout/taskwarrior_layout_dark.xml new file mode 100644 index 00000000..c310fdff --- /dev/null +++ b/android/app/src/main/res/layout/taskwarrior_layout_dark.xml @@ -0,0 +1,65 @@ + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/android/app/src/main/res/values/colors.xml b/android/app/src/main/res/values/colors.xml index b2bffa8d..22648051 100644 --- a/android/app/src/main/res/values/colors.xml +++ b/android/app/src/main/res/values/colors.xml @@ -1,6 +1,20 @@ - #FFE1F5FE - #FF81D4FA - #FF039BE5 - #FF01579B + #000000 + #FFFFFF + #000 + #fff + #000 + #4D4D4D + #efefef + #FFFFFF + #000000 + #FFFFFF + #2C2C2C + #FFFFFF + #787878 + #4D4D4D + #FF0000 + #FFF200 + #00FF42 + #A2A2A2 \ No newline at end of file diff --git a/android/app/src/main/res/values/dimens.xml b/android/app/src/main/res/values/dimens.xml index 4db8c590..27da692e 100644 --- a/android/app/src/main/res/values/dimens.xml +++ b/android/app/src/main/res/values/dimens.xml @@ -6,5 +6,8 @@ Refer to App Widget Documentation for margin information http://developer.android.com/guide/topics/appwidgets/index.html#CreatingLayout --> 0dp - + 40dp + 15dp + 60dp + 40dp \ No newline at end of file diff --git a/android/app/src/main/res/values/strings.xml b/android/app/src/main/res/values/strings.xml index 1989514f..ff9b9745 100644 --- a/android/app/src/main/res/values/strings.xml +++ b/android/app/src/main/res/values/strings.xml @@ -7,8 +7,11 @@ imageData es.antonborri.home_widget.action.LAUNCH taskwarriorappwidget://cardclicked + taskwarriorappwidget://addclicked This widget shows pending tasks from TaskWarrior app TaskWarrior Add widget - + Task List + add_task + No Tasks available \ No newline at end of file diff --git a/android/app/src/main/res/xml/taskwarriorconfig.xml b/android/app/src/main/res/xml/taskwarriorconfig.xml index e3aca793..1a5d2c7f 100644 --- a/android/app/src/main/res/xml/taskwarriorconfig.xml +++ b/android/app/src/main/res/xml/taskwarriorconfig.xml @@ -1,8 +1,8 @@ > getUniqueProjects() async { @@ -552,6 +571,10 @@ class HomeController extends GetxController { void initLanguageAndDarkMode() { isDarkModeOn.value = AppSettings.isDarkMode; selectedLanguage.value = AppSettings.selectedLanguage; + HomeWidget.saveWidgetData("themeMode", AppSettings.isDarkMode ? "dark" : "light"); + HomeWidget.updateWidget( + androidName: "TaskWarriorWidgetProvider" + ); // print("called and value is${isDarkModeOn.value}"); } @@ -645,21 +668,22 @@ class HomeController extends GetxController { }, ); } - late RxString uuid = "".obs; late RxBool isHomeWidgetTaskTapped = false.obs; void handleHomeWidgetClicked() async { - Uri? myUri = await HomeWidget.initiallyLaunchedFromHomeWidget(); - if (myUri != null) { - if (myUri.host == "cardclicked") { - if (myUri.queryParameters["uuid"] != null) { - uuid.value = myUri.queryParameters["uuid"] as String; + Uri? uri = await HomeWidget.initiallyLaunchedFromHomeWidget(); + if (uri != null) { + if (uri.host == "cardclicked") { + if (uri.queryParameters["uuid"] != null) { + uuid.value = uri.queryParameters["uuid"] as String; isHomeWidgetTaskTapped.value = true; Future.delayed(Duration.zero, () { Get.toNamed(Routes.DETAIL_ROUTE, arguments: ["uuid", uuid.value]); }); } + }else if(uri.host == "addclicked"){ + showAddDialogAfterWidgetClick(); } } HomeWidget.widgetClicked.listen((uri) async { @@ -671,8 +695,15 @@ class HomeController extends GetxController { } debugPrint('uuid is $uuid'); Get.toNamed(Routes.DETAIL_ROUTE, arguments: ["uuid", uuid.value]); + }else if(uri.host == "addclicked"){ + showAddDialogAfterWidgetClick(); } } + }); } + void showAddDialogAfterWidgetClick() { + Widget showDialog = taskchampion.value ? AddTaskToTaskcBottomSheet(homeController: this) : AddTaskBottomSheet(homeController: this); + Get.dialog(showDialog); + } } diff --git a/lib/app/modules/home/controllers/widget.controller.dart b/lib/app/modules/home/controllers/widget.controller.dart index a618564f..61ca0e47 100644 --- a/lib/app/modules/home/controllers/widget.controller.dart +++ b/lib/app/modules/home/controllers/widget.controller.dart @@ -17,12 +17,9 @@ import 'package:taskwarrior/app/utils/taskfunctions/urgency.dart'; // import 'package:taskwarrior/widgets/taskfunctions/datetime_differences.dart'; class WidgetController extends GetxController { - final BuildContext? context; - WidgetController(this.context); final HomeController storageWidget = Get.find(); late Storage storage; - late final Filters filters; - RxList taskData = [].obs; // Use RxList for observable list + late final Filters filters; // Use RxList for observable list List dailyBurnDown = []; Directory? baseDirectory; RxList allData = [].obs; // Use RxList for observable list @@ -33,7 +30,6 @@ class WidgetController extends GetxController { // storageWidget = StorageWidget.of(context!); // Use Get.context from GetX // var currentProfile = ProfilesWidget.of(context!).currentProfile; var currentProfile = Get.find().currentProfile.value; - baseDirectory = Get.find().baseDirectory(); storage = Storage(Directory('${baseDirectory!.path}/profiles/$currentProfile')); @@ -41,30 +37,102 @@ class WidgetController extends GetxController { sendAndUpdate(); } } - Future sendAndUpdate() async { await sendData(); await updateWidget(); } - + Future sendData() async { - int i = 1; + final HomeController taskController = Get.find(); + int lengthBeforeFilters = allData.length; + List tasks = allData; + debugPrint('Tasks: ${tasks.length}, ${taskController.projectFilter}, ${taskController.pendingFilter.value}, ${taskController.selectedSort.value}'); + if (taskController.projectFilter.value != 'All Projects'&&taskController.projectFilter.toString().isNotEmpty) { + tasks = tasks.where((task) => task.project == taskController.projectFilter.value).toList(); + } else { + tasks = List.from(tasks); + } + + // Apply other filters and sorting + tasks.sort((a, b) => a.id!.compareTo(b.id!)); + + tasks = tasks.where((task) { + if (taskController.pendingFilter.value) { + return task.status == 'pending'; + } else { + return task.status == 'completed'; + } + }).toList(); + + tasks = tasks.where((task) { + var tags = task.tags?.toSet() ?? {}; + if (taskController.tagUnion.value) { + if (taskController.selectedTags.isEmpty) { + return true; + } + return taskController.selectedTags.any((tag) => (tag.startsWith('+')) + ? tags.contains(tag.substring(1)) + : !tags.contains(tag.substring(1))); + } else { + return taskController.selectedTags.every((tag) => (tag.startsWith('+')) + ? tags.contains(tag.substring(1)) + : !tags.contains(tag.substring(1))); + } + }).toList(); + + // Apply sorting based on selectedSort + tasks.sort((a, b) { + switch (taskController.selectedSort.value) { + case 'Created+': + return a.entry.compareTo(b.entry); + case 'Created-': + return b.entry.compareTo(a.entry); + case 'Modified+': + return a.modified!.compareTo(b.modified!); + case 'Modified-': + return b.modified!.compareTo(a.modified!); + case 'Due till+': + return a.due!.compareTo(b.due!); + case 'Due till-': + return b.due!.compareTo(a.due!); + case 'Priority-': + return a.priority!.compareTo(b.priority!); + case 'Priority+': + return b.priority!.compareTo(a.priority!); + case 'Project+': + return a.project!.compareTo(b.project!); + case 'Project-': + return b.project!.compareTo(a.project!); + case 'Urgency-': + return b.urgency!.compareTo(a.urgency!); + case 'Urgency+': + return a.urgency!.compareTo(b.urgency!); + default: + return 0; + } + }); List> l = []; - for (var task in allData) { - if (task.status == "pending") { + for (var task in tasks) { l.add({ - "description": "$i.${task.description}", + "description": task.description, "urgency": 'urgencyLevel : ${urgency(task)}', - "uuid": task.uuid + "uuid": task.uuid, + "priority": task.priority ?? "N" }); - i++; - } } - if (l.isEmpty) { + if (l.isEmpty&&lengthBeforeFilters>0) { + l.add({ + "description": "No tasks found because of filter", + "urgency": "urgencyLevel : 0", + "priority": "2", + "uuid": "NO_TASK" + }); + }else if(l.isEmpty&&lengthBeforeFilters==0){ l.add({ - "description": "No tasks added yet.", + "description": "No tasks found", "urgency": "urgencyLevel : 0", - "uuid": "" + "priority": "1", + "uuid": "NO_TASK" }); } await HomeWidget.saveWidgetData("tasks", jsonEncode(l)); diff --git a/lib/app/modules/home/views/add_task_bottom_sheet.dart b/lib/app/modules/home/views/add_task_bottom_sheet.dart index f1ba5200..a1364610 100644 --- a/lib/app/modules/home/views/add_task_bottom_sheet.dart +++ b/lib/app/modules/home/views/add_task_bottom_sheet.dart @@ -467,7 +467,7 @@ class AddTaskBottomSheet extends StatelessWidget { Get.back(); if (Platform.isAndroid) { WidgetController widgetController = - Get.put(WidgetController(context)); + Get.put(WidgetController()); widgetController.fetchAllData(); widgetController.update(); diff --git a/lib/app/modules/home/views/show_tasks.dart b/lib/app/modules/home/views/show_tasks.dart index de45cebe..da694964 100644 --- a/lib/app/modules/home/views/show_tasks.dart +++ b/lib/app/modules/home/views/show_tasks.dart @@ -29,7 +29,6 @@ class TaskViewBuilder extends StatelessWidget { return Obx(() { List tasks = List.from(taskController.tasks); - // Filter tasks based on the selected project if (project != 'All Projects') { tasks = tasks.where((task) => task.project == project).toList(); diff --git a/lib/app/modules/home/views/tasks_builder.dart b/lib/app/modules/home/views/tasks_builder.dart index e0254e67..d17c5875 100644 --- a/lib/app/modules/home/views/tasks_builder.dart +++ b/lib/app/modules/home/views/tasks_builder.dart @@ -218,7 +218,7 @@ class TasksBuilder extends StatelessWidget { } if (Platform.isAndroid) { WidgetController widgetController = - Get.put(WidgetController(context)); + Get.put(WidgetController()); widgetController.fetchAllData(); widgetController.update();