Update NewCsharpFileDialog.cs

This commit is contained in:
Matt Parker
2025-10-20 19:35:50 +10:00
parent f8bb4901c7
commit 7d379939e9

View File

@@ -26,10 +26,31 @@ public partial class NewCsharpFileDialog : ConfirmationDialog
_fileTypeItemList.AddItem("Record", _classIcon);
_fileTypeItemList.AddItem("Struct", _classIcon);
_fileTypeItemList.AddItem("Enum", _classIcon);
_fileTypeItemList.Select(0);
_fileTypeItemList.ItemSelected += FileTypeItemListOnItemSelected;
Confirmed += OnConfirmed;
}
public override void _Input(InputEvent @event)
{
if (@event is InputEventKey { Pressed: true, Keycode: Key.Enter })
{
OnConfirmed();
}
else if (@event is InputEventKey { Pressed: true, Keycode: Key.Down })
{
var selectedIndex = _fileTypeItemList.GetSelectedItems()[0];
var nextIndex = (selectedIndex + 1) % _fileTypeItemList.GetItemCount();
_fileTypeItemList.Select(nextIndex);
}
else if (@event is InputEventKey { Pressed: true, Keycode: Key.Up })
{
var selectedIndex = _fileTypeItemList.GetSelectedItems()[0];
var previousIndex = (selectedIndex - 1 + _fileTypeItemList.GetItemCount()) % _fileTypeItemList.GetItemCount();
_fileTypeItemList.Select(previousIndex);
}
}
private void FileTypeItemListOnItemSelected(long index)
{
GD.Print("Selected file type index: " + index);
@@ -38,7 +59,7 @@ public partial class NewCsharpFileDialog : ConfirmationDialog
private void OnConfirmed()
{
var fileName = _nameLineEdit.Text.Trim();
if (string.IsNullOrEmpty(fileName))
if (IsNameInvalid(fileName))
{
GD.PrintErr("File name cannot be empty.");
return;
@@ -53,5 +74,11 @@ public partial class NewCsharpFileDialog : ConfirmationDialog
{
//await _ideFileOperationsService.CreateCSharpFile(ParentFolder, fileName);
});
QueueFree();
}
private bool IsNameInvalid(string name)
{
return string.IsNullOrWhiteSpace(name);
}
}