shift+enter for newline instead of ctrl+enter
Some checks are pending
ContinuousDelivery / linux-ubuntu (push) Waiting to run
ContinuousDelivery / android (map[ndk_abi:arm64-v8a vcpkg_toolkit:arm64-android]) (push) Waiting to run
ContinuousDelivery / android (map[ndk_abi:armeabi-v7a vcpkg_toolkit:arm-neon-android]) (push) Waiting to run
ContinuousDelivery / android (map[ndk_abi:x86_64 vcpkg_toolkit:x64-android]) (push) Waiting to run
ContinuousDelivery / windows (push) Waiting to run
ContinuousDelivery / windows-asan (push) Waiting to run
ContinuousDelivery / release (push) Blocked by required conditions
ContinuousIntegration / linux (push) Waiting to run
ContinuousIntegration / android (map[ndk_abi:arm64-v8a vcpkg_toolkit:arm64-android]) (push) Waiting to run
ContinuousIntegration / android (map[ndk_abi:armeabi-v7a vcpkg_toolkit:arm-neon-android]) (push) Waiting to run
ContinuousIntegration / android (map[ndk_abi:x86_64 vcpkg_toolkit:x64-android]) (push) Waiting to run
ContinuousIntegration / macos (push) Waiting to run
ContinuousIntegration / windows (push) Waiting to run

This commit is contained in:
Green Sky 2025-01-21 02:27:42 +01:00
parent 96b20aab67
commit 6bd151e618
No known key found for this signature in database

View File

@ -899,22 +899,46 @@ float ChatGui4::render(float time_delta, bool window_hidden, bool window_focused
ImGui::EndChild(); ImGui::EndChild();
if (ImGui::BeginChild("text_input", {-150, 0})) { if (ImGui::BeginChild("text_input", {-150, 0})) {
static bool evil_enter_looses_focus_hack = false;
if (evil_enter_looses_focus_hack) {
ImGui::SetKeyboardFocusHere();
evil_enter_looses_focus_hack = false;
}
constexpr ImGuiInputTextFlags input_flags = constexpr ImGuiInputTextFlags input_flags =
ImGuiInputTextFlags_EnterReturnsTrue |
//ImGuiInputTextFlags_AllowTabInput | //ImGuiInputTextFlags_AllowTabInput |
ImGuiInputTextFlags_NoHorizontalScroll | ImGuiInputTextFlags_NoHorizontalScroll |
ImGuiInputTextFlags_CtrlEnterForNewLine; ImGuiInputTextFlags_CallbackCharFilter;
if (ImGui::InputTextMultiline("##text_input", &_text_input_buffer, {-0.001f, -0.001f}, input_flags)) { bool text_input_validate {false};
ImGui::InputTextMultiline(
"##text_input",
&_text_input_buffer,
{-0.001f, -0.001f},
input_flags,
+[](ImGuiInputTextCallbackData* data) -> int {
// ignore unrelated callbacks
if ((data->EventFlag & ImGuiInputTextFlags_CallbackCharFilter) == 0) {
return 0;
}
// we let everything through, except enter without shift, in which case we signal outside
if (
data->EventChar == '\n' &&
!ImGui::GetIO().KeyShift &&
ImGui::IsKeyPressed(ImGuiKey_Enter) // also needs to be a key press, not a paste
) {
*reinterpret_cast<bool*>(data->UserData) = true;
return 1;
}
return 0;
},
&text_input_validate
);
if (text_input_validate) {
_rmm.sendText(*_selected_contact, _text_input_buffer); _rmm.sendText(*_selected_contact, _text_input_buffer);
_text_input_buffer.clear(); _text_input_buffer = "";
evil_enter_looses_focus_hack = true; if (ImGuiInputTextState* input_state = ImGui::GetInputTextState(ImGui::GetItemID())) {
//input_state->ReloadUserBufAndSelectAll();
input_state->ReloadUserBufAndMoveToEnd();
}
ImGui::SetKeyboardFocusHere(-1);
} }
// welcome to linux // welcome to linux