Functions/StreamDeck/Clear-StreamDeckProfile.ps1
function Clear-StreamDeckProfile { <# .Synopsis Clears StreamDeck Profiles .Description Clears rows or columns from a StreamDeck profile. By default, clears an entire profile. #> [CmdletBinding(SupportsShouldProcess)] param( # The name of one or more profiles [Parameter(Mandatory)] [string[]] $ProfileName, # The root directory to look for profiles. [string] $ProfileRoot, # One or more rows to clear [Parameter(ValueFromPipelineByPropertyName)] [string[]] $Row, # One or more columns to clear [Parameter(ValueFromPipelineByPropertyName)] [string[]] $Column, # One or more action UUIDs to clear [Parameter(ValueFromPipelineByPropertyName)] [string[]] $UUID ) begin { $sdProfiles = Get-StreamDeckProfile -ProfileRoot $ProfileRoot | Where-Object Name -In $ProfileName if (-not $sdProfiles) { Write-Error "StreamDeck Profile $ProfileName not found" } } process { if (-not $UUID -and -not $Row -and -not $Column) { $row, $Column = '*', '*' } if ($UUID) { foreach ($prof in $sdProfiles) { $prof.Actions.psobject.Properties | Where-Object { $_.Value.UUID -in $UUID } | Select-Object -ExpandProperty Name | ForEach-Object { $c, $r = $_ -split ','; $Row += $r; $Column += $c } } } if ($Row -and $Column) { foreach ($prof in $sdProfiles) { foreach ($r in $row) { foreach ($c in $Column) { if ($PSCmdlet.ShouldProcess("Remove Action at $r, $c")) { $prof.RemoveAction($R, $C) $prof.Save() } } } } } } } |