# Pull Request Template ## Description This PR adds support to auto-focus the editor when clicking reply to this message, the editor now automatically receives focus so users can start typing immediately. Fixes https://linear.app/chatwoot/issue/CW-6661/typing-box-not-focused-after-clicking-reply-to-message ## Type of change - [x] Bug fix (non-breaking change which fixes an issue) ## How Has This Been Tested? ### Screencast https://github.com/user-attachments/assets/c5e77055-3f68-4ad8-934e-cfc465166e8a ## Checklist: - [x] My code follows the style guidelines of this project - [x] I have performed a self-review of my code - [ ] I have commented on my code, particularly in hard-to-understand areas - [ ] I have made corresponding changes to the documentation - [x] My changes generate no new warnings - [ ] I have added tests that prove my fix is effective or that my feature works - [x] New and existing unit tests pass locally with my changes - [ ] Any dependent changes have been merged and published in downstream modules
50 lines
1.2 KiB
Vue
50 lines
1.2 KiB
Vue
<script setup>
|
|
import MessagePreview from 'dashboard/components/widgets/conversation/MessagePreview.vue';
|
|
import Button from 'dashboard/components-next/button/Button.vue';
|
|
|
|
defineProps({
|
|
message: {
|
|
type: Object,
|
|
required: true,
|
|
},
|
|
});
|
|
|
|
const emit = defineEmits(['dismiss']);
|
|
</script>
|
|
|
|
<template>
|
|
<div
|
|
class="reply-editor bg-n-slate-9/10 rounded-md py-1 pl-2 pr-1 text-xs tracking-wide mt-2 flex items-center gap-1.5"
|
|
>
|
|
<fluent-icon class="flex-shrink-0 icon" icon="arrow-reply" size="14" />
|
|
<div class="flex-grow gap-1 mt-px text-xs truncate">
|
|
{{ $t('CONVERSATION.REPLYBOX.REPLYING_TO') }}
|
|
<MessagePreview
|
|
:message="message"
|
|
:show-message-type="false"
|
|
:default-empty-message="$t('CONVERSATION.REPLY_MESSAGE_NOT_FOUND')"
|
|
class="inline"
|
|
/>
|
|
</div>
|
|
<Button
|
|
v-tooltip="$t('CONVERSATION.REPLYBOX.DISMISS_REPLY')"
|
|
ghost
|
|
xs
|
|
slate
|
|
icon="i-lucide-x"
|
|
class="flex-shrink-0"
|
|
@click.stop="emit('dismiss')"
|
|
/>
|
|
</div>
|
|
</template>
|
|
|
|
<style lang="scss">
|
|
// TODO: Remove this
|
|
// override for dashboard/assets/scss/widgets/_reply-box.scss
|
|
.reply-editor {
|
|
.icon {
|
|
margin-right: 0px !important;
|
|
}
|
|
}
|
|
</style>
|