Skip to content

Commit

Permalink
Merge pull request #2131 from element-hq/feature/bma/sendImageFromKey…
Browse files Browse the repository at this point in the history
…board

Add support for sending images from the keyboard
  • Loading branch information
bmarty authored Jan 8, 2024
2 parents 66bc3bf + b6f88f9 commit cd25990
Show file tree
Hide file tree
Showing 5 changed files with 28 additions and 1 deletion.
1 change: 1 addition & 0 deletions changelog.d/1977.feature
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Add support for sending images from the keyboard
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@

package io.element.android.features.messages.impl.messagecomposer

import android.net.Uri
import androidx.compose.runtime.Immutable
import io.element.android.features.messages.impl.mentions.MentionSuggestion
import io.element.android.libraries.textcomposer.model.Message
Expand All @@ -26,6 +27,7 @@ import io.element.android.libraries.textcomposer.model.Suggestion
sealed interface MessageComposerEvents {
data object ToggleFullScreenState : MessageComposerEvents
data class SendMessage(val message: Message) : MessageComposerEvents
data class SendUri(val uri: Uri) : MessageComposerEvents
data object CloseSpecialMode : MessageComposerEvents
data class SetMode(val composerMode: MessageComposerMode) : MessageComposerEvents
data object AddAttachment : MessageComposerEvents
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -225,6 +225,18 @@ class MessageComposerPresenter @Inject constructor(
updateComposerMode = { messageComposerContext.composerMode = it },
richTextEditorState = richTextEditorState,
)
is MessageComposerEvents.SendUri -> appCoroutineScope.sendAttachment(
attachment = Attachment.Media(
localMedia = localMediaFactory.createFromUri(
uri = event.uri,
mimeType = null,
name = null,
formattedFileSize = null
),
compressIfPossible = true
),
attachmentState = attachmentsState,
)
is MessageComposerEvents.SetMode -> {
messageComposerContext.composerMode = event.composerMode
when (event.composerMode) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@

package io.element.android.features.messages.impl.messagecomposer

import android.net.Uri
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.IntrinsicSize
import androidx.compose.foundation.layout.height
Expand Down Expand Up @@ -52,6 +53,10 @@ internal fun MessageComposerView(
state.eventSink(MessageComposerEvents.SendMessage(message))
}

fun sendUri(uri: Uri) {
state.eventSink(MessageComposerEvents.SendUri(uri))
}

fun onAddAttachment() {
state.eventSink(MessageComposerEvents.AddAttachment)
}
Expand Down Expand Up @@ -117,6 +122,7 @@ internal fun MessageComposerView(
onSuggestionReceived = ::onSuggestionReceived,
onError = ::onError,
currentUserId = state.currentUserId,
onRichContentSelected = ::sendUri,
)
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@

package io.element.android.libraries.textcomposer

import android.net.Uri
import androidx.compose.foundation.background
import androidx.compose.foundation.border
import androidx.compose.foundation.clickable
Expand Down Expand Up @@ -111,6 +112,7 @@ fun TextComposer(
onDeleteVoiceMessage: () -> Unit,
onError: (Throwable) -> Unit,
onSuggestionReceived: (Suggestion?) -> Unit,
onRichContentSelected: ((Uri) -> Unit)?,
modifier: Modifier = Modifier,
showTextFormatting: Boolean = false,
subcomposing: Boolean = false,
Expand Down Expand Up @@ -162,6 +164,7 @@ fun TextComposer(
resolveMentionDisplay = { text, url -> TextDisplay.Custom(mentionSpanProvider.getMentionSpanFor(text, url)) },
resolveRoomMentionDisplay = { TextDisplay.Custom(mentionSpanProvider.getMentionSpanFor("@room", "#")) },
onError = onError,
onRichContentSelected = onRichContentSelected,
)
}
}
Expand Down Expand Up @@ -397,6 +400,7 @@ private fun TextInput(
resolveMentionDisplay: (text: String, url: String) -> TextDisplay,
modifier: Modifier = Modifier,
onError: (Throwable) -> Unit = {},
onRichContentSelected: ((Uri) -> Unit)? = null,
) {
val bgColor = ElementTheme.colors.bgSubtleSecondary
val borderColor = ElementTheme.colors.borderDisabled
Expand Down Expand Up @@ -443,7 +447,8 @@ private fun TextInput(
style = ElementRichTextEditorStyle.composerStyle(hasFocus = state.hasFocus),
resolveMentionDisplay = resolveMentionDisplay,
resolveRoomMentionDisplay = resolveRoomMentionDisplay,
onError = onError
onError = onError,
onRichContentSelected = onRichContentSelected,
)
}
}
Expand Down Expand Up @@ -902,5 +907,6 @@ private fun ATextComposer(
onDeleteVoiceMessage = {},
onError = {},
onSuggestionReceived = {},
onRichContentSelected = null,
)
}

0 comments on commit cd25990

Please sign in to comment.