Compare commits

..

1 Commits

Author SHA1 Message Date
Mr.k
9aa8550153
Merge fb21479531 into ce1ef2a519 2024-11-01 23:53:50 +00:00

View File

@ -1,54 +1,91 @@
function Invoke-WPFPopup { function Invoke-WPFPopup {
param ( param (
[ValidateSet("Show", "Hide", "Toggle")] [Parameter(position=0)]
[ValidateSet("Show","Hide","Toggle", ErrorMessage="Action '{0}' is not part of the valid set '{1}'.")]
[string]$Action = "", [string]$Action = "",
[Parameter(position=1)]
[string[]]$Popups = @(), [string[]]$Popups = @(),
[Parameter(position=2)]
[ValidateScript({ [ValidateScript({
$invalid = $_.GetEnumerator() | Where-Object { $_.Value -notin @("Show", "Hide", "Toggle") } $PossibleActions = @("Show", "Hide", "Toggle")
if ($invalid) { [hashtable]$UnExpectedPairs = @{}
throw "Found invalid Popup-Action pair(s): " + ($invalid | ForEach-Object { "$($_.Key) = $($_.Value)" } -join "; ") Foreach ($pair in $_.GetEnumerator()) {
$key = $pair.Name
$value = $pair.Value
if (-not ($value -in $PossibleActions)) {
$UnExpectedPairs.Add("$key", "$value")
}
} }
if ($UnExpectedPairs.Count -gt 0) {
$UnExpectedPairsAsString = "@{"
Foreach ($pair in $UnExpectedPairs.GetEnumerator()) { $UnExpectedPairsAsString += "`"$($pair.Name)`" = `"$($pair.Value)`"; " }
$UnExpectedPairsAsString = $UnExpectedPairsAsString -replace (';\s*$', '')
$UnExpectedPairsAsString += "}"
throw "Found Unexpected pair(s), these Popup & Action pair(s) are: $UnExpectedPairsAsString"
}
# Return true for passing validation checks
$true $true
})] })]
[hashtable]$PopupActionTable = @{} [hashtable]$PopupActionTable = @{}
) )
if (-not $PopupActionTable.Count -and (-not $Action -or -not $Popups.Count)) { if ($PopupActionTable.Count -eq 0 -and $Action -eq "" -and $Popups.Count -eq 0) {
throw "Provide either 'PopupActionTable' or both 'Action' and 'Popups'." throw [GenericException]::new("No Parameter was provided, please use either 'PopupActionTable' on its own, or use 'Action' and 'Popups' on their own, depending on your use case.")
}
if ($PopupActionTable.Count -gt 0 -and ($Action -ne "" -or $Popups.Count -gt 0)) {
throw [GenericException]::new("Only use 'PopupActionTable' on its own, or use 'Action' and 'Popups' on their own, depending on your use case.")
} }
if ($PopupActionTable.Count -and ($Action -or $Popups.Count)) { $PopupsNotFound = [System.Collections.Generic.List[string]]::new($Popups.Count)
throw "Use 'PopupActionTable' on its own, or 'Action' with 'Popups'."
}
# Collect popups and actions if ($PopupActionTable.Count -gt 0) {
$PopupsToProcess = if ($PopupActionTable.Count) { Foreach ($popupActionPair in $PopupActionTable.GetEnumerator()) {
$PopupActionTable.GetEnumerator() | ForEach-Object { [PSCustomObject]@{ Name = "$($_.Key)Popup"; Action = $_.Value } } $popup = $popupActionPair.Name + "Popup"
} else { $action = $popupActionPair.Value
$Popups | ForEach-Object { [PSCustomObject]@{ Name = "$_`Popup"; Action = $Action } } if ($sync.$popup -eq $null) {
} $PopupsNotFound.Add("$popup") | Out-Null
continue
$PopupsNotFound = @() }
switch ($action) {
# Apply actions 'Show' { $actionAsBool = $true }
foreach ($popupEntry in $PopupsToProcess) { 'Hide' { $actionAsBool = $false }
$popupName = $popupEntry.Name 'Toggle' { $actionAsBool = -not $sync.$popup.IsOpen }
default { throw [GenericException]::new("Action can only be `"Show`" or `"Hide`" or `"Toggle`".") }
if (-not $sync.$popupName) { }
$PopupsNotFound += $popupName $sync.$popup.IsOpen = $actionAsBool
continue
} }
} else {
$sync.$popupName.IsOpen = switch ($popupEntry.Action) { if ($Action -eq "" -or $Popups.Count -eq 0) {
"Show" { $true } throw [GenericException]::new("Please provide both the 'Action' and 'Popups' Parameters, with the appropriate values foreach parameter.")
"Hide" { $false } }
"Toggle" { -not $sync.$popupName.IsOpen } Foreach ($popup in $Popups) {
$popup += "Popup"
if ($sync.$popup -eq $null) {
$PopupsNotFound.Add("$popup") | Out-Null
continue
}
switch ($action) {
'Show' { $actionAsBool = $true }
'Hide' { $actionAsBool = $false }
'Toggle' { $actionAsBool = -not $sync.$popup.IsOpen }
default { throw [GenericException]::new("Action can only be `"Show`" or `"Hide`" or `"Toggle`".") }
}
$sync.$popup.IsOpen = $actionAsBool
} }
} }
if ($PopupsNotFound.Count -gt 0) { if ($PopupsNotFound.Count -gt 0) {
throw "Could not find the following popups: $($PopupsNotFound -join ', ')" $PopupsNotFoundAsString = "@("
Foreach ($popupNotFound in $PopupsNotFound) {
$PopupsNotFoundAsString += "$popupNotFound"
$PopupsNotFoundAsString += ", "
}
$PopupsNotFoundAsString = $PopupsNotFoundAsString -replace (',\s*$', '')
$PopupsNotFoundAsString += ")"
throw [GenericException]::new("Could not find $PopupsNotFoundAsString Popups in `$sync variable.")
} }
} }