diff --git a/app/src/main/java/ani/dantotsu/connections/anilist/AnilistMutations.kt b/app/src/main/java/ani/dantotsu/connections/anilist/AnilistMutations.kt index 88e88e41bf..0ba016bdcb 100644 --- a/app/src/main/java/ani/dantotsu/connections/anilist/AnilistMutations.kt +++ b/app/src/main/java/ani/dantotsu/connections/anilist/AnilistMutations.kt @@ -101,6 +101,14 @@ class AnilistMutations { return errors?.toString() ?: (currContext()?.getString(ani.dantotsu.R.string.success) ?: "Success") } + suspend fun postMessage(userId: Int, text: String, edit: Int? = null,isPrivate: Boolean = false): String { + val encodedText = text.stringSanitizer() + val query = "mutation{SaveMessageActivity(${if (edit != null) "id:$edit," else ""} recipientId:$userId,message:$encodedText,private:$isPrivate){id}}" + val result = executeQuery(query) + val errors = result?.get("errors") + return errors?.toString() + ?: (currContext()?.getString(ani.dantotsu.R.string.success) ?: "Success") + } suspend fun postReply(activityId: Int, text: String, edit: Int? = null ): String { val encodedText = text.stringSanitizer() val query = "mutation{SaveActivityReply(${if (edit != null) "id:$edit," else ""} activityId:$activityId,text:$encodedText){id}}" diff --git a/app/src/main/java/ani/dantotsu/connections/anilist/AnilistQueries.kt b/app/src/main/java/ani/dantotsu/connections/anilist/AnilistQueries.kt index 23ee295a2c..75ab4ee1ee 100644 --- a/app/src/main/java/ani/dantotsu/connections/anilist/AnilistQueries.kt +++ b/app/src/main/java/ani/dantotsu/connections/anilist/AnilistQueries.kt @@ -6,6 +6,7 @@ import ani.dantotsu.checkGenreTime import ani.dantotsu.checkId import ani.dantotsu.connections.anilist.Anilist.authorRoles import ani.dantotsu.connections.anilist.Anilist.executeQuery +import ani.dantotsu.connections.anilist.api.Activity import ani.dantotsu.connections.anilist.api.FeedResponse import ani.dantotsu.connections.anilist.api.FuzzyDate import ani.dantotsu.connections.anilist.api.NotificationResponse @@ -453,13 +454,24 @@ class AnilistQueries { ) if (user.id == Anilist.userid) { anilistActivities.add(0, userToAdd) + } else { list.add(userToAdd) } } } - + if (anilistActivities.isEmpty() && Anilist.token != null){ + anilistActivities.add(0, + User( + Anilist.userid!!, + Anilist.username!!, + Anilist.avatar, + Anilist.bg, + activity = listOf() + ) + ) + } list.addAll(0, anilistActivities) return list.toCollection(ArrayList()) } else return null diff --git a/app/src/main/java/ani/dantotsu/home/status/StatusActivity.kt b/app/src/main/java/ani/dantotsu/home/status/StatusActivity.kt index e37c68a552..7fc0e78bc7 100644 --- a/app/src/main/java/ani/dantotsu/home/status/StatusActivity.kt +++ b/app/src/main/java/ani/dantotsu/home/status/StatusActivity.kt @@ -101,7 +101,7 @@ class StatusActivity : AppCompatActivity(), StoriesCallback { override fun onStoriesStart() { position -= 1 - if (position >= 0) { + if (position >= 0 && activity[position].activity.isNotEmpty()) { val key = "activities" val watchedActivity = PrefManager.getCustomVal>(key, setOf()) val startFrom = findFirstNonMatch(watchedActivity, activity[position].activity ) diff --git a/app/src/main/java/ani/dantotsu/home/status/Stories.kt b/app/src/main/java/ani/dantotsu/home/status/Stories.kt index c8df6d9a71..d65228442a 100644 --- a/app/src/main/java/ani/dantotsu/home/status/Stories.kt +++ b/app/src/main/java/ani/dantotsu/home/status/Stories.kt @@ -5,6 +5,7 @@ import android.content.Context import android.content.Intent import android.content.res.ColorStateList import android.util.AttributeSet +import android.view.Gravity import android.view.LayoutInflater import android.view.MotionEvent import android.view.View @@ -15,6 +16,7 @@ import androidx.core.app.ActivityOptionsCompat import androidx.core.content.ContextCompat import androidx.core.view.ViewCompat import androidx.core.view.isVisible +import androidx.core.widget.NestedScrollView import androidx.fragment.app.FragmentActivity import ani.dantotsu.R import ani.dantotsu.blurImage diff --git a/app/src/main/java/ani/dantotsu/home/status/UserStatusAdapter.kt b/app/src/main/java/ani/dantotsu/home/status/UserStatusAdapter.kt index 5daebcd950..8aa021049e 100644 --- a/app/src/main/java/ani/dantotsu/home/status/UserStatusAdapter.kt +++ b/app/src/main/java/ani/dantotsu/home/status/UserStatusAdapter.kt @@ -15,6 +15,8 @@ import ani.dantotsu.profile.ProfileActivity import ani.dantotsu.profile.User import ani.dantotsu.setAnimation import ani.dantotsu.settings.saving.PrefManager +import ani.dantotsu.snackString +import ani.dantotsu.util.MarkdownCreatorActivity class UserStatusAdapter(private val user: ArrayList) : RecyclerView.Adapter() { @@ -23,6 +25,10 @@ class UserStatusAdapter(private val user: ArrayList) : RecyclerView.ViewHolder(binding.root) { init { itemView.setOnClickListener { + if (user[bindingAdapterPosition].activity.isEmpty()) { + snackString("No activity") + return@setOnClickListener + } StatusActivity.user = user ContextCompat.startActivity( itemView.context, @@ -34,14 +40,23 @@ class UserStatusAdapter(private val user: ArrayList) : ) } itemView.setOnLongClickListener { - ContextCompat.startActivity( - itemView.context, - Intent( + if (user[bindingAdapterPosition].id == Anilist.userid) { + ContextCompat.startActivity( itemView.context, - ProfileActivity::class.java - ).putExtra("userId", user[bindingAdapterPosition].id), - null - ) + Intent(itemView.context, MarkdownCreatorActivity::class.java) + .putExtra("type", "activity"), + null + ) + }else{ + ContextCompat.startActivity( + itemView.context, + Intent( + itemView.context, + ProfileActivity::class.java + ).putExtra("userId", user[bindingAdapterPosition].id), + null + ) + } true } } diff --git a/app/src/main/java/ani/dantotsu/media/CharacterAdapter.kt b/app/src/main/java/ani/dantotsu/media/CharacterAdapter.kt index d97e138d8c..13b8d3bbeb 100644 --- a/app/src/main/java/ani/dantotsu/media/CharacterAdapter.kt +++ b/app/src/main/java/ani/dantotsu/media/CharacterAdapter.kt @@ -9,6 +9,7 @@ import androidx.core.content.ContextCompat import androidx.core.util.Pair import androidx.core.view.ViewCompat import androidx.recyclerview.widget.RecyclerView +import ani.dantotsu.copyToClipboard import ani.dantotsu.databinding.ItemCharacterBinding import ani.dantotsu.loadImage import ani.dantotsu.setAnimation @@ -32,6 +33,9 @@ class CharacterAdapter( binding.itemCompactRelation.text = whitespace binding.itemCompactImage.loadImage(character.image) binding.itemCompactTitle.text = character.name + binding.root.setOnClickListener { + copyToClipboard(character.name ?: "") + } } override fun getItemCount(): Int = characterList.size diff --git a/app/src/main/java/ani/dantotsu/profile/ProfileActivity.kt b/app/src/main/java/ani/dantotsu/profile/ProfileActivity.kt index 6c8c88bcf9..29ac59d44b 100644 --- a/app/src/main/java/ani/dantotsu/profile/ProfileActivity.kt +++ b/app/src/main/java/ani/dantotsu/profile/ProfileActivity.kt @@ -157,15 +157,6 @@ class ProfileActivity : AppCompatActivity(), AppBarLayout.OnOffsetChangedListene true } - R.id.action_create_new_activity -> { - ContextCompat.startActivity( - context, - Intent(context, MarkdownCreatorActivity::class.java) - .putExtra("type", "activity"), - null - ) - true - } else -> false } diff --git a/app/src/main/java/ani/dantotsu/profile/activity/ActivityFragment.kt b/app/src/main/java/ani/dantotsu/profile/activity/ActivityFragment.kt index 78f234d4be..ce647f15a6 100644 --- a/app/src/main/java/ani/dantotsu/profile/activity/ActivityFragment.kt +++ b/app/src/main/java/ani/dantotsu/profile/activity/ActivityFragment.kt @@ -20,6 +20,7 @@ import ani.dantotsu.media.MediaDetailsActivity import ani.dantotsu.navBarHeight import ani.dantotsu.profile.ProfileActivity import ani.dantotsu.setBaseline +import ani.dantotsu.util.MarkdownCreatorActivity import com.xwray.groupie.GroupieAdapter import eu.kanade.tachiyomi.util.system.getSerializableCompat import kotlinx.coroutines.launch @@ -46,6 +47,27 @@ class ActivityFragment : Fragment() { type = arguments?.getSerializableCompat("type") as ActivityType userId = arguments?.getInt("userId") activityId = arguments?.getInt("activityId") + binding.titleBar.visibility = if (type == ActivityType.OTHER_USER) View.VISIBLE else View.GONE + binding.titleText.text = if (userId == Anilist.userid) getString(R.string.create_new_activity) else getString(R.string.write_a_message) + binding.titleImage.setOnClickListener { + if(userId == Anilist.userid) { + ContextCompat.startActivity( + requireContext(), + Intent(context, MarkdownCreatorActivity::class.java) + .putExtra("type", "activity"), + null + ) + } else{ + ContextCompat.startActivity( + requireContext(), + Intent(context, MarkdownCreatorActivity::class.java) + .putExtra("type", "message") + .putExtra("userId", userId), + + null + ) + } + } binding.listRecyclerView.adapter = adapter binding.listRecyclerView.layoutManager = LinearLayoutManager(context) binding.listProgressBar.isVisible = true @@ -53,7 +75,7 @@ class ActivityFragment : Fragment() { binding.feedRefresh.updateLayoutParams { bottomMargin = navBarHeight } - binding.emptyTextView.text = getString(R.string.no_notifications) + binding.emptyTextView.text = getString(R.string.no_activities) lifecycleScope.launch { getList() if (adapter.itemCount == 0) { @@ -87,8 +109,8 @@ class ActivityFragment : Fragment() { private suspend fun getList() { val list = when (type) { - ActivityType.GLOBAL -> getActivities(true) - ActivityType.USER -> getActivities() + ActivityType.GLOBAL -> getActivities(global = true) + ActivityType.USER -> getActivities(filter = true) ActivityType.OTHER_USER -> getActivities(userId = userId) ActivityType.ONE -> getActivities(activityId = activityId) } @@ -99,12 +121,13 @@ class ActivityFragment : Fragment() { global: Boolean = false, userId: Int? = null, activityId: Int? = null, + filter:Boolean = false ): List { val res = Anilist.query.getFeed(userId, global, page, activityId)?.data?.page?.activities page += 1 return res ?.filter { if (Anilist.adult) true else it.media?.isAdult != true } - ?.filterNot { it.recipient?.id != null && it.recipient.id != Anilist.userid } + ?.filterNot { it.recipient?.id != null && it.recipient.id != Anilist.userid && filter } ?: emptyList() } diff --git a/app/src/main/java/ani/dantotsu/profile/activity/ActivityItem.kt b/app/src/main/java/ani/dantotsu/profile/activity/ActivityItem.kt index f7375ddda9..9dd423dab0 100644 --- a/app/src/main/java/ani/dantotsu/profile/activity/ActivityItem.kt +++ b/app/src/main/java/ani/dantotsu/profile/activity/ActivityItem.kt @@ -68,12 +68,10 @@ class ActivityItem( } binding.activityLikeCount.text = (activity.likeCount ?: 0).toString() binding.activityLikeContainer.setOnClickListener { - scope.launch { val res = Anilist.mutation.toggleLike(activity.id, "ACTIVITY") withContext(Dispatchers.Main) { if (res != null) { - if (activity.isLiked == true) { activity.likeCount = activity.likeCount?.minus(1) } else { @@ -89,7 +87,7 @@ class ActivityItem( } } } - binding.activityDelete.isVisible = activity.userId == Anilist.userid + binding.activityDelete.isVisible = activity.userId == Anilist.userid || activity.messenger?.id == Anilist.userid binding.activityDelete.setOnClickListener { scope.launch { val res = Anilist.mutation.deleteActivity(activity.id) @@ -109,6 +107,7 @@ class ActivityItem( val banner = activity.media?.bannerImage binding.activityContent.visibility = View.GONE binding.activityBannerContainer.visibility = View.VISIBLE + binding.activityPrivate.visibility = View.GONE binding.activityMediaName.text = activity.media?.title?.userPreferred val activityText = "${activity.user!!.name} ${activity.status} ${ activity.progress @@ -135,6 +134,7 @@ class ActivityItem( "TextActivity" -> { binding.activityBannerContainer.visibility = View.GONE binding.activityContent.visibility = View.VISIBLE + binding.activityPrivate.visibility = View.GONE if (!(context as android.app.Activity).isDestroyed) { val markwon = buildMarkwon(context, false) markwon.setMarkdown( @@ -164,6 +164,7 @@ class ActivityItem( "MessageActivity" -> { binding.activityBannerContainer.visibility = View.GONE binding.activityContent.visibility = View.VISIBLE + binding.activityPrivate.visibility = if (activity.isPrivate == true) View.VISIBLE else View.GONE if (!(context as android.app.Activity).isDestroyed) { val markwon = buildMarkwon(context, false) markwon.setMarkdown( @@ -178,6 +179,18 @@ class ActivityItem( clickCallback(activity.messengerId ?: -1, "USER") } binding.activityEdit.isVisible = false + binding.activityEdit.isVisible = activity.messenger?.id == Anilist.userid + binding.activityEdit.setOnClickListener { + ContextCompat.startActivity( + context, + Intent(context, MarkdownCreatorActivity::class.java) + .putExtra("type", "message") + .putExtra("other", activity.message) + .putExtra("edit", activity.id) + .putExtra("userId", activity.recipientId), + null + ) + } } } } diff --git a/app/src/main/java/ani/dantotsu/util/AniMarkdown.kt b/app/src/main/java/ani/dantotsu/util/AniMarkdown.kt index 0228256c16..3f8c04d725 100644 --- a/app/src/main/java/ani/dantotsu/util/AniMarkdown.kt +++ b/app/src/main/java/ani/dantotsu/util/AniMarkdown.kt @@ -90,10 +90,8 @@ class AniMarkdown { //istg anilist has the worst api /* Add responsive design elements for other content as needed */ - - $basicHtml - - +$basicHtml + """.trimIndent() return returnHtml } diff --git a/app/src/main/java/ani/dantotsu/util/MarkdownCreatorActivity.kt b/app/src/main/java/ani/dantotsu/util/MarkdownCreatorActivity.kt index 1f02170412..bfb0191266 100644 --- a/app/src/main/java/ani/dantotsu/util/MarkdownCreatorActivity.kt +++ b/app/src/main/java/ani/dantotsu/util/MarkdownCreatorActivity.kt @@ -51,6 +51,7 @@ class MarkdownCreatorActivity : AppCompatActivity() { binding.markdownCreatorTitle.text = when (type) { "activity" -> getString(R.string.create_new_activity) "review" -> getString(R.string.create_new_review) + "message" -> getString(R.string.create_new_message) "replyActivity" -> { parentId = intent.getIntExtra("parentId", -1) if (parentId == -1) { @@ -64,6 +65,7 @@ class MarkdownCreatorActivity : AppCompatActivity() { else -> "" } ping = intent.getStringExtra("other") + val userId = intent.getIntExtra("userId", -1) text = ping ?: "" binding.editText.setText(text) binding.editText.addTextChangedListener { @@ -106,7 +108,11 @@ class MarkdownCreatorActivity : AppCompatActivity() { } else { Anilist.mutation.postReply(parentId, text) } - + "message" -> if (isEdit) { //TODO private + Anilist.mutation.postMessage(userId , text, editId) + } else { + Anilist.mutation.postMessage(userId , text) + } else -> "Error: Unknown type" } toast(success) diff --git a/app/src/main/res/layout/bottom_sheet_settings.xml b/app/src/main/res/layout/bottom_sheet_settings.xml index 66b041b760..049fc75c85 100644 --- a/app/src/main/res/layout/bottom_sheet_settings.xml +++ b/app/src/main/res/layout/bottom_sheet_settings.xml @@ -27,7 +27,7 @@ android:id="@+id/homeUserAvatarContainer" android:layout_width="52dp" android:layout_height="52dp" - android:layout_marginTop="4dp" + android:layout_margin="4dp" android:backgroundTint="@color/nav_bg_inv" app:cardCornerRadius="26dp"> @@ -165,7 +165,6 @@