From 944ee3eb67461de2efad22f3dc99854027b383f6 Mon Sep 17 00:00:00 2001 From: Philipp Heckel Date: Sun, 13 Feb 2022 10:47:51 -0500 Subject: [PATCH] Polishing; base URL list properly filled with last topics too --- .../java/io/heckel/ntfy/ui/ShareActivity.kt | 19 +++++++++---------- app/src/main/res/layout/activity_share.xml | 10 +++++----- .../main/res/layout/fragment_share_item.xml | 10 +++++----- 3 files changed, 19 insertions(+), 20 deletions(-) diff --git a/app/src/main/java/io/heckel/ntfy/ui/ShareActivity.kt b/app/src/main/java/io/heckel/ntfy/ui/ShareActivity.kt index 5612f85..04a42ad 100644 --- a/app/src/main/java/io/heckel/ntfy/ui/ShareActivity.kt +++ b/app/src/main/java/io/heckel/ntfy/ui/ShareActivity.kt @@ -27,9 +27,6 @@ class ShareActivity : AppCompatActivity() { // File to share private var fileUri: Uri? = null - // Lazy-loaded things from Repository - private lateinit var baseUrls: List - // Context-dependent things private lateinit var appBaseUrl: String @@ -67,6 +64,7 @@ class ShareActivity : AppCompatActivity() { appBaseUrl = getString(R.string.app_base_url) // UI elements + val root: View = findViewById(R.id.share_root_view) contentText = findViewById(R.id.share_content_text) contentImage = findViewById(R.id.share_content_image) contentFileBox = findViewById(R.id.share_content_file_box) @@ -74,10 +72,10 @@ class ShareActivity : AppCompatActivity() { contentFileIcon = findViewById(R.id.share_content_file_icon) topicText = findViewById(R.id.share_topic_text) baseUrlLayout = findViewById(R.id.share_base_url_layout) - //baseUrlLayout.background = window.background + baseUrlLayout.background = root.background baseUrlLayout.makeEndIconSmaller(resources) // Hack! baseUrlText = findViewById(R.id.share_base_url_text) - //baseUrlText.background = topicText.background + baseUrlText.background = root.background useAnotherServerCheckbox = findViewById(R.id.share_use_another_server_checkbox) lastTopicsList = findViewById(R.id.share_last_topics) progress = findViewById(R.id.share_progress) @@ -117,6 +115,12 @@ class ShareActivity : AppCompatActivity() { .map { topicUrl(it.baseUrl, it.topic) } .subtract(lastShareTopics.toSet()) val suggestedTopics = lastShareTopics.reversed() + subscribedTopics + val baseUrls = suggestedTopics + .mapNotNull { + try { splitTopicUrl(it).first } + catch (_: Exception) { null } + } + .filterNot { it == appBaseUrl } lastTopicsList.adapter = TopicAdapter(suggestedTopics) { topicUrl -> try { val (baseUrl, topic) = splitTopicUrl(topicUrl) @@ -133,11 +137,6 @@ class ShareActivity : AppCompatActivity() { } // Add baseUrl auto-complete behavior - baseUrls = subscriptions - .groupBy { it.baseUrl } - .map { it.key } - .filterNot { it == appBaseUrl } - .sorted() val activity = this@ShareActivity activity.runOnUiThread { initBaseUrlDropdown(baseUrls, baseUrlText, baseUrlLayout) diff --git a/app/src/main/res/layout/activity_share.xml b/app/src/main/res/layout/activity_share.xml index 2bc1850..a37d64d 100644 --- a/app/src/main/res/layout/activity_share.xml +++ b/app/src/main/res/layout/activity_share.xml @@ -7,7 +7,7 @@ + android:orientation="horizontal" android:paddingStart="15dp" android:paddingEnd="15dp" android:paddingTop="10dp" android:paddingBottom="10dp" android:id="@+id/share_root_view"> + app:layout_constraintTop_toTopOf="parent" android:layout_marginStart="1dp"/> + app:layout_constraintTop_toBottomOf="@id/share_content_title" android:layout_marginTop="5dp" android:layout_marginStart="1dp"/> + app:layout_constraintTop_toBottomOf="@id/share_content_file_box" android:layout_marginTop="20dp" android:layout_marginStart="1dp"/> + android:textAppearance="@style/TextAppearance.AppCompat.Medium" + android:textColor="?android:attr/textColorPrimary" android:layout_marginTop="5dp" + app:layout_constraintBottom_toBottomOf="parent" android:layout_marginBottom="5dp" android:layout_marginStart="6dp"/>