Skip to content

Commit

Permalink
fix: [Ai] issues of input-edit-widget
Browse files Browse the repository at this point in the history
1.reference dialog can not hide normally
2.Optimize the display and hiding of the `@` symbol

Log: fix bugs

Bug: https://pms.uniontech.com/bug-view-298457.html
    https://pms.uniontech.com/bug-view-298349.html
  • Loading branch information
LiHua000 committed Jan 6, 2025
1 parent 64af9a3 commit e126e11
Showing 1 changed file with 29 additions and 14 deletions.
43 changes: 29 additions & 14 deletions src/plugins/codegeex/widgets/inputeditwidget.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -143,28 +143,29 @@ void InputEditWidgetPrivate::initEdit()
sendButton->setEnabled(true);

q->setFixedHeight(edit->height() + buttonBox->height());
auto cursorPos = edit->textCursor().position();
if (cursorPos > 0 && edit->document()->characterAt(cursorPos - 1) == "@")
q->popupReference();

auto cursor = edit->textCursor();
if (!currentText.contains('@')) {
referencePopup->hide();
} else if (!currentText.endsWith('@')) {
auto start = currentText.indexOf('@');
auto firstSpace = currentText.indexOf(' ', start); // first space after `@`
if (start == -1 || (firstSpace != -1 && cursorPos > firstSpace)) {
referencePopup->hide();
return;
} else if (currentText.endsWith('@')) {
q->popupReference();
} else {
QString filterText = "";
while (cursor.movePosition(QTextCursor::Left, QTextCursor::KeepAnchor)) {
if (cursor.selectedText().contains(" ")) {
referencePopup->hide();
model.setFilterText("");
return;
} else if (cursor.selectedText().startsWith('@')) {
filterText = cursor.selectedText().remove('@');
break;
}
}

auto filterText = currentText.mid(start + 1, cursorPos - start - 1);
model.setFilterText(filterText);
if (model.getItems().isEmpty())
referencePopup->hide();
else
referencePopup->show();
} else {
model.setFilterText("");
}
});
}
Expand Down Expand Up @@ -442,7 +443,14 @@ bool InputEdit::hasTag(const QString &text)

void InputEditWidget::onReferenceBtnClicked()
{
d->edit->append("@");
auto cursor = d->edit->textCursor();
cursor.movePosition(QTextCursor::Left, QTextCursor::KeepAnchor);
auto charBeforeCursor = cursor.selectedText();
if (charBeforeCursor != "@")
cursor.insertText("@");
else if (!d->referencePopup->isVisible())
d->referencePopup->show();
d->edit->setFocus();
}

void InputEditWidget::onCodeBaseBtnClicked()
Expand Down Expand Up @@ -522,6 +530,13 @@ bool InputEditWidget::eventFilter(QObject *watched, QEvent *event)
case Qt::Key_Escape:
d->referencePopup->hide();
break;
case Qt::Key_Left: {
auto cursor = d->edit->textCursor();
cursor.movePosition(QTextCursor::Left, QTextCursor::KeepAnchor);
auto charSelected = cursor.selectedText();
if (charSelected == '@')
d->referencePopup->hide();
} break;
default:
break;
}
Expand Down

0 comments on commit e126e11

Please sign in to comment.