ConsoleUserInteractionHelper 4.0.0

dotnet add package ConsoleUserInteractionHelper --version 4.0.0                
NuGet\Install-Package ConsoleUserInteractionHelper -Version 4.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="ConsoleUserInteractionHelper" Version="4.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add ConsoleUserInteractionHelper --version 4.0.0                
#r "nuget: ConsoleUserInteractionHelper, 4.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install ConsoleUserInteractionHelper as a Cake Addin
#addin nuget:?package=ConsoleUserInteractionHelper&version=4.0.0

// Install ConsoleUserInteractionHelper as a Cake Tool
#tool nuget:?package=ConsoleUserInteractionHelper&version=4.0.0                

Package Description

ConsoleHelper is a versatile .NET library designed to simplify console-based user interactions. It provides a rich set of methods to handle various input scenarios, from simple string inputs to complex numeric constraints.

Key Features

  • Robust Input Handling: Gracefully manage user inputs with built-in validation and error handling.
  • Flexible Numeric Inputs: Easily obtain integer values with custom constraints.
  • Secure String Input: Collect sensitive information without displaying it on the console.
  • Progress Indication: Display spinner animations for long-running operations.
  • Customizable Retry Logic: Control the number of retry attempts for each input operation.

Installation

Install ConsoleHelper via NuGet Package Manager:

Install-Package ConsoleUserInteractionHelper

Or via .NET CLI:

dotnet add package ConsoleUserInteractionHelper

Usage Examples

Here are some examples to demonstrate the versatility of ConsoleHelper:

using ConsoleUserInteractionHelper;

var helper = new ConsoleHelper();

// Get a non-empty string
string name = helper.GetNonEmptyStringFromUser();

// Get a positive integer with max 3 retry attempts
int age = helper.GetPositiveInt(maxRetries: 3);

// Use custom constraints for integer input
int evenNumber = helper.GetIntWithConstraints(
    n => n % 2 == 0, 
    "Please enter an even number."
);

// Collect a password securely
string password = helper.GetSecretStringFromUser();

// Display a spinner during a long operation
Task longRunningTask = SomeLongRunningOperation();
helper.ShowSpinnerUntilTaskIsRunning(longRunningTask);

// Get a file path with specific extension
string filePath = helper.GetPathToExistingFileFromUser(".txt");

Extensibility

ConsoleHelper is designed with extensibility in mind. You can easily create custom input methods using the generic GetIntWithConstraints method:

// Custom method to get a prime number
public int GetPrimeNumber(int? maxRetries = null)
{
    return GetIntWithConstraints(
        n => IsPrime(n),
        "Please enter a prime number.",
        maxRetries
    );
}

private bool IsPrime(int number)
{
    if (number < 2) return false;
    for (int i = 2; i <= Math.Sqrt(number); i++)
    {
        if (number % i == 0) return false;
    }
    return true;
}

Contributing

We welcome contributions! Please see our Contributing Guidelines for more details.

License

ConsoleHelper is released under the MIT License.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
4.0.0 704 9/10/2024
3.4.1 253 8/30/2023
3.3.0 356 11/18/2021
3.2.3 332 11/7/2021
3.2.2 361 11/7/2021
3.2.1 317 11/4/2021
3.2.0 347 11/4/2021
3.1.0 331 11/3/2021
3.0.0 342 11/3/2021
2.2.0 391 2/20/2021
2.1.0 391 2/14/2021
2.0.0 1,012 10/8/2018
1.1.0 800 10/7/2018
1.0.0 784 10/7/2018

# ConsoleUserInteractionHelper

     ## Release Notes (v4.0.0)

     This major update brings significant improvements and new features to enhance your console application development experience.

     ### What's New

     - **Generic Integer Input Method**: Introduced `GetIntWithConstraints` for flexible integer input handling.
     - **Optional Max Retries**: All input methods now support an optional maximum retry limit.
     - **Improved Error Handling**: Enhanced error messages and consistency across all methods.
     ### Breaking Changes

     - Signature changes to existing methods to incorporate the optional `maxRetries` parameter.