From f35f08be50176258e3e1858a94bd1818534db819 Mon Sep 17 00:00:00 2001 From: fam007e Date: Wed, 21 Aug 2024 18:01:55 +0600 Subject: [PATCH] Add 'Update-Progress' Script Utility --- tools/Update-Progress.ps1 | 36 ++++++++++++++++++++++++++++++++++++ 1 file changed, 36 insertions(+) create mode 100644 tools/Update-Progress.ps1 diff --git a/tools/Update-Progress.ps1 b/tools/Update-Progress.ps1 new file mode 100644 index 00000000..2749f7e0 --- /dev/null +++ b/tools/Update-Progress.ps1 @@ -0,0 +1,36 @@ +# Update-Progress.ps1 + +function Update-Progress { + param ( + [Parameter(Mandatory, Position = 0)] + [ValidateNotNullOrEmpty()] + [string]$StatusMessage, + + [Parameter(Mandatory, Position = 1)] + [ValidateRange(0, 100)] + [int]$Percent, + + [Parameter(Position = 2)] + [string]$Activity, + + [Parameter(Position = 3)] + [switch]$LogProgress + ) + + # Default activity to "Processing" if not provided + if (-not $Activity) { + $Activity = "Processing" + } + + # Write the progress to the console + Write-Progress -Activity $Activity -Status $StatusMessage -PercentComplete $Percent + + # Optionally log the progress to a file + if ($LogProgress) { + $logMessage = "{0:yyyy-MM-dd HH:mm:ss} - {1} - {2}% - {3}" -f (Get-Date), $Activity, $Percent, $StatusMessage + $logMessage | Out-File -FilePath "$PSScriptRoot\progress.log" -Append -Encoding utf8 + } +} + +# Example Usage: +# Update-Progress "Processing files..." 50 "File Processing" -LogProgress