diff --git a/.github/actions/spell-check/expect.txt b/.github/actions/spell-check/expect.txt index 749a25a379..779a848e6b 100644 --- a/.github/actions/spell-check/expect.txt +++ b/.github/actions/spell-check/expect.txt @@ -35,6 +35,7 @@ Allman ALLOWUNDO ALLVIEW ALPHATYPE +altkey AModifier amr ANDSCANS @@ -456,6 +457,9 @@ fdx FErase fesf FFFF +fffffffzzz +FInc +FFh Figma FILEEXPLORER FILEFLAGS @@ -577,6 +581,7 @@ HIBYTE hicon HIDEWINDOW Hif +highcontrast highlightbackground highlightthickness HIMAGELIST @@ -850,6 +855,8 @@ MDL mdtext mdtxt mdwn +measuretool +mccs meme memicmp MENUITEMINFO @@ -893,6 +900,7 @@ MONITORINFOEX MONITORINFOEXW monitorinfof MOUSEACTIVATE +mousecrosshairs MOUSEDATA MOUSEEVENTF MOUSEHWHEEL @@ -924,6 +932,7 @@ mstsc msvcp MT MTND +multimonitor MULTIPLEUSE multizone muxc @@ -1017,6 +1026,9 @@ NORMALDISPLAY NORMALUSER NOSEARCH NOSENDCHANGING +NOSIZE +notdefault +Nosize NOTHOUSANDS NOTICKS NOTIFICATIONSDLL @@ -1107,6 +1119,7 @@ PCIDLIST PCTSTR PCWSTR PDEVMODE +PDFs pdisp PDLL pdo @@ -1155,6 +1168,10 @@ Pokedex Popups POPUPWINDOW POSITIONITEM +powerocr +POWERBROADCAST +powerdisplay +POWERDISPLAYMODULEINTERFACE POWERRENAMECONTEXTMENU powerrenameinput POWERRENAMETEST @@ -1518,6 +1535,9 @@ STYLECHANGING subkeys sublang SUBMODULEUPDATE +subresource +suntimes +swp sug Superbar sut @@ -1736,6 +1756,7 @@ wdm wdp wdupenv webbrowsers +webdev webpage websites wekyb diff --git a/doc/dsc/Settings.md b/doc/dsc/Settings.md deleted file mode 100644 index 24fab1e2dd..0000000000 --- a/doc/dsc/Settings.md +++ /dev/null @@ -1,83 +0,0 @@ -# Settings resource -Manage the settings for PowerToys modules - -## Commands - -### โœจ Modules -List all the modules supported by the settings resource. -```shell -PS C:\> PowerToys.DSC.exe modules --resource 'settings' -AdvancedPaste -AlwaysOnTop -App -Awake -ColorPicker -CropAndLock -EnvironmentVariables -FancyZones -FileLocksmith -FindMyMouse -Hosts -ImageResizer -KeyboardManager -MeasureTool -MouseHighlighter -MouseJump -MousePointerCrosshairs -Peek -PowerAccent -PowerOCR -PowerRename -RegistryPreview -ShortcutGuide -Workspaces -ZoomIt -``` - -### ๐Ÿ“„ Get -Get the settings for a specific module. -```shell -PS C:\> PowerToys.DSC.exe get --resource 'settings' --module EnvironmentVariables -{"settings":{"properties":{"LaunchAdministrator":{"value":true}},"name":"EnvironmentVariables","version":"1.0"}} -``` - -### ๐Ÿ–จ๏ธ Export -Export the settings for a specific module. - -โ„น๏ธ Settings resource Get and Export operation output states are identical. -```shell -PS C:\> PowerToys.DSC.exe get --resource 'settings' --module EnvironmentVariables -{"settings":{"properties":{"LaunchAdministrator":{"value":true}},"name":"EnvironmentVariables","version":"1.0"}} -``` - -### ๐Ÿ“ Set -Set the settings for a specific module. This command will update the settings to the specified values. -```shell -PS C:\> PowerToys.DSC.exe set --resource 'settings' --module Awake --input '{"settings":{"properties":{"keepDisplayOn":false,"mode":0,"intervalHours":0,"intervalMinutes":1,"expirationDateTime":"2025-08-13T10:10:00.000001-07:00","customTrayTimes":{}},"name":"Awake","version":"0.0.1"}}' -{"settings":{"properties":{"keepDisplayOn":false,"mode":0,"intervalHours":0,"intervalMinutes":1,"expirationDateTime":"2025-08-13T10:10:00.000001-07:00","customTrayTimes":{}},"name":"Awake","version":"0.0.1"}} -["settings"] -``` - -### ๐Ÿงช Test -Test the settings for a specific module. This command will check if the current settings match the desired state. -```shell -PS C:\> PowerToys.DSC.exe test --resource 'settings' --module Awake --input '{"settings":{"properties":{"keepDisplayOn":false,"mode":0,"intervalHours":0,"intervalMinutes":1,"expirationDateTime":"2025-08-13T10:10:00.000002-07:00","customTrayTimes":{}},"name":"Awake","version":"0.0.1"}}' -{"settings":{"properties":{"keepDisplayOn":false,"mode":0,"intervalHours":0,"intervalMinutes":1,"expirationDateTime":"2025-08-13T10:10:00.000001-07:00","customTrayTimes":{}},"name":"Awake","version":"0.0.1"},"_inDesiredState":false} -["settings"] -``` - -### ๐Ÿ› ๏ธ Schema -Generates the JSON schema for the settings resource of a specific module. -```shell -PS C:\> PowerToys.DSC.exe schema --resource 'settings' --module Awake -{"$schema":"http://json-schema.org/draft-04/schema#","title":"SettingsResourceObjectOfAwakeSettings","type":"object","additionalProperties":false,"required":["settings"],"properties":{"_inDesiredState":{"type":["boolean","null"],"description":"Indicates whether an instance is in the desired state"},"settings":{"description":"The settings content for the module."}}} -PS E:\src\powertoys> PowerToys.DSC.exe schema --resource 'settings' --module Awake | Format-Json -``` - -### ๐Ÿ“ฆ Manifest -Generates a manifest dsc resource JSON file for the specified module. -- If the module is not specified, it will generate a manifest for all modules. -- If the output directory is not specified, it will print the manifest to the console. -```shell -PS C:\> PowerToys.DSC.exe manifest --resource settings --module 'Awake' --outputDir "C:\manifests" -``` \ No newline at end of file diff --git a/doc/dsc/modules/AdvancedPaste.md b/doc/dsc/modules/AdvancedPaste.md new file mode 100644 index 0000000000..5cc0bc4d77 --- /dev/null +++ b/doc/dsc/modules/AdvancedPaste.md @@ -0,0 +1,263 @@ +--- +description: DSC configuration reference for PowerToys AdvancedPaste module +ms.date: 10/18/2025 +ms.topic: reference +title: AdvancedPaste Module +--- + +# AdvancedPaste Module + +## Synopsis + +Manages configuration for the Advanced Paste utility, which provides advanced clipboard operations and custom paste formats. + +## Description + +The `AdvancedPaste` module configures PowerToys Advanced Paste, a utility +that extends clipboard functionality with AI-powered transformations, custom +formats, and advanced paste options. It allows you to paste clipboard content +with transformations like plain text conversion, markdown formatting, JSON +formatting, and AI-based text processing. + +## Properties + +The AdvancedPaste module supports the following configurable properties: + +### IsAdvancedAIEnabled + +Controls whether AI-powered paste transformations are enabled. + +**Type:** boolean +**Default:** `false` +**Description:** Enables AI-based clipboard transformations such as +summarization, translation, and content reformatting. + +### PasteAsPlainTextHotkey + +Sets the keyboard shortcut for pasting as plain text. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier. +- `ctrl` (boolean) - Ctrl key modifier. +- `alt` (boolean) - Alt key modifier. +- `shift` (boolean) - Shift key modifier. +- `code` (integer) - Virtual key code. +- `key` (string) - Key name. + +**Default:** `Ctrl+Win+V` + +### PasteAsMarkdownHotkey + +Sets the keyboard shortcut for pasting as markdown. + +**Type:** object (same structure as PasteAsPlainTextHotkey) +**Default:** `Ctrl+Win+Shift+V` + +### PasteAsJsonHotkey + +Sets the keyboard shortcut for pasting as JSON. + +**Type:** object (same structure as PasteAsPlainTextHotkey) + +### ShowCustomPreview + +Controls whether a preview window is shown before pasting custom formats. + +**Type:** boolean +**Default:** `true` + +### CloseAfterLosingFocus + +Controls whether the Advanced Paste window closes when it loses focus. + +**Type:** boolean +**Default:** `false` + +## Examples + +### Example 1 - Enable AI features with direct execution + +This example enables AI-powered paste transformations. + +```powershell +$config = @{ + settings = @{ + properties = @{ + IsAdvancedAIEnabled = $true + } + name = "AdvancedPaste" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module AdvancedPaste ` + --input $config +``` + +### Example 2 - Configure paste hotkeys with DSC + +This example customizes keyboard shortcuts for different paste formats. + +```bash +dsc config set --file advancedpaste-hotkeys.dsc.yaml +``` + +```yaml +# advancedpaste-hotkeys.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Advanced Paste hotkeys + type: Microsoft.PowerToys/AdvancedPasteSettings + properties: + settings: + properties: + PasteAsPlainTextHotkey: + win: true + ctrl: true + alt: false + shift: false + code: 86 + key: V + PasteAsMarkdownHotkey: + win: true + ctrl: true + alt: false + shift: true + code: 86 + key: V + name: AdvancedPaste + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Advanced Paste with AI +enabled. + +```bash +winget configure winget-advancedpaste.yaml +``` + +```yaml +# winget-advancedpaste.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Advanced Paste + type: Microsoft.PowerToys/AdvancedPasteSettings + properties: + settings: + properties: + IsAdvancedAIEnabled: true + ShowCustomPreview: true + CloseAfterLosingFocus: true + name: AdvancedPaste + version: 1.0 +``` + +### Example 4 - Enable with custom preview settings + +This example configures preview behavior for custom paste formats. + +```bash +dsc config set --file advancedpaste-preview.dsc.yaml +``` + +```yaml +# advancedpaste-preview.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure preview settings + type: Microsoft.PowerToys/AdvancedPasteSettings + properties: + settings: + properties: + ShowCustomPreview: true + CloseAfterLosingFocus: false + name: AdvancedPaste + version: 1.0 +``` + +### Example 5 - Test AI enablement + +This example tests whether AI features are enabled. + +```powershell +$desired = @{ + settings = @{ + properties = @{ + IsAdvancedAIEnabled = $true + } + name = "AdvancedPaste" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +$result = PowerToys.DSC.exe test --resource 'settings' ` + --module AdvancedPaste --input $desired | ConvertFrom-Json + +if ($result._inDesiredState) { + Write-Host "AI features are enabled" +} else { + Write-Host "AI features need to be enabled" +} +``` + +## Use cases + +### Development workflow + +Enable AI transformations for code snippets and documentation: + +```yaml +resources: + - name: Developer paste settings + type: Microsoft.PowerToys/AdvancedPasteSettings + properties: + settings: + properties: + IsAdvancedAIEnabled: true + ShowCustomPreview: true + name: AdvancedPaste + version: 1.0 +``` + +### Content creation + +Configure for markdown and formatted text operations: + +```yaml +resources: + - name: Content creator settings + type: Microsoft.PowerToys/AdvancedPasteSettings + properties: + settings: + properties: + ShowCustomPreview: true + CloseAfterLosingFocus: false + name: AdvancedPaste + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [ColorPicker Module][03] - System-wide color picker utility +- [PowerToys Advanced Paste Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./ColorPicker.md +[04]: https://learn.microsoft.com/windows/powertoys/advanced-paste diff --git a/doc/dsc/modules/AlwaysOnTop.md b/doc/dsc/modules/AlwaysOnTop.md new file mode 100644 index 0000000000..1a063b3b48 --- /dev/null +++ b/doc/dsc/modules/AlwaysOnTop.md @@ -0,0 +1,299 @@ +--- +description: DSC configuration reference for PowerToys AlwaysOnTop module +ms.date: 10/18/2025 +ms.topic: reference +title: AlwaysOnTop Module +--- + +# AlwaysOnTop Module + +## Synopsis + +Manages configuration for the Always On Top utility, which pins windows to stay on top of other windows. + +## Description + +The `AlwaysOnTop` module configures PowerToys Always On Top, a utility that +allows you to pin any window to remain visible above all other windows. This +is useful for keeping reference materials, chat windows, or monitoring tools +visible while working with other applications. + +## Properties + +The AlwaysOnTop module supports the following configurable properties: + +### Hotkey + +Sets the keyboard shortcut to toggle Always On Top for the active window. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier. +- `ctrl` (boolean) - Ctrl key modifier. +- `alt` (boolean) - Alt key modifier. +- `shift` (boolean) - Shift key modifier. +- `code` (integer) - Virtual key code. +- `key` (string) - Key name. + +**Default:** `Win+Ctrl+T` + +### FrameEnabled + +Controls whether a colored border is displayed around pinned windows. + +**Type:** boolean +**Default:** `true` + +### FrameThickness + +Sets the thickness of the border around pinned windows (in pixels). + +**Type:** integer +**Range:** `1` to `100` +**Default:** `5` + +### FrameColor + +Sets the color of the border around pinned windows. + +**Type:** string (hex color) +**Format:** `"#RRGGBB"` +**Default:** `"#FF0000"` (red) + +### FrameOpacity + +Sets the opacity of the border (0-100). + +**Type:** integer +**Range:** `0` to `100` +**Default:** `100` + +### FrameAccentColor + +Controls whether to use the Windows accent color for the frame. + +**Type:** boolean +**Default:** `false` + +### SoundEnabled + +Controls whether a sound plays when toggling Always On Top. + +**Type:** boolean +**Default:** `false` + +### DoNotActivateOnGameMode + +Controls whether Always On Top is automatically disabled during game mode. + +**Type:** boolean +**Default:** `true` + +### RoundCornersEnabled + +Controls whether the frame has rounded corners. + +**Type:** boolean +**Default:** `true` + +### ExcludedApps + +List of applications excluded from Always On Top functionality. + +**Type:** string (newline-separated list of executable names) + +## Examples + +### Example 1 - Enable with default settings using direct execution + +This example enables Always On Top with default border appearance. + +```powershell +$config = @{ + settings = @{ + properties = @{ + FrameEnabled = $true + FrameThickness = 5 + FrameColor = "#FF0000" + FrameOpacity = 100 + } + name = "AlwaysOnTop" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module AlwaysOnTop ` + --input $config +``` + +### Example 2 - Customize frame appearance with DSC + +This example configures a custom border color and thickness. + +```bash +dsc config set --file alwaysontop-appearance.dsc.yaml +``` + +```yaml +# alwaysontop-appearance.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Customize Always On Top frame + type: Microsoft.PowerToys/AlwaysOnTopSettings + properties: + settings: + properties: + FrameEnabled: true + FrameThickness: 8 + FrameColor: "#0078D7" + FrameOpacity: 80 + RoundCornersEnabled: true + name: AlwaysOnTop + version: 1.0 +``` + +### Example 3 - Configure with accent color using WinGet + +This example installs PowerToys and configures Always On Top to use the +Windows accent color. + +```bash +winget configure winget-alwaysontop.yaml +``` + +```yaml +# winget-alwaysontop.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Always On Top + type: Microsoft.PowerToys/AlwaysOnTopSettings + properties: + settings: + properties: + FrameEnabled: true + FrameAccentColor: true + FrameThickness: 6 + SoundEnabled: true + name: AlwaysOnTop + version: 1.0 +``` + +### Example 4 - Disable for gaming + +This example ensures Always On Top is disabled during game mode. + +```yaml +# alwaysontop-gaming.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure for gaming + type: Microsoft.PowerToys/AlwaysOnTopSettings + properties: + settings: + properties: + DoNotActivateOnGameMode: true + name: AlwaysOnTop + version: 1.0 +``` + +### Example 5 - Minimal border configuration + +This example configures a subtle, thin border. + +```powershell +$config = @{ + settings = @{ + properties = @{ + FrameEnabled = $true + FrameThickness = 2 + FrameOpacity = 50 + RoundCornersEnabled = true + } + name = "AlwaysOnTop" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module AlwaysOnTop --input $config +``` + +### Example 6 - Exclude specific applications + +This example excludes certain applications from Always On Top. + +```yaml +# alwaysontop-exclusions.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Exclude apps from Always On Top + type: Microsoft.PowerToys/AlwaysOnTopSettings + properties: + settings: + properties: + ExcludedApps: | + Game.exe + FullScreenApp.exe + name: AlwaysOnTop + version: 1.0 +``` + +## Use cases + +### Reference material + +Keep documentation or reference windows visible: + +```yaml +resources: + - name: Reference window settings + type: Microsoft.PowerToys/AlwaysOnTopSettings + properties: + settings: + properties: + FrameEnabled: true + FrameColor: "#00FF00" + FrameOpacity: 60 + name: AlwaysOnTop + version: 1.0 +``` + +### Monitoring dashboards + +Pin monitoring tools and dashboards: + +```yaml +resources: + - name: Monitoring settings + type: Microsoft.PowerToys/AlwaysOnTopSettings + properties: + settings: + properties: + FrameEnabled: true + FrameAccentColor: true + SoundEnabled: false + name: AlwaysOnTop + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [FancyZones Module][03] - Window layout manager +- [PowerToys Always On Top Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./FancyZones.md +[04]: https://learn.microsoft.com/windows/powertoys/always-on-top diff --git a/doc/dsc/modules/App.md b/doc/dsc/modules/App.md new file mode 100644 index 0000000000..22c85c4534 --- /dev/null +++ b/doc/dsc/modules/App.md @@ -0,0 +1,279 @@ +--- +description: DSC configuration reference for PowerToys App module (general settings) +ms.date: 10/18/2025 +ms.topic: reference +title: App module +--- + +# App Module + +## Synopsis + +Manages general PowerToys application settings, including utility enable/disable states, startup behavior, and theme preferences. + +## Description + +The `App` module controls global PowerToys settings that affect the entire +application. This includes which utilities are enabled, whether PowerToys +runs at startup, the application theme, and other general preferences. + +Unlike other modules that configure specific utilities, the App module +manages PowerToys-wide settings and the enabled state of all utilities. + +## Properties + +The App module supports the following configurable properties: + +### Enabled + +Controls which PowerToys utilities are enabled or disabled. + +**Type:** Object +**Properties:** + +- `AdvancedPaste` (boolean) - Enable/disable Advanced Paste utility. +- `AlwaysOnTop` (boolean) - Enable/disable Always On Top utility. +- `Awake` (boolean) - Enable/disable Awake utility. +- `ColorPicker` (boolean) - Enable/disable Color Picker utility. +- `CropAndLock` (boolean) - Enable/disable Crop And Lock utility. +- `EnvironmentVariables` (boolean) - Enable/disable Environment Variables + utility. +- `FancyZones` (boolean) - Enable/disable FancyZones utility. +- `FileLocksmith` (boolean) - Enable/disable File Locksmith utility. +- `FindMyMouse` (boolean) - Enable/disable Find My Mouse utility. +- `Hosts` (boolean) - Enable/disable Hosts File Editor utility. +- `ImageResizer` (boolean) - Enable/disable Image Resizer utility. +- `KeyboardManager` (boolean) - Enable/disable Keyboard Manager utility. +- `MeasureTool` (boolean) - Enable/disable Measure Tool utility. +- `MouseHighlighter` (boolean) - Enable/disable Mouse Highlighter utility. +- `MouseJump` (boolean) - Enable/disable Mouse Jump utility. +- `MousePointerCrosshairs` (boolean) - Enable/disable Mouse Pointer + Crosshairs utility. +- `Peek` (boolean) - Enable/disable Peek utility. +- `PowerAccent` (boolean) - Enable/disable Power Accent utility. +- `PowerOCR` (boolean) - Enable/disable Power OCR utility. +- `PowerRename` (boolean) - Enable/disable Power Rename utility. +- `RegistryPreview` (boolean) - Enable/disable Registry Preview utility. +- `ShortcutGuide` (boolean) - Enable/disable Shortcut Guide utility. +- `Workspaces` (boolean) - Enable/disable Workspaces utility. +- `ZoomIt` (boolean) - Enable/disable ZoomIt utility. + +### startup + +Controls whether PowerToys starts automatically when you sign in. + +**Type:** boolean +**Default:** `true` + +### run_elevated + +Controls whether PowerToys runs with administrator privileges. + +**Type:** boolean +**Default:** `false` + +### theme + +Sets the application theme. + +**Type:** string +**Allowed values:** `"light"`, `"dark"`, `"system"` +**Default:** `"system"` + +## Examples + +### Example 1 - Enable specific utilities with direct execution + +This example enables only FancyZones, PowerRename, and ColorPicker while +disabling all others. + +```powershell +$config = @{ + settings = @{ + properties = @{ + Enabled = @{ + AdvancedPaste = $false + AlwaysOnTop = $false + Awake = $false + ColorPicker = $true + CropAndLock = $false + EnvironmentVariables = $false + FancyZones = $true + FileLocksmith = $false + FindMyMouse = $false + Hosts = $false + ImageResizer = $false + KeyboardManager = $false + MeasureTool = $false + MouseHighlighter = $false + MouseJump = $false + MousePointerCrosshairs = $false + Peek = $false + PowerAccent = $false + PowerOCR = $false + PowerRename = $true + RegistryPreview = $false + ShortcutGuide = $false + Workspaces = $false + ZoomIt = $false + } + } + name = "App" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module App --input $config +``` + +### Example 2 - Configure startup and theme with DSC + +This example configures PowerToys to run at startup with elevated privileges +and use dark theme. + +```bash +dsc config set --file app-config.dsc.yaml +``` + +```yaml +# app-config.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure PowerToys general settings + type: Microsoft.PowerToys/AppSettings + properties: + settings: + properties: + startup: true + run_elevated: true + theme: dark + name: App + version: 1.0 +``` + +### Example 3 - Enable all utilities with WinGet + +This example installs PowerToys and enables all available utilities. + +```bash +winget configure winget-enable-all.yaml +``` + +```yaml +# winget-enable-all.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Enable all utilities + type: Microsoft.PowerToys/AppSettings + properties: + settings: + properties: + Enabled: + AdvancedPaste: true + AlwaysOnTop: true + Awake: true + ColorPicker: true + CropAndLock: true + EnvironmentVariables: true + FancyZones: true + FileLocksmith: true + FindMyMouse: true + Hosts: true + ImageResizer: true + KeyboardManager: true + MeasureTool: true + MouseHighlighter: true + MouseJump: true + MousePointerCrosshairs: true + Peek: true + PowerAccent: true + PowerOCR: true + PowerRename: true + RegistryPreview: true + ShortcutGuide: true + Workspaces: true + ZoomIt: true + name: App + version: 1.0 +``` + +### Example 4 - Test if specific utilities are enabled + +This example tests whether FancyZones and PowerRename are enabled. + +```powershell +$desired = @{ + settings = @{ + properties = @{ + Enabled = @{ + FancyZones = $true + PowerRename = $true + } + } + name = "App" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +$result = PowerToys.DSC.exe test --resource 'settings' --module App ` + --input $desired | ConvertFrom-Json + +if ($result._inDesiredState) { + Write-Host "FancyZones and PowerRename are enabled" +} else { + Write-Host "Configuration needs to be updated" +} +``` + +### Example 5 - Individual resource for each utility + +This example shows enabling utilities individually, which provides better granularity for complex configurations. + +```powershell +# Get current state +PowerToys.DSC.exe get --resource 'settings' --module App + +# Enable individual utilities +$config = @{ + settings = @{ + properties = @{ + Enabled = @{ + FancyZones = $true + } + } + name = "App" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module App --input $config +``` + +### Example 6 - Get schema for App module + +This example retrieves the complete JSON schema for the App module. + +```powershell +PowerToys.DSC.exe schema --resource 'settings' --module App | ` + ConvertFrom-Json | ConvertTo-Json -Depth 10 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [Awake][03] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./Awake.md diff --git a/doc/dsc/modules/Awake.md b/doc/dsc/modules/Awake.md new file mode 100644 index 0000000000..33a227343b --- /dev/null +++ b/doc/dsc/modules/Awake.md @@ -0,0 +1,342 @@ +--- +description: DSC configuration reference for PowerToys Awake module +ms.date: 10/18/2025 +ms.topic: reference +title: Awake Module +--- + +# Awake Module + +## Synopsis + +Manages configuration for the Awake utility, which keeps your computer awake without changing power settings. + +## Description + +The `Awake` module configures PowerToys Awake, a utility that prevents your +computer from going to sleep or turning off the display. This is useful +during installations, presentations, or any scenario where you need to +temporarily override power settings without permanently changing them. + +Awake supports multiple modes including indefinite keep-awake, timed +intervals, and scheduled expiration. The display can be kept on or allowed +to turn off independently of the system sleep state. + +## Properties + +The Awake module supports the following configurable properties: + +### keepDisplayOn + +Controls whether the display remains on while Awake is active. + +**Type:** boolean +**Default:** `true` +**Description:** When `true`, prevents the display from turning off. When +`false`, only prevents system sleep while allowing the display to turn off +according to power settings. + +### mode + +Specifies the Awake operating mode. + +**Type:** integer +**Allowed values:** + +- `0` - Off (Awake is disabled). +- `1` - Keep awake indefinitely. +- `2` - Keep awake for a timed interval. +- `3` - Keep awake until a specific date/time. + +**Default:** `0` + +### intervalHours + +Number of hours to keep the system awake (used when mode is `2`). + +**Type:** integer +**Range:** `0` to `999` +**Default:** `0` + +### intervalMinutes + +Number of minutes to keep the system awake (used when mode is `2`). + +**Type:** integer +**Range:** `0` to `59` +**Default:** `1` + +### expirationDateTime + +The date and time when Awake should automatically disable (used when mode is `3`). + +**Type:** string (ISO 8601 datetime format) +**Format:** `"YYYY-MM-DDTHH:mm:ss.fffffffzzz"` +**Example:** `"2025-12-31T23:59:59.0000000-08:00"` + +### customTrayTimes + +Custom time intervals displayed in the system tray context menu for quick activation. + +**Type:** object +**Description:** A dictionary of custom time presets for quick access. Keys +are display names, values are time specifications. + +## Examples + +### Example 1 - Keep awake indefinitely with display on + +This example configures Awake to keep the system and display awake +indefinitely using direct execution. + +```powershell +$config = @{ + settings = @{ + properties = @{ + keepDisplayOn = $true + mode = 1 + } + name = "Awake" + version = "0.0.1" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module Awake --input $config +``` + +### Example 2 - Keep awake for 2 hours with DSC + +This example configures a timed keep-awake period. + +```bash +dsc config set --file awake-timed.dsc.yaml +``` + +```yaml +# awake-timed.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Awake for 2 hours + type: Microsoft.PowerToys/AwakeSettings + properties: + settings: + properties: + keepDisplayOn: true + mode: 2 + intervalHours: 2 + intervalMinutes: 0 + name: Awake + version: 0.0.1 +``` + +### Example 3 - Keep awake until specific time with WinGet + +This example configures Awake to stay active until a specific date and time. + +```bash +winget configure winget-awake-scheduled.yaml +``` + +```yaml +# winget-awake-scheduled.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Keep awake until end of workday + type: Microsoft.PowerToys/AwakeSettings + properties: + settings: + properties: + keepDisplayOn: true + mode: 3 + expirationDateTime: "2025-10-18T17:00:00.0000000-07:00" + name: Awake + version: 0.0.1 +``` + +### Example 4 - Disable Awake + +This example disables Awake using direct execution. + +```powershell +$config = @{ + settings = @{ + properties = @{ + mode = 0 + } + name = "Awake" + version = "0.0.1" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module Awake --input $config +``` + +### Example 5 - Keep system awake but allow display to sleep + +This example keeps the system awake while allowing the display to turn off. + +```bash +dsc config set --file awake-system-only.dsc.yaml +``` + +```yaml +# awake-system-only.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Keep system awake only + type: Microsoft.PowerToys/AwakeSettings + properties: + settings: + properties: + keepDisplayOn: false + mode: 1 + name: Awake + version: 0.0.1 +``` + +### Example 6 - Configure for presentation (4 hours) + +This example configures Awake for a presentation scenario using WinGet. + +```bash +winget configure presentation-mode.yaml +``` + +```yaml +# presentation-mode.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Enable Awake for presentation + type: Microsoft.PowerToys/AwakeSettings + properties: + settings: + properties: + keepDisplayOn: true + mode: 2 + intervalHours: 4 + intervalMinutes: 0 + name: Awake + version: 0.0.1 +``` + +### Example 7 - Test current configuration + +This example tests whether Awake is configured for indefinite keep-awake. + +```powershell +$desired = @{ + settings = @{ + properties = @{ + keepDisplayOn = $true + mode = 1 + } + name = "Awake" + version = "0.0.1" + } +} | ConvertTo-Json -Depth 10 -Compress + +$result = PowerToys.DSC.exe test --resource 'settings' --module Awake --input $desired | ConvertFrom-Json + +if ($result._inDesiredState) { + Write-Host "Awake is configured for indefinite keep-awake" +} else { + Write-Host "Awake configuration differs from desired state" +} +``` + +### Example 8 - Get current Awake configuration + +This example retrieves the current Awake settings. + +```powershell +PowerToys.DSC.exe get --resource 'settings' --module Awake | ConvertFrom-Json | ConvertTo-Json -Depth 10 +``` + +### Example 9 - Get Awake schema + +This example retrieves the JSON schema for Awake module properties. + +```powershell +PowerToys.DSC.exe schema --resource 'settings' --module Awake | ConvertFrom-Json | ConvertTo-Json -Depth 10 +``` + +## Use cases + +### Development and builds + +Keep the system awake during long-running builds or installations: + +```yaml +resources: + - name: Keep awake during build + type: Microsoft.PowerToys/AwakeSettings + properties: + settings: + properties: + mode: 2 + intervalHours: 8 + intervalMinutes: 0 + keepDisplayOn: false + name: Awake + version: 0.0.1 +``` + +### Presentations and demos + +Ensure the system stays awake during presentations: + +```yaml +resources: + - name: Presentation mode + type: Microsoft.PowerToys/AwakeSettings + properties: + settings: + properties: + mode: 1 + keepDisplayOn: true + name: Awake + version: 0.0.1 +``` + +### Scheduled maintenance + +Keep the system awake until a specific time for scheduled tasks: + +```yaml +resources: + - name: Maintenance window + type: Microsoft.PowerToys/AwakeSettings + properties: + settings: + properties: + mode: 3 + expirationDateTime: "2025-10-19T02:00:00.0000000-07:00" + keepDisplayOn: false + name: Awake + version: 0.0.1 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [PowerRename][03] +- [PowerToys Awake Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./PowerRename.md +[04]: https://learn.microsoft.com/windows/powertoys/awake diff --git a/doc/dsc/modules/ColorPicker.md b/doc/dsc/modules/ColorPicker.md new file mode 100644 index 0000000000..c96025276c --- /dev/null +++ b/doc/dsc/modules/ColorPicker.md @@ -0,0 +1,307 @@ +--- +description: DSC configuration reference for PowerToys ColorPicker module +ms.date: 10/18/2025 +ms.topic: reference +title: ColorPicker Module +--- + +# ColorPicker Module + +## Synopsis + +Manages configuration for the Color Picker utility, a system-wide color selection and identification tool. + +## Description + +The `ColorPicker` module configures PowerToys Color Picker, a utility that allows you to pick colors from anywhere on your screen and copy them to the clipboard in various formats. It's useful for designers, developers, and anyone working with colors. + +## Properties + +The ColorPicker module supports the following configurable properties: + +### ActivationShortcut + +Sets the keyboard shortcut to activate the color picker. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier. +- `ctrl` (boolean) - Ctrl key modifier. +- `alt` (boolean) - Alt key modifier. +- `shift` (boolean) - Shift key modifier. +- `code` (integer) - Virtual key code. +- `key` (string) - Key name. + +**Default:** `Win+Shift+C` + +### changecursor + +Controls whether the cursor changes when the color picker is activated. + +**Type:** boolean +**Default:** `true` + +### copiedcolorrepresentation + +Sets the default color format copied to the clipboard. + +**Type:** string +**Allowed values:** `"HEX"`, `"RGB"`, `"HSL"`, `"HSV"`, `"CMYK"`, `"HSB"`, +`"HSI"`, `"HWB"`, `"NCol"` +**Default:** `"HEX"` + +### activationaction + +Controls the action when the color picker activation shortcut is pressed. + +**Type:** integer +**Allowed values:** + +- `0` - Open color picker and show editor +- `1` - Open color picker only +- `2` - Open editor only + +**Default:** `0` + +### showColorName + +Controls whether color names are displayed in the color picker. + +**Type:** boolean +**Default:** `false` + +### VisibleColorFormats + +Defines which color formats are visible in the picker interface. + +**Type:** object with boolean properties for each format: + +- `HEX` (boolean) +- `RGB` (boolean) +- `HSL` (boolean) +- `HSV` (boolean) +- `CMYK` (boolean) +- `HSB` (boolean) +- `HSI` (boolean) +- `HWB` (boolean) +- `NCol` (boolean) +- `Decimal` (boolean) + +## Examples + +### Example 1 - Configure default color format with direct execution + +This example sets the default copied color format to RGB. + +```powershell +$config = @{ + settings = @{ + properties = @{ + copiedcolorrepresentation = "RGB" + } + name = "ColorPicker" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module ColorPicker --input $config +``` + +### Example 2 - Configure activation behavior with DSC + +This example configures the color picker to open directly without the +editor. + +```bash +dsc config set --file colorpicker-activation.dsc.yaml +``` + +```yaml +# colorpicker-activation.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Color Picker activation + type: Microsoft.PowerToys/ColorPickerSettings + properties: + settings: + properties: + activationaction: 1 + changecursor: true + copiedcolorrepresentation: HEX + name: ColorPicker + version: 1.0 +``` + +### Example 3 - Install and configure for web development with WinGet + +This example installs PowerToys and configures Color Picker for web +developers. + +```bash +winget configure winget-colorpicker-webdev.yaml +``` + +```yaml +# winget-colorpicker-webdev.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Color Picker for web development + type: Microsoft.PowerToys/ColorPickerSettings + properties: + settings: + properties: + copiedcolorrepresentation: HEX + showColorName: true + changecursor: true + VisibleColorFormats: + HEX: true + RGB: true + HSL: true + HSV: false + CMYK: false + name: ColorPicker + version: 1.0 +``` + +### Example 4 - Configure visible formats + +This example enables only HEX, RGB, and HSL formats. + +```bash +dsc config set --file colorpicker-formats.dsc.yaml +``` + +```yaml +# colorpicker-formats.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure visible color formats + type: Microsoft.PowerToys/ColorPickerSettings + properties: + settings: + properties: + VisibleColorFormats: + HEX: true + RGB: true + HSL: true + HSV: false + CMYK: false + HSB: false + HSI: false + HWB: false + NCol: false + Decimal: false + name: ColorPicker + version: 1.0 +``` + +### Example 5 - Configure for graphic design + +This example configures Color Picker for graphic designers with CMYK support. + +```powershell +$config = @{ + settings = @{ + properties = @{ + copiedcolorrepresentation = "CMYK" + showColorName = $true + VisibleColorFormats = @{ + HEX = $true + RGB = $true + CMYK = $true + HSL = $true + HSV = $true + } + } + name = "ColorPicker" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module ColorPicker --input $config +``` + +### Example 6 - Test configuration + +This example tests whether HEX is the default format. + +```powershell +$desired = @{ + settings = @{ + properties = @{ + copiedcolorrepresentation = "HEX" + } + name = "ColorPicker" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +$result = PowerToys.DSC.exe test --resource 'settings' --module ColorPicker ` + --input $desired | ConvertFrom-Json + +if ($result._inDesiredState) { + Write-Host "HEX is the default format" +} +``` + +## Use cases + +### Web development + +Configure for HTML/CSS color codes: + +```yaml +resources: + - name: Web developer settings + type: Microsoft.PowerToys/ColorPickerSettings + properties: + settings: + properties: + copiedcolorrepresentation: HEX + VisibleColorFormats: + HEX: true + RGB: true + HSL: true + name: ColorPicker + version: 1.0 +``` + +### Print design + +Configure for CMYK color space: + +```yaml +resources: + - name: Print designer settings + type: Microsoft.PowerToys/ColorPickerSettings + properties: + settings: + properties: + copiedcolorrepresentation: CMYK + showColorName: true + name: ColorPicker + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [ImageResizer][03] +- [PowerToys Color Picker Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./ImageResizer.md +[04]: https://learn.microsoft.com/windows/powertoys/color-picker diff --git a/doc/dsc/modules/CropAndLock.md b/doc/dsc/modules/CropAndLock.md new file mode 100644 index 0000000000..d4799dae88 --- /dev/null +++ b/doc/dsc/modules/CropAndLock.md @@ -0,0 +1,195 @@ +--- +description: DSC configuration reference for PowerToys CropAndLock module +ms.date: 10/18/2025 +ms.topic: reference +title: CropAndLock Module +--- + +# CropAndLock Module + +## Synopsis + +Manages configuration for the Crop And Lock utility, which crops and locks portions of windows. + +## Description + +The `CropAndLock` module configures PowerToys Crop And Lock, a utility that allows you to crop a portion of any window and keep it visible as a thumbnail. This is useful for monitoring specific parts of applications, keeping reference information visible, or focusing on particular UI elements. + +## Properties + +The CropAndLock module supports the following configurable properties: + +### Hotkey + +Sets the keyboard shortcut to activate Crop And Lock for the active window. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier. +- `ctrl` (boolean) - Ctrl key modifier. +- `alt` (boolean) - Alt key modifier. +- `shift` (boolean) - Shift key modifier. +- `code` (integer) - Virtual key code. +- `key` (string) - Key name. + +**Default:** `Win+Ctrl+Shift+T` + +### ReparentHotkey + +Sets the keyboard shortcut to change the parent window of a cropped thumbnail. + +**Type:** object (same structure as Hotkey) + +### ThumbnailOpacity + +Sets the opacity of cropped thumbnails (0-100). + +**Type:** integer +**Range:** `0` to `100` +**Default:** `100` + +## Examples + +### Example 1 - Configure basic settings with direct execution + +This example sets the Crop And Lock hotkey and thumbnail opacity. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ThumbnailOpacity = 90 + } + name = "CropAndLock" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module CropAndLock --input $config +``` + +### Example 2 - Configure hotkeys with DSC + +This example configures custom hotkeys for cropping and reparenting. + +```bash +dsc config set --file cropandlock-hotkeys.dsc.yaml +``` + +```yaml +# cropandlock-hotkeys.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Crop And Lock hotkeys + type: Microsoft.PowerToys/CropAndLockSettings + properties: + settings: + properties: + Hotkey: + win: true + ctrl: true + shift: true + alt: false + code: 84 + key: T + ThumbnailOpacity: 85 + name: CropAndLock + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Crop And Lock. + +```bash +winget configure winget-cropandlock.yaml +``` + +```yaml +# winget-cropandlock.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Crop And Lock + type: Microsoft.PowerToys/CropAndLockSettings + properties: + settings: + properties: + ThumbnailOpacity: 75 + name: CropAndLock + version: 1.0 +``` + +### Example 4 - Semi-transparent thumbnails + +This example configures thumbnails to be semi-transparent for overlay use. + +```yaml +# cropandlock-transparent.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Semi-transparent thumbnails + type: Microsoft.PowerToys/CropAndLockSettings + properties: + settings: + properties: + ThumbnailOpacity: 60 + name: CropAndLock + version: 1.0 +``` + +## Use cases + +### Monitoring dashboards + +Keep portions of monitoring tools visible: + +```yaml +resources: + - name: Monitoring configuration + type: Microsoft.PowerToys/CropAndLockSettings + properties: + settings: + properties: + ThumbnailOpacity: 80 + name: CropAndLock + version: 1.0 +``` + +### Reference material + +Crop and display reference information: + +```yaml +resources: + - name: Reference display + type: Microsoft.PowerToys/CropAndLockSettings + properties: + settings: + properties: + ThumbnailOpacity: 95 + name: CropAndLock + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [MouseJump][03] +- [PowerToys Crop And Lock Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./MouseJump.md +[04]: https://learn.microsoft.com/windows/powertoys/crop-and-lock diff --git a/doc/dsc/modules/EnvironmentVariables.md b/doc/dsc/modules/EnvironmentVariables.md new file mode 100644 index 0000000000..e6ae196935 --- /dev/null +++ b/doc/dsc/modules/EnvironmentVariables.md @@ -0,0 +1,193 @@ +--- +description: DSC configuration reference for PowerToys EnvironmentVariables module +ms.date: 10/18/2025 +ms.topic: reference +title: EnvironmentVariables Module +--- + +# EnvironmentVariables Module + +## Synopsis + +Manages configuration for the Environment Variables utility, a quick editor for system and user environment variables. + +## Description + +The `EnvironmentVariables` module configures PowerToys Environment Variables, a utility that provides an enhanced interface for viewing and editing Windows environment variables. It offers a more user-friendly alternative to the standard Windows environment variable editor. + +## Properties + +The EnvironmentVariables module supports the following configurable properties: + +### LaunchAdministrator + +Controls whether the Environment Variables editor launches with administrator privileges by default. + +**Type:** boolean +**Default:** `false` +**Description:** When enabled, the editor will always attempt to launch with elevated permissions, allowing editing of system-wide environment variables. + +## Examples + +### Example 1 - Enable admin launch with direct execution + +This example configures the Environment Variables editor to always launch with admin rights. + +```powershell +$config = @{ + settings = @{ + properties = @{ + LaunchAdministrator = $true + } + name = "EnvironmentVariables" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module EnvironmentVariables --input $config +``` + +### Example 2 - Configure with DSC + +This example enables administrator launch through DSC configuration. + +```bash +dsc config set --file environmentvariables-config.dsc.yaml +``` + +```yaml +# environmentvariables-config.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Environment Variables editor + type: Microsoft.PowerToys/EnvironmentVariablesSettings + properties: + settings: + properties: + LaunchAdministrator: true + name: EnvironmentVariables + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Environment Variables for +admin launch. + +```bash +winget configure winget-envvars.yaml +``` + +```yaml +# winget-envvars.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Environment Variables + type: Microsoft.PowerToys/EnvironmentVariablesSettings + properties: + settings: + properties: + LaunchAdministrator: true + name: EnvironmentVariables + version: 1.0 +``` + +### Example 4 - Standard user mode + +This example configures for standard user access (no elevation). + +```bash +dsc config set --file envvars-user.dsc.yaml +``` + +```yaml +# envvars-user.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: User-level Environment Variables + type: Microsoft.PowerToys/EnvironmentVariablesSettings + properties: + settings: + properties: + LaunchAdministrator: false + name: EnvironmentVariables + version: 1.0 +``` + +### Example 5 - Test admin launch configuration + +This example tests whether admin launch is enabled. + +```powershell +$desired = @{ + settings = @{ + properties = @{ + LaunchAdministrator = $true + } + name = "EnvironmentVariables" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +$result = PowerToys.DSC.exe test --resource 'settings' --module EnvironmentVariables --input $desired | ConvertFrom-Json + +if ($result._inDesiredState) { + Write-Host "Admin launch is enabled" +} +``` + +## Use cases + +### System administration + +Configure for system-wide environment variable management: + +```yaml +resources: + - name: Admin configuration + type: Microsoft.PowerToys/EnvironmentVariablesSettings + properties: + settings: + properties: + LaunchAdministrator: true + name: EnvironmentVariables + version: 1.0 +``` + +### Development workstations + +Configure for user-level variable management: + +```yaml +resources: + - name: Developer configuration + type: Microsoft.PowerToys/EnvironmentVariablesSettings + properties: + settings: + properties: + LaunchAdministrator: false + name: EnvironmentVariables + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [Hosts][03] +- [PowerToys Environment Variables Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./Hosts.md +[04]: https://learn.microsoft.com/windows/powertoys/environment-variables diff --git a/doc/dsc/modules/FancyZones.md b/doc/dsc/modules/FancyZones.md new file mode 100644 index 0000000000..574e532aba --- /dev/null +++ b/doc/dsc/modules/FancyZones.md @@ -0,0 +1,545 @@ +--- +description: DSC configuration reference for PowerToys FancyZones module +ms.date: 10/18/2025 +ms.topic: reference +title: FancyZones Module +--- + +# FancyZones Module + +## Synopsis + +Manages configuration for the FancyZones utility, a window layout manager that arranges and snaps windows into efficient layouts. + +## Description + +The `FancyZones` module configures PowerToys FancyZones, a window manager +utility that helps organize windows into custom layouts called zones. +FancyZones allows you to create multiple zone layouts for different displays +and quickly snap windows into position using keyboard shortcuts or mouse +actions. + +This module controls activation methods, window behavior, zone appearance, editor settings, and other FancyZones preferences. + +## Properties + +The FancyZones module supports the following configurable properties: + +### fancyzones_shiftDrag + +Controls whether holding Shift while dragging a window activates zone snapping. + +**Type:** boolean +**Default:** `true` + +### fancyzones_mouseSwitch + +Controls whether moving a window across monitors triggers zone selection. + +**Type:** boolean +**Default:** `false` + +### fancyzones_overrideSnapHotkeys + +Controls whether FancyZones overrides the Windows Snap hotkeys (Win+Arrow keys). + +**Type:** boolean +**Default:** `false` + +### fancyzones_moveWindowsAcrossMonitors + +Controls whether moving windows between monitors is enabled. + +**Type:** boolean +**Default:** `false` + +### fancyzones_moveWindowsBasedOnPosition + +Controls whether windows move to zones based on cursor position rather than window position. + +**Type:** boolean +**Default:** `false` + +### fancyzones_overlappingZonesAlgorithm + +Determines the algorithm used when multiple zones overlap. + +**Type:** integer +**Allowed values:** + +- `0` - Smallest zone +- `1` - Largest zone +- `2` - Positional (based on cursor/window position) + +**Default:** `0` + +### fancyzones_displayOrWorkAreaChange_moveWindows + +Controls whether windows are moved to fit when display or work area changes. + +**Type:** boolean +**Default:** `false` + +### fancyzones_zoneSetChange_flashZones + +Controls whether zones flash briefly when the zone set changes. + +**Type:** boolean +**Default:** `false` + +### fancyzones_zoneSetChange_moveWindows + +Controls whether windows are automatically moved when the zone set changes. + +**Type:** boolean +**Default:** `false` + +### fancyzones_appLastZone_moveWindows + +Controls whether windows are moved to their last known zone when reopened. + +**Type:** boolean +**Default:** `true` + +### fancyzones_openWindowOnActiveMonitor + +Controls whether newly opened windows appear on the currently active monitor. + +**Type:** boolean +**Default:** `false` + +### fancyzones_spanZonesAcrossMonitors + +Controls whether zones can span across multiple monitors. + +**Type:** boolean +**Default:** `false` + +### fancyzones_makeDraggedWindowTransparent + +Controls whether dragged windows become transparent to show zones underneath. + +**Type:** boolean +**Default:** `true` + +### fancyzones_zoneColor + +Sets the color of zone areas. + +**Type:** string (hex color) +**Format:** `"#RRGGBB"` +**Example:** `"#0078D7"` +**Default:** `"#0078D7"` + +### fancyzones_zoneBorderColor + +Sets the color of zone borders. + +**Type:** string (hex color) +**Format:** `"#RRGGBB"` +**Example:** `"#FFFFFF"` +**Default:** `"#FFFFFF"` + +### fancyzones_zoneHighlightColor + +Sets the highlight color when a zone is activated. + +**Type:** string (hex color) +**Format:** `"#RRGGBB"` +**Example:** `"#0078D7"` +**Default:** `"#0078D7"` + +### fancyzones_highlightOpacity + +Sets the opacity of zone highlights (0-100). + +**Type:** integer +**Range:** `0` to `100` +**Default:** `50` + +### fancyzones_editorHotkey + +Sets the keyboard shortcut to open the FancyZones editor. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier +- `ctrl` (boolean) - Ctrl key modifier +- `alt` (boolean) - Alt key modifier +- `shift` (boolean) - Shift key modifier +- `code` (integer) - Virtual key code +- `key` (string) - Key name + +**Default:** `Win+Shift+~` + +### fancyzones_windowSwitching + +Controls whether window switching with arrow keys is enabled. + +**Type:** boolean +**Default:** `true` + +### fancyzones_nextTabHotkey + +Sets the keyboard shortcut to switch to the next tab/window in a zone. + +**Type:** object (same structure as fancyzones_editorHotkey) + +### fancyzones_prevTabHotkey + +Sets the keyboard shortcut to switch to the previous tab/window in a zone. + +**Type:** object (same structure as fancyzones_editorHotkey) + +### fancyzones_excludedApps + +List of applications excluded from FancyZones snapping. + +**Type:** string (newline-separated list of executable names) +**Example:** `"Notepad.exe\nCalc.exe"` + +## Examples + +### Example 1 - Enable basic zone snapping with direct execution + +This example enables Shift-drag zone snapping and mouse-based monitor switching. + +```powershell +$config = @{ + settings = @{ + properties = @{ + fancyzones_shiftDrag = $true + fancyzones_mouseSwitch = $true + } + name = "FancyZones" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module FancyZones --input $config +``` + +### Example 2 - Configure window movement behavior with DSC + +This example configures how windows behave when displays or zones change. + +```bash +dsc config set --file fancyzones-window-behavior.dsc.yaml +``` + +```yaml +# fancyzones-window-behavior.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure FancyZones window behavior + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + fancyzones_displayOrWorkAreaChange_moveWindows: true + fancyzones_zoneSetChange_moveWindows: true + fancyzones_appLastZone_moveWindows: true + fancyzones_moveWindowsAcrossMonitors: true + name: FancyZones + version: 1.0 +``` + +### Example 3 - Customize zone appearance with WinGet + +This example installs PowerToys and configures custom zone colors and +opacity. + +```bash +winget configure winget-fancyzones-appearance.yaml +``` + +```yaml +# winget-fancyzones-appearance.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Customize FancyZones appearance + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + fancyzones_zoneColor: "#2D2D30" + fancyzones_zoneBorderColor: "#007ACC" + fancyzones_zoneHighlightColor: "#007ACC" + fancyzones_highlightOpacity: 75 + fancyzones_makeDraggedWindowTransparent: true + name: FancyZones + version: 1.0 +``` + +### Example 4 - Override Windows Snap hotkeys + +This example configures FancyZones to replace Windows default snap +functionality. + +```bash +dsc config set --file fancyzones-snap-override.dsc.yaml +``` + +```yaml +# fancyzones-snap-override.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Override Windows Snap + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + fancyzones_overrideSnapHotkeys: true + fancyzones_moveWindowsBasedOnPosition: true + name: FancyZones + version: 1.0 +``` + +### Example 5 - Configure editor hotkey + +This example changes the FancyZones editor hotkey to Ctrl+Shift+Alt+F. + +```powershell +$config = @{ + settings = @{ + properties = @{ + fancyzones_editorHotkey = @{ + win = $false + ctrl = $true + alt = $true + shift = $true + code = 70 # F key + key = "F" + } + } + name = "FancyZones" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module FancyZones --input $config +``` + +### Example 6 - Exclude applications from zone snapping + +This example configures FancyZones to ignore specific applications. + +```yaml +# fancyzones-exclusions.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Exclude apps from FancyZones + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + fancyzones_excludedApps: | + Notepad.exe + Calculator.exe + mspaint.exe + name: FancyZones + version: 1.0 +``` + +### Example 7 - Multi-monitor configuration + +This example configures FancyZones for optimal multi-monitor workflow. + +```bash +dsc config set --file fancyzones-multimonitor.dsc.yaml +``` + +```yaml +# fancyzones-multimonitor.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Multi-monitor FancyZones setup + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + fancyzones_shiftDrag: true + fancyzones_mouseSwitch: true + fancyzones_moveWindowsAcrossMonitors: true + fancyzones_spanZonesAcrossMonitors: false + fancyzones_openWindowOnActiveMonitor: true + fancyzones_displayOrWorkAreaChange_moveWindows: true + name: FancyZones + version: 1.0 +``` + +### Example 8 - Complete FancyZones configuration with WinGet + +This example shows a comprehensive FancyZones setup with installation. + +```bash +winget configure winget-fancyzones-complete.yaml +``` + +```yaml +# winget-fancyzones-complete.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Enable FancyZones + type: Microsoft.PowerToys/AppSettings + properties: + settings: + properties: + Enabled: + FancyZones: true + name: App + version: 1.0 + + - name: Configure FancyZones + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + # Activation + fancyzones_shiftDrag: true + fancyzones_mouseSwitch: true + fancyzones_overrideSnapHotkeys: false + + # Window behavior + fancyzones_moveWindowsAcrossMonitors: true + fancyzones_moveWindowsBasedOnPosition: false + fancyzones_displayOrWorkAreaChange_moveWindows: true + fancyzones_zoneSetChange_moveWindows: false + fancyzones_appLastZone_moveWindows: true + + # Appearance + fancyzones_makeDraggedWindowTransparent: true + fancyzones_zoneColor: "#0078D7" + fancyzones_zoneBorderColor: "#FFFFFF" + fancyzones_zoneHighlightColor: "#0078D7" + fancyzones_highlightOpacity: 50 + + # Multi-monitor + fancyzones_openWindowOnActiveMonitor: true + fancyzones_spanZonesAcrossMonitors: false + name: FancyZones + version: 1.0 +``` + +### Example 9 - Test FancyZones configuration + +This example tests whether FancyZones is configured for multi-monitor use. + +```powershell +$desired = @{ + settings = @{ + properties = @{ + fancyzones_moveWindowsAcrossMonitors = $true + fancyzones_openWindowOnActiveMonitor = $true + } + name = "FancyZones" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +$result = PowerToys.DSC.exe test --resource 'settings' --module FancyZones ` + --input $desired | ConvertFrom-Json + +if ($result._inDesiredState) { + Write-Host "FancyZones is configured for multi-monitor" +} else { + Write-Host "FancyZones configuration needs updating" +} +``` + +### Example 10 - Get FancyZones schema + +This example retrieves the complete JSON schema for FancyZones properties. + +```powershell +PowerToys.DSC.exe schema --resource 'settings' --module FancyZones | ` + ConvertFrom-Json | ConvertTo-Json -Depth 10 +``` + +## Use cases + +### Development workflow + +Configure FancyZones for efficient development with IDE, browser, and terminal windows: + +```yaml +resources: + - name: Developer layout + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + fancyzones_shiftDrag: true + fancyzones_overrideSnapHotkeys: true + fancyzones_appLastZone_moveWindows: true + name: FancyZones + version: 1.0 +``` + +### Presentation mode + +Optimize window management for presentations and screen sharing: + +```yaml +resources: + - name: Presentation layout + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + fancyzones_openWindowOnActiveMonitor: true + fancyzones_highlightOpacity: 30 + fancyzones_makeDraggedWindowTransparent: false + name: FancyZones + version: 1.0 +``` + +### Home office setup + +Configure for docking/undocking laptop scenarios: + +```yaml +resources: + - name: Home office configuration + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + fancyzones_displayOrWorkAreaChange_moveWindows: true + fancyzones_moveWindowsAcrossMonitors: true + fancyzones_appLastZone_moveWindows: true + name: FancyZones + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [Peek][03] +- [PowerToys FancyZones Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./Peek.md +[04]: https://learn.microsoft.com/windows/powertoys/fancyzones diff --git a/doc/dsc/modules/FileLocksmith.md b/doc/dsc/modules/FileLocksmith.md new file mode 100644 index 0000000000..48dcf1bc1a --- /dev/null +++ b/doc/dsc/modules/FileLocksmith.md @@ -0,0 +1,179 @@ +--- +description: DSC configuration reference for PowerToys FileLocksmith module +ms.date: 10/18/2025 +ms.topic: reference +title: FileLocksmith Module +--- + +# FileLocksmith Module + +## Synopsis + +Manages configuration for the File Locksmith utility, which identifies +processes that are locking files or folders. + +## Description + +The `FileLocksmith` module configures PowerToys File Locksmith, a Windows +shell extension that helps identify which processes are using (locking) +specific files or folders. It integrates with the Windows Explorer context +menu for easy access. + +## Properties + +The FileLocksmith module supports the following configurable properties: + +### ExtendedContextMenuOnly + +Controls whether File Locksmith appears only in the extended context menu. + +**Type:** boolean +**Default:** `false` +**Description:** When `true`, File Locksmith only appears in the context menu +when you hold Shift while right-clicking. When `false`, it appears in the +standard context menu. + +## Examples + +### Example 1 - Show in standard context menu with direct execution + +This example configures File Locksmith to appear in the standard context menu. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ExtendedContextMenuOnly = $false + } + name = "FileLocksmith" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module FileLocksmith ` + --input $config +``` + +### Example 2 - Extended menu only with DSC + +This example configures File Locksmith to appear only in the extended +context menu. + +```bash +dsc config set --file filelocksmith-extended.dsc.yaml +``` + +```yaml +# filelocksmith-extended.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure File Locksmith for extended menu + type: Microsoft.PowerToys/FileLocksmithSettings + properties: + settings: + properties: + ExtendedContextMenuOnly: true + name: FileLocksmith + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures File Locksmith for standard +menu access. + +```bash +winget configure winget-filelocksmith.yaml +``` + +```yaml +# winget-filelocksmith.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure File Locksmith + type: Microsoft.PowerToys/FileLocksmithSettings + properties: + settings: + properties: + ExtendedContextMenuOnly: false + name: FileLocksmith + version: 1.0 +``` + +### Example 4 - Minimize context menu clutter + +This example configures for extended menu to reduce clutter. + +```bash +dsc config set --file filelocksmith-minimal.dsc.yaml +``` + +```yaml +# filelocksmith-minimal.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Minimal context menu + type: Microsoft.PowerToys/FileLocksmithSettings + properties: + settings: + properties: + ExtendedContextMenuOnly: true + name: FileLocksmith + version: 1.0 +``` + +## Use cases + +### System administration + +Quick access for troubleshooting file locks: + +```yaml +resources: + - name: Admin quick access + type: Microsoft.PowerToys/FileLocksmithSettings + properties: + settings: + properties: + ExtendedContextMenuOnly: false + name: FileLocksmith + version: 1.0 +``` + +### Clean context menu + +Reduce menu clutter for casual users: + +```yaml +resources: + - name: Clean menu + type: Microsoft.PowerToys/FileLocksmithSettings + properties: + settings: + properties: + ExtendedContextMenuOnly: true + name: FileLocksmith + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [RegistryPreview][03] +- [PowerToys File Locksmith Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./RegistryPreview.md +[04]: https://learn.microsoft.com/windows/powertoys/file-locksmith diff --git a/doc/dsc/modules/FindMyMouse.md b/doc/dsc/modules/FindMyMouse.md new file mode 100644 index 0000000000..1d0acb7c46 --- /dev/null +++ b/doc/dsc/modules/FindMyMouse.md @@ -0,0 +1,288 @@ +--- +description: DSC configuration reference for PowerToys FindMyMouse module +ms.date: 10/18/2025 +ms.topic: reference +title: FindMyMouse Module +--- + +# FindMyMouse Module + +## Synopsis + +Manages configuration for the Find My Mouse utility, which helps locate your +mouse cursor on the screen. + +## Description + +The `FindMyMouse` module configures PowerToys Find My Mouse, a utility that +highlights your mouse cursor location when you press the Ctrl key. This is +particularly useful on large or multiple displays where the cursor can be +difficult to locate. + +## Properties + +The FindMyMouse module supports the following configurable properties: + +### DoNotActivateOnGameMode + +Controls whether Find My Mouse is disabled during game mode. + +**Type:** boolean +**Default:** `true` +**Description:** When enabled, Find My Mouse will not activate when Windows +game mode is active. + +### BackgroundColor + +Sets the background color of the spotlight effect. + +**Type:** string (hex color) +**Format:** `"#RRGGBB"` +**Default:** `"#000000"` (black) + +### SpotlightColor + +Sets the color of the spotlight circle around the cursor. + +**Type:** string (hex color) +**Format:** `"#RRGGBB"` +**Default:** `"#FFFFFF"` (white) + +### OverlayOpacity + +Sets the opacity of the background overlay (0-100). + +**Type:** integer +**Range:** `0` to `100` +**Default:** `50` + +### SpotlightRadius + +Sets the radius of the spotlight in pixels. + +**Type:** integer +**Range:** `50` to `500` +**Default:** `100` + +### AnimationDurationMs + +Sets the duration of the spotlight animation in milliseconds. + +**Type:** integer +**Range:** `0` to `5000` +**Default:** `500` + +### SpotlightInitialZoom + +Sets the initial zoom level of the spotlight effect. + +**Type:** integer +**Range:** `100` to `1000` +**Default:** `200` + +### ExcludedApps + +List of applications where Find My Mouse is disabled. + +**Type:** string (newline-separated list of executable names) + +## Examples + +### Example 1 - Configure spotlight appearance with direct execution + +This example customizes the spotlight colors and radius. + +```powershell +$config = @{ + settings = @{ + properties = @{ + BackgroundColor = "#000000" + SpotlightColor = "#00FF00" + SpotlightRadius = 150 + OverlayOpacity = 60 + } + name = "FindMyMouse" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module FindMyMouse --input $config +``` + +### Example 2 - Configure animation with DSC + +This example customizes the spotlight animation behavior. + +```bash +dsc config set --file findmymouse-animation.dsc.yaml +``` + +```yaml +# findmymouse-animation.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Find My Mouse animation + type: Microsoft.PowerToys/FindMyMouseSettings + properties: + settings: + properties: + AnimationDurationMs: 750 + SpotlightInitialZoom: 300 + SpotlightRadius: 120 + name: FindMyMouse + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Find My Mouse with custom +colors. + +```bash +winget configure winget-findmymouse.yaml +``` + +```yaml +# winget-findmymouse.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Find My Mouse + type: Microsoft.PowerToys/FindMyMouseSettings + properties: + settings: + properties: + BackgroundColor: "#000000" + SpotlightColor: "#0078D7" + OverlayOpacity: 70 + SpotlightRadius: 140 + DoNotActivateOnGameMode: true + name: FindMyMouse + version: 1.0 +``` + +### Example 4 - Subtle configuration + +This example creates a subtle, less intrusive spotlight effect. + +```bash +dsc config set --file findmymouse-subtle.dsc.yaml +``` + +```yaml +# findmymouse-subtle.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Subtle spotlight + type: Microsoft.PowerToys/FindMyMouseSettings + properties: + settings: + properties: + OverlayOpacity: 30 + SpotlightRadius: 100 + AnimationDurationMs: 300 + name: FindMyMouse + version: 1.0 +``` + +### Example 5 - High visibility configuration + +This example creates a high-visibility spotlight for accessibility. + +```powershell +$config = @{ + settings = @{ + properties = @{ + BackgroundColor = "#000000" + SpotlightColor = "#FFFF00" + OverlayOpacity = 80 + SpotlightRadius = 200 + SpotlightInitialZoom = 400 + } + name = "FindMyMouse" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module FindMyMouse --input $config +``` + +### Example 6 - Disable during gaming + +This example ensures Find My Mouse doesn't interfere with games. + +```bash +dsc config set --file findmymouse-gaming.dsc.yaml +``` + +```yaml +# findmymouse-gaming.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Gaming configuration + type: Microsoft.PowerToys/FindMyMouseSettings + properties: + settings: + properties: + DoNotActivateOnGameMode: true + name: FindMyMouse + version: 1.0 +``` + +## Use cases + +### Large displays + +Configure for high visibility on large screens: + +```yaml +resources: + - name: Large display configuration + type: Microsoft.PowerToys/FindMyMouseSettings + properties: + settings: + properties: + SpotlightRadius: 180 + OverlayOpacity: 70 + SpotlightColor: "#FFFFFF" + name: FindMyMouse + version: 1.0 +``` + +### Accessibility + +Configure for maximum visibility: + +```yaml +resources: + - name: Accessibility configuration + type: Microsoft.PowerToys/FindMyMouseSettings + properties: + settings: + properties: + SpotlightColor: "#FFFF00" + OverlayOpacity: 80 + SpotlightRadius: 200 + AnimationDurationMs: 1000 + name: FindMyMouse + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [MouseHighlighter][03] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./MouseHighlighter.md diff --git a/doc/dsc/modules/Hosts.md b/doc/dsc/modules/Hosts.md new file mode 100644 index 0000000000..2fedc79202 --- /dev/null +++ b/doc/dsc/modules/Hosts.md @@ -0,0 +1,200 @@ +--- +description: DSC configuration reference for PowerToys Hosts module +ms.date: 10/18/2025 +ms.topic: reference +title: Hosts Module +--- + +# Hosts Module + +## Synopsis + +Manages configuration for the Hosts File Editor utility, a quick editor for +the Windows hosts file. + +## Description + +The `Hosts` module configures PowerToys Hosts File Editor, a utility that +provides a user-friendly interface for viewing and editing the Windows hosts +file. It simplifies the process of adding, modifying, and managing DNS +entries in the hosts file. + +## Properties + +The Hosts module supports the following configurable properties: + +### LaunchAdministrator + +Controls whether the Hosts File Editor launches with administrator privileges +by default. + +**Type:** boolean +**Default:** `false` +**Description:** When enabled, the editor will always attempt to launch with +elevated permissions, which is required to edit the hosts file. + +### LoopbackDuplicates + +Controls how duplicate loopback addresses are handled. + +**Type:** boolean +**Default:** `false` + +### AdditionalLinesPosition + +Controls where additional lines are positioned when editing entries. + +**Type:** integer +**Allowed values:** + +- `0` - Top +- `1` - Bottom + +**Default:** `0` + +## Examples + +### Example 1 - Enable admin launch with direct execution + +This example configures the Hosts editor to always launch with admin rights. + +```powershell +$config = @{ + settings = @{ + properties = @{ + LaunchAdministrator = $true + } + name = "Hosts" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module Hosts --input $config +``` + +### Example 2 - Configure with DSC + +This example enables administrator launch and configures line positioning. + +```bash +dsc config set --file hosts-config.dsc.yaml +``` + +```yaml +# hosts-config.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Hosts File Editor + type: Microsoft.PowerToys/HostsSettings + properties: + settings: + properties: + LaunchAdministrator: true + AdditionalLinesPosition: 1 + name: Hosts + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures the Hosts editor for admin +launch. + +```bash +winget configure winget-hosts.yaml +``` + +```yaml +# winget-hosts.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Hosts File Editor + type: Microsoft.PowerToys/HostsSettings + properties: + settings: + properties: + LaunchAdministrator: true + LoopbackDuplicates: false + name: Hosts + version: 1.0 +``` + +### Example 4 - Development configuration + +This example configures for development use with new entries at the bottom. + +```bash +dsc config set --file hosts-development.dsc.yaml +``` + +```yaml +# hosts-development.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Development hosts configuration + type: Microsoft.PowerToys/HostsSettings + properties: + settings: + properties: + LaunchAdministrator: true + AdditionalLinesPosition: 1 + name: Hosts + version: 1.0 +``` + +## Use cases + +### System administration + +Configure for frequent hosts file editing: + +```yaml +resources: + - name: Admin configuration + type: Microsoft.PowerToys/HostsSettings + properties: + settings: + properties: + LaunchAdministrator: true + name: Hosts + version: 1.0 +``` + +### Web development + +Configure for development environment management: + +```yaml +resources: + - name: Developer configuration + type: Microsoft.PowerToys/HostsSettings + properties: + settings: + properties: + LaunchAdministrator: true + AdditionalLinesPosition: 1 + name: Hosts + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [KeyboardManager][03] +- [PowerToys Hosts File Editor Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./KeyboardManager.md +[04]: https://learn.microsoft.com/windows/powertoys/hosts-file-editor diff --git a/doc/dsc/modules/ImageResizer.md b/doc/dsc/modules/ImageResizer.md new file mode 100644 index 0000000000..65c81638ef --- /dev/null +++ b/doc/dsc/modules/ImageResizer.md @@ -0,0 +1,349 @@ +--- +description: DSC configuration reference for PowerToys ImageResizer module +ms.date: 10/18/2025 +ms.topic: reference +title: ImageResizer Module +--- + +# ImageResizer Module + +## Synopsis + +Manages configuration for the Image Resizer utility, which provides quick +image resizing from the Windows Explorer context menu. + +## Description + +The `ImageResizer` module configures PowerToys Image Resizer, a Windows shell +extension that allows you to resize one or multiple images directly from the +File Explorer context menu. It supports custom size presets and various +resize options. + +## Properties + +The ImageResizer module supports the following configurable properties: + +### ImageResizerSizes + +Defines the preset sizes available in the Image Resizer interface. + +**Type:** array of objects +**Object properties:** + +- `Name` (string) - Display name for the preset +- `Width` (integer) - Width value +- `Height` (integer) - Height value +- `Unit` (string) - Unit of measurement: `"Pixel"`, `"Percent"`, `"Centimeter"`, `"Inch"` +- `Fit` (string) - Resize mode: `"Fit"`, `"Fill"`, `"Stretch"` + +### ImageresizerSelectedSizeIndex + +Sets the default selected size preset (0-based index). + +**Type:** integer +**Default:** `0` + +### ImageresizerShrinkOnly + +Controls whether images are only resized if they're larger than the target size. + +**Type:** boolean +**Default:** `false` + +### ImageresizerReplace + +Controls whether resized images replace the original files. + +**Type:** boolean +**Default:** `false` + +### ImageresizerIgnoreOrientation + +Controls whether EXIF orientation data is ignored. + +**Type:** boolean +**Default:** `true` + +### ImageresizerJpegQualityLevel + +Sets the JPEG quality level for resized images (1-100). + +**Type:** integer +**Range:** `1` to `100` +**Default:** `90` + +### ImageresizerPngInterlaceOption + +Sets the PNG interlace option. + +**Type:** integer +**Allowed values:** + +- `0` - No interlacing +- `1` - Interlaced + +**Default:** `0` + +### ImageresizerTiffCompressOption + +Sets the TIFF compression option. + +**Type:** integer +**Allowed values:** + +- `0` - No compression +- `1` - LZW compression +- `2` - ZIP compression + +**Default:** `0` + +### ImageresizerFileName + +Sets the naming pattern for resized images. + +**Type:** string +**Default:** `"%1 (%2)"` +**Placeholders:** + +- `%1` - Original filename +- `%2` - Size name +- `%3` - Selected width +- `%4` - Selected height +- `%5` - Actual width +- `%6` - Actual height + +### ImageresizerKeepDateModified + +Controls whether the original file's modified date is preserved. + +**Type:** boolean +**Default:** `false` + +### ImageresizerFallbackEncoder + +Sets the fallback encoder for unsupported formats. + +**Type:** string +**Allowed values:** `"png"`, `"jpg"`, `"bmp"`, `"tiff"`, `"gif"` +**Default:** `"png"` + +## Examples + +### Example 1 - Configure custom size presets with direct execution + +This example defines custom image resize presets. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ImageResizerSizes = @( + @{ + Name = "Small" + Width = 640 + Height = 480 + Unit = "Pixel" + Fit = "Fit" + }, + @{ + Name = "Medium" + Width = 1280 + Height = 720 + Unit = "Pixel" + Fit = "Fit" + }, + @{ + Name = "Large" + Width = 1920 + Height = 1080 + Unit = "Pixel" + Fit = "Fit" + } + ) + } + name = "ImageResizer" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module ImageResizer ` + --input $config +``` + +### Example 2 - Configure quality settings with DSC + +This example configures image quality and format options. + +```bash +dsc config set --file imageresizer-quality.dsc.yaml +``` + +```yaml +# imageresizer-quality.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Image Resizer quality + type: Microsoft.PowerToys/ImageResizerSettings + properties: + settings: + properties: + ImageresizerJpegQualityLevel: 95 + ImageresizerShrinkOnly: true + ImageresizerKeepDateModified: true + name: ImageResizer + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Image Resizer with +web-optimized presets. + +```bash +winget configure winget-imageresizer.yaml +``` + +```yaml +# winget-imageresizer.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Image Resizer + type: Microsoft.PowerToys/ImageResizerSettings + properties: + settings: + properties: + ImageResizerSizes: + - Name: Thumbnail + Width: 320 + Height: 240 + Unit: Pixel + Fit: Fit + - Name: Web Small + Width: 800 + Height: 600 + Unit: Pixel + Fit: Fit + - Name: Web Large + Width: 1920 + Height: 1080 + Unit: Pixel + Fit: Fit + ImageresizerJpegQualityLevel: 85 + ImageresizerFileName: "%1_resized_%2" + name: ImageResizer + version: 1.0 +``` + +### Example 4 - Photography workflow + +This example configures for photography with high quality and metadata +preservation. + +```bash +dsc config set --file imageresizer-photo.dsc.yaml +``` + +```yaml +# imageresizer-photography.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Photography configuration + type: Microsoft.PowerToys/ImageResizerSettings + properties: + settings: + properties: + ImageresizerJpegQualityLevel: 100 + ImageresizerKeepDateModified: true + ImageresizerIgnoreOrientation: false + ImageresizerShrinkOnly: true + name: ImageResizer + version: 1.0 +``` + +### Example 5 - Social media presets + +This example defines presets for social media platforms. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ImageResizerSizes = @( + @{ Name = "Instagram Square"; Width = 1080; Height = 1080; Unit = "Pixel"; Fit = "Fill" }, + @{ Name = "Instagram Portrait"; Width = 1080; Height = 1350; Unit = "Pixel"; Fit = "Fill" }, + @{ Name = "Facebook Cover"; Width = 820; Height = 312; Unit = "Pixel"; Fit = "Fill" }, + @{ Name = "Twitter Header"; Width = 1500; Height = 500; Unit = "Pixel"; Fit = "Fill" } + ) + ImageresizerJpegQualityLevel = 90 + } + name = "ImageResizer" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module ImageResizer ` + --input $config +``` + +## Use cases + +### Web development + +Configure for web-optimized images: + +```yaml +resources: + - name: Web optimization + type: Microsoft.PowerToys/ImageResizerSettings + properties: + settings: + properties: + ImageresizerJpegQualityLevel: 85 + ImageresizerShrinkOnly: true + name: ImageResizer + version: 1.0 +``` + +### Content creation + +Configure for social media and content platforms: + +```yaml +resources: + - name: Content creation + type: Microsoft.PowerToys/ImageResizerSettings + properties: + settings: + properties: + ImageResizerSizes: + - Name: HD + Width: 1920 + Height: 1080 + Unit: Pixel + Fit: Fit + ImageresizerJpegQualityLevel: 90 + name: ImageResizer + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [MeasureTool][03] +- [PowerToys Image Resizer Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./MeasureTool.md +[04]: https://learn.microsoft.com/windows/powertoys/image-resizer diff --git a/doc/dsc/modules/KeyboardManager.md b/doc/dsc/modules/KeyboardManager.md new file mode 100644 index 0000000000..cf79c44dd5 --- /dev/null +++ b/doc/dsc/modules/KeyboardManager.md @@ -0,0 +1,145 @@ +--- +description: DSC configuration reference for PowerToys KeyboardManager module +ms.date: 10/18/2025 +ms.topic: reference +title: KeyboardManager Module +--- + +# KeyboardManager Module + +## Synopsis + +Manages configuration for the Keyboard Manager utility, which allows key +remapping and custom keyboard shortcuts. + +## Description + +The `KeyboardManager` module configures PowerToys Keyboard Manager, a utility +that enables you to remap keys and create custom keyboard shortcuts. It +allows reassigning keys, creating application-specific remappings, and +defining shortcuts that run programs or commands. + +## Properties + +The KeyboardManager module supports the following configurable properties: + +### Enabled + +Controls whether Keyboard Manager is enabled. + +**Type:** boolean +**Default:** `true` + +## Examples + +### Example 1 - Enable Keyboard Manager with direct execution + +This example enables the Keyboard Manager utility. + +```powershell +$config = @{ + settings = @{ + properties = @{ + Enabled = $true + } + name = "KeyboardManager" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module KeyboardManager --input $config +``` + +### Example 2 - Configure with DSC + +This example enables Keyboard Manager through DSC configuration. + +```bash +dsc config set --file keyboardmanager-config.dsc.yaml +``` + +```yaml +# keyboardmanager-config.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Enable Keyboard Manager + type: Microsoft.PowerToys/KeyboardManagerSettings + properties: + settings: + properties: + Enabled: true + name: KeyboardManager + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and enables Keyboard Manager. + +```bash +winget configure winget-keyboardmanager.yaml +``` + +```yaml +# winget-keyboardmanager.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Enable Keyboard Manager + type: Microsoft.PowerToys/KeyboardManagerSettings + properties: + settings: + properties: + Enabled: true + name: KeyboardManager + version: 1.0 +``` + +## Important notes + +> **Note:** The Keyboard Manager module DSC configuration controls the enabled state only. Key remappings and shortcut definitions are managed through the Keyboard Manager UI and stored separately. This design ensures that complex remapping configurations are not accidentally overwritten by DSC operations. + +To configure key remappings: +1. Enable Keyboard Manager using DSC +2. Open PowerToys Settings +3. Navigate to Keyboard Manager +4. Use "Remap a key" or "Remap a shortcut" to configure specific mappings + +## Use cases + +### Enable for deployment + +Enable Keyboard Manager on new workstations: + +```yaml +resources: + - name: Enable Keyboard Manager + type: Microsoft.PowerToys/KeyboardManagerSettings + properties: + settings: + properties: + Enabled: true + name: KeyboardManager + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [PowerOCR][03] +- [PowerToys Keyboard Manager Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./PowerOCR.md +[04]: https://learn.microsoft.com/windows/powertoys/keyboard-manager diff --git a/doc/dsc/modules/MeasureTool.md b/doc/dsc/modules/MeasureTool.md new file mode 100644 index 0000000000..10566e17bc --- /dev/null +++ b/doc/dsc/modules/MeasureTool.md @@ -0,0 +1,254 @@ +--- +description: DSC configuration reference for PowerToys MeasureTool module +ms.date: 10/18/2025 +ms.topic: reference +title: MeasureTool Module +--- + +# MeasureTool Module + +## Synopsis + +Manages configuration for the Measure Tool (Screen Ruler) utility, which +measures pixels on your screen. + +## Description + +The `MeasureTool` module configures PowerToys Measure Tool (also known as +Screen Ruler), a utility that allows you to measure the distance between two +points on your screen in pixels. It's useful for designers, developers, and +anyone who needs to measure UI elements or screen distances. + +## Properties + +The MeasureTool module supports the following configurable properties: + +### ActivationShortcut + +Sets the keyboard shortcut to activate the measure tool. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier +- `ctrl` (boolean) - Ctrl key modifier +- `alt` (boolean) - Alt key modifier +- `shift` (boolean) - Shift key modifier +- `code` (integer) - Virtual key code +- `key` (string) - Key name + +**Default:** `Win+Shift+M` + +### ContinuousCapture + +Controls whether continuous capture mode is enabled. + +**Type:** boolean +**Default:** `false` + +### DrawFeetOnCross + +Controls whether measurement lines extend to screen edges. + +**Type:** boolean +**Default:** `true` + +### PerColorChannelEdgeDetection + +Controls whether edge detection is per-color-channel or luminosity-based. + +**Type:** boolean +**Default:** `false` + +### PixelTolerance + +Sets the pixel tolerance for edge detection (0-255). + +**Type:** integer +**Range:** `0` to `255` +**Default:** `30` + +### MeasureCrossColor + +Sets the color of the measurement crosshair. + +**Type:** string (hex color) +**Format:** `"#RRGGBBAA"` (with alpha) +**Default:** `"#FF4500FF"` + +## Examples + +### Example 1 - Configure activation shortcut with direct execution + +This example customizes the measure tool activation shortcut. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ActivationShortcut = @{ + win = $true + ctrl = $false + alt = $false + shift = $true + code = 77 + key = "M" + } + } + name = "MeasureTool" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module MeasureTool ` + --input $config +``` + +### Example 2 - Configure measurement appearance with DSC + +This example customizes the crosshair color and measurement behavior. + +```bash +dsc config set --file measuretool-appearance.dsc.yaml +``` + +```yaml +# measuretool-appearance.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Measure Tool appearance + type: Microsoft.PowerToys/MeasureToolSettings + properties: + settings: + properties: + MeasureCrossColor: "#00FF00FF" + DrawFeetOnCross: true + ContinuousCapture: false + name: MeasureTool + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Measure Tool with edge +detection. + +```bash +winget configure winget-measuretool.yaml +``` + +```yaml +# winget-measuretool.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Measure Tool + type: Microsoft.PowerToys/MeasureToolSettings + properties: + settings: + properties: + PixelTolerance: 20 + PerColorChannelEdgeDetection: true + DrawFeetOnCross: true + name: MeasureTool + version: 1.0 +``` + +### Example 4 - High contrast configuration + +This example configures for high visibility measurements. + +```bash +dsc config set --file measuretool-highcontrast.dsc.yaml +``` + +```yaml +# measuretool-highcontrast.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: High contrast Measure Tool + type: Microsoft.PowerToys/MeasureToolSettings + properties: + settings: + properties: + MeasureCrossColor: "#FFFF00FF" + DrawFeetOnCross: true + name: MeasureTool + version: 1.0 +``` + +### Example 5 - Continuous capture mode + +This example enables continuous capture for repeated measurements. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ContinuousCapture = $true + PixelTolerance = 25 + } + name = "MeasureTool" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module MeasureTool --input $config +``` + +## Use cases + +### UI/UX design + +Configure for design work with precise measurements: + +```yaml +resources: + - name: Design configuration + type: Microsoft.PowerToys/MeasureToolSettings + properties: + settings: + properties: + PixelTolerance: 15 + DrawFeetOnCross: true + name: MeasureTool + version: 1.0 +``` + +### Web development + +Configure for layout debugging: + +```yaml +resources: + - name: Developer configuration + type: Microsoft.PowerToys/MeasureToolSettings + properties: + settings: + properties: + ContinuousCapture: true + MeasureCrossColor: "#0078D7FF" + name: MeasureTool + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [PowerAccent][03] +- [PowerToys Screen Ruler Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./PowerAccent.md +[04]: https://learn.microsoft.com/windows/powertoys/screen-ruler diff --git a/doc/dsc/modules/MouseHighlighter.md b/doc/dsc/modules/MouseHighlighter.md new file mode 100644 index 0000000000..586f9354cb --- /dev/null +++ b/doc/dsc/modules/MouseHighlighter.md @@ -0,0 +1,276 @@ +--- +description: DSC configuration reference for PowerToys MouseHighlighter module +ms.date: 10/18/2025 +ms.topic: reference +title: MouseHighlighter Module +--- + +# MouseHighlighter Module + +## Synopsis + +Manages configuration for the Mouse Highlighter utility, which highlights +your mouse cursor and clicks. + +## Description + +The `MouseHighlighter` module configures PowerToys Mouse Highlighter, a +utility that adds visual highlights to your mouse cursor and click locations. +This is useful for presentations, tutorials, screen recordings, or +accessibility purposes. + +## Properties + +The MouseHighlighter module supports the following configurable properties: + +### ActivationShortcut + +Sets the keyboard shortcut to toggle mouse highlighting. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier +- `ctrl` (boolean) - Ctrl key modifier +- `alt` (boolean) - Alt key modifier +- `shift` (boolean) - Shift key modifier +- `code` (integer) - Virtual key code +- `key` (string) - Key name + +**Default:** `Win+Shift+H` + +### LeftButtonClickColor + +Sets the color for left mouse button clicks. + +**Type:** string (hex color) +**Format:** `"#RRGGBB"` +**Default:** `"#FFFF00"` (yellow) + +### RightButtonClickColor + +Sets the color for right mouse button clicks. + +**Type:** string (hex color) +**Format:** `"#RRGGBB"` +**Default:** `"#0000FF"` (blue) + +### HighlightOpacity + +Sets the opacity of click highlights (0-100). + +**Type:** integer +**Range:** `0` to `100` +**Default:** `160` + +### HighlightRadius + +Sets the radius of click highlights in pixels. + +**Type:** integer +**Range:** `1` to `500` +**Default:** `20` + +### HighlightFadeDelayMs + +Sets how long highlights remain visible in milliseconds. + +**Type:** integer +**Range:** `0` to `10000` +**Default:** `500` + +### HighlightFadeDurationMs + +Sets the duration of the highlight fade animation in milliseconds. + +**Type:** integer +**Range:** `0` to `10000` +**Default:** `250` + +### AutoActivate + +Controls whether Mouse Highlighter activates automatically during presentations. + +**Type:** boolean +**Default:** `false` + +## Examples + +### Example 1 - Configure highlight colors with direct execution + +This example customizes the click highlight colors. + +```powershell +$config = @{ + settings = @{ + properties = @{ + LeftButtonClickColor = "#00FF00" + RightButtonClickColor = "#FF0000" + HighlightOpacity = 200 + } + name = "MouseHighlighter" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module MouseHighlighter ` + --input $config +``` + +### Example 2 - Configure highlight animation with DSC + +This example customizes the animation timing and appearance. + +```bash +dsc config set --file mousehighlighter-animation.dsc.yaml +``` + +```yaml +# mousehighlighter-animation.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Mouse Highlighter animation + type: Microsoft.PowerToys/MouseHighlighterSettings + properties: + settings: + properties: + HighlightRadius: 30 + HighlightFadeDelayMs: 750 + HighlightFadeDurationMs: 400 + name: MouseHighlighter + version: 1.0 +``` + +### Example 3 - Install and configure for presentations with WinGet + +This example installs PowerToys and configures Mouse Highlighter for +presentations. + +```bash +winget configure winget-mousehighlighter.yaml +``` + +```yaml +# winget-mousehighlighter.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Mouse Highlighter for presentations + type: Microsoft.PowerToys/MouseHighlighterSettings + properties: + settings: + properties: + LeftButtonClickColor: "#FFD700" + RightButtonClickColor: "#FF4500" + HighlightOpacity: 220 + HighlightRadius: 25 + AutoActivate: true + name: MouseHighlighter + version: 1.0 +``` + +### Example 4 - Subtle highlighting + +This example configures subtle, less distracting highlights. + +```bash +dsc config set --file mousehighlighter-subtle.dsc.yaml +``` + +```yaml +# mousehighlighter-subtle.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Subtle mouse highlighting + type: Microsoft.PowerToys/MouseHighlighterSettings + properties: + settings: + properties: + HighlightOpacity: 100 + HighlightRadius: 15 + HighlightFadeDelayMs: 300 + name: MouseHighlighter + version: 1.0 +``` + +### Example 5 - High visibility for accessibility + +This example configures high-contrast, long-lasting highlights. + +```powershell +$config = @{ + settings = @{ + properties = @{ + LeftButtonClickColor = "#FFFFFF" + RightButtonClickColor = "#FF0000" + HighlightOpacity = 255 + HighlightRadius = 40 + HighlightFadeDelayMs = 1500 + HighlightFadeDurationMs = 500 + } + name = "MouseHighlighter" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module MouseHighlighter --input $config +``` + +## Use cases + +### Presentations and demos + +Configure for clear visibility during presentations: + +```yaml +resources: + - name: Presentation highlighting + type: Microsoft.PowerToys/MouseHighlighterSettings + properties: + settings: + properties: + LeftButtonClickColor: "#FFD700" + HighlightOpacity: 200 + HighlightRadius: 25 + AutoActivate: true + name: MouseHighlighter + version: 1.0 +``` + +### Screen recording + +Configure for video tutorials and recordings: + +```yaml +resources: + - name: Recording configuration + type: Microsoft.PowerToys/MouseHighlighterSettings + properties: + settings: + properties: + HighlightOpacity: 180 + HighlightFadeDelayMs: 600 + name: MouseHighlighter + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [MousePointerCrosshairs][03] +- [PowerToys Mouse Utilities Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./MousePointerCrosshairs.md +[04]: https://learn.microsoft.com/windows/powertoys/mouse-utilities diff --git a/doc/dsc/modules/MouseJump.md b/doc/dsc/modules/MouseJump.md new file mode 100644 index 0000000000..b82fdc7a64 --- /dev/null +++ b/doc/dsc/modules/MouseJump.md @@ -0,0 +1,220 @@ +--- +description: DSC configuration reference for PowerToys MouseJump module +ms.date: 10/18/2025 +ms.topic: reference +title: MouseJump Module +--- + +# MouseJump Module + +## Synopsis + +Manages configuration for the Mouse Jump utility, which enables quick +navigation across large or multiple displays. + +## Description + +The `MouseJump` module configures PowerToys Mouse Jump, a utility that +provides a miniature preview of all your displays, allowing you to quickly +jump your mouse cursor to any location. This is particularly useful with +large monitors or multi-monitor setups. + +## Properties + +The MouseJump module supports the following configurable properties: + +### ActivationShortcut + +Sets the keyboard shortcut to activate Mouse Jump. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier +- `ctrl` (boolean) - Ctrl key modifier +- `alt` (boolean) - Alt key modifier +- `shift` (boolean) - Shift key modifier +- `code` (integer) - Virtual key code +- `key` (string) - Key name + +**Default:** `Win+Shift+D` + +### ThumbnailSize + +Sets the size of the screen thumbnail preview. + +**Type:** string +**Allowed values:** + +- `"small"` - Smaller thumbnail for faster performance +- `"medium"` - Balanced size and performance +- `"large"` - Larger thumbnail for better visibility + +**Default:** `"medium"` + +## Examples + +### Example 1 - Configure activation shortcut with direct execution + +This example customizes the Mouse Jump activation shortcut. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ActivationShortcut = @{ + win = $true + ctrl = $false + alt = $false + shift = $true + code = 68 + key = "D" + } + } + name = "MouseJump" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module MouseJump ` + --input $config +``` + +### Example 2 - Configure thumbnail size with DSC + +This example sets a larger thumbnail for better visibility. + +```bash +dsc config set --file mousejump-size.dsc.yaml +``` + +```yaml +# mousejump-size.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Mouse Jump thumbnail + type: Microsoft.PowerToys/MouseJumpSettings + properties: + settings: + properties: + ThumbnailSize: large + name: MouseJump + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Mouse Jump for multi-monitor +setups. + +```bash +winget configure winget-mousejump.yaml +``` + +```yaml +# winget-mousejump.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Mouse Jump + type: Microsoft.PowerToys/MouseJumpSettings + properties: + settings: + properties: + ThumbnailSize: medium + name: MouseJump + version: 1.0 +``` + +### Example 4 - Performance-optimized configuration + +This example uses a smaller thumbnail for better performance. + +```bash +dsc config set --file mousejump-performance.dsc.yaml +``` + +```yaml +# mousejump-performance.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Performance-optimized Mouse Jump + type: Microsoft.PowerToys/MouseJumpSettings + properties: + settings: + properties: + ThumbnailSize: small + name: MouseJump + version: 1.0 +``` + +### Example 5 - Large display configuration + +This example configures for large or high-DPI displays. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ThumbnailSize = "large" + } + name = "MouseJump" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module MouseJump --input $config +``` + +## Use cases + +### Multi-monitor workstations + +Configure for efficient navigation across multiple displays: + +```yaml +resources: + - name: Multi-monitor configuration + type: Microsoft.PowerToys/MouseJumpSettings + properties: + settings: + properties: + ThumbnailSize: medium + name: MouseJump + version: 1.0 +``` + +### Large displays + +Configure for ultra-wide or 4K+ displays: + +```yaml +resources: + - name: Large display configuration + type: Microsoft.PowerToys/MouseJumpSettings + properties: + settings: + properties: + ThumbnailSize: large + name: MouseJump + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [FindMyMouse][03] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./FindMyMouse.md diff --git a/doc/dsc/modules/MousePointerCrosshairs.md b/doc/dsc/modules/MousePointerCrosshairs.md new file mode 100644 index 0000000000..2f49d5732c --- /dev/null +++ b/doc/dsc/modules/MousePointerCrosshairs.md @@ -0,0 +1,290 @@ +--- +description: DSC configuration reference for PowerToys MousePointerCrosshairs module +ms.date: 10/18/2025 +ms.topic: reference +title: MousePointerCrosshairs Module +--- + +# MousePointerCrosshairs Module + +## Synopsis + +Manages configuration for the Mouse Pointer Crosshairs utility, which +displays crosshairs centered on your mouse pointer. + +## Description + +The `MousePointerCrosshairs` module configures PowerToys Mouse Pointer +Crosshairs, a utility that displays customizable crosshairs overlaid on your +screen, centered on the mouse cursor. This is useful for presentations, +design work, or improving cursor visibility. + +## Properties + +The MousePointerCrosshairs module supports the following configurable properties: + +### ActivationShortcut + +Sets the keyboard shortcut to toggle crosshairs display. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier +- `ctrl` (boolean) - Ctrl key modifier +- `alt` (boolean) - Alt key modifier +- `shift` (boolean) - Shift key modifier +- `code` (integer) - Virtual key code +- `key` (string) - Key name + +**Default:** `Win+Alt+P` + +### CrosshairsColor + +Sets the color of the crosshairs. + +**Type:** string (hex color) +**Format:** `"#RRGGBB"` +**Default:** `"#FF0000"` (red) + +### CrosshairsOpacity + +Sets the opacity of the crosshairs (0-100). + +**Type:** integer +**Range:** `0` to `100` +**Default:** `75` + +### CrosshairsRadius + +Sets the length of the crosshair lines in pixels. + +**Type:** integer +**Range:** `0` to `9999` +**Default:** `100` + +### CrosshairsThickness + +Sets the thickness of the crosshair lines in pixels. + +**Type:** integer +**Range:** `1` to `50` +**Default:** `5` + +### CrosshairsBorderColor + +Sets the border color of the crosshairs. + +**Type:** string (hex color) +**Format:** `"#RRGGBB"` +**Default:** `"#FFFFFF"` (white) + +### CrosshairsBorderSize + +Sets the width of the crosshair border in pixels. + +**Type:** integer +**Range:** `0` to `50` +**Default:** `1` + +### CrosshairsAutoHide + +Controls whether crosshairs automatically hide when the mouse is not moving. + +**Type:** boolean +**Default:** `false` + +### CrosshairsIsFixedLengthEnabled + +Controls whether crosshairs have a fixed length or extend to screen edges. + +**Type:** boolean +**Default:** `true` + +### CrosshairsFixedLength + +Sets the fixed length of crosshairs when fixed length mode is enabled. + +**Type:** integer +**Range:** `0` to `9999` +**Default:** `100` + +## Examples + +### Example 1 - Configure crosshair appearance with direct execution + +This example customizes the crosshair color and size. + +```powershell +$config = @{ + settings = @{ + properties = @{ + CrosshairsColor = "#00FF00" + CrosshairsOpacity = 85 + CrosshairsThickness = 3 + CrosshairsRadius = 150 + } + name = "MousePointerCrosshairs" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module MousePointerCrosshairs ` + --input $config +``` + +### Example 2 - Configure with border with DSC + +This example adds a border to the crosshairs for better visibility. + +```bash +dsc config set --file mousecrosshairs-border.dsc.yaml +``` + +```yaml +# mousecrosshairs-border.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure crosshairs with border + type: Microsoft.PowerToys/MousePointerCrosshairsSettings + properties: + settings: + properties: + CrosshairsColor: "#FF0000" + CrosshairsBorderColor: "#FFFFFF" + CrosshairsBorderSize: 2 + CrosshairsThickness: 4 + name: MousePointerCrosshairs + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures crosshairs for presentations. + +```bash +winget configure winget-mousecrosshairs.yaml +``` + +```yaml +# winget-mousecrosshairs.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Mouse Crosshairs + type: Microsoft.PowerToys/MousePointerCrosshairsSettings + properties: + settings: + properties: + CrosshairsColor: "#FFFF00" + CrosshairsOpacity: 90 + CrosshairsRadius: 120 + CrosshairsThickness: 5 + CrosshairsBorderSize: 2 + name: MousePointerCrosshairs + version: 1.0 +``` + +### Example 4 - Full-screen crosshairs + +This example configures crosshairs that extend to screen edges. + +```bash +dsc config set --file mousecrosshairs-fullscreen.dsc.yaml +``` + +```yaml +# mousecrosshairs-fullscreen.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Full-screen crosshairs + type: Microsoft.PowerToys/MousePointerCrosshairsSettings + properties: + settings: + properties: + CrosshairsIsFixedLengthEnabled: false + CrosshairsOpacity: 60 + name: MousePointerCrosshairs + version: 1.0 +``` + +### Example 5 - Subtle crosshairs with auto-hide + +This example creates subtle crosshairs that hide when idle. + +```powershell +$config = @{ + settings = @{ + properties = @{ + CrosshairsColor = "#FFFFFF" + CrosshairsOpacity = 50 + CrosshairsThickness = 2 + CrosshairsRadius = 80 + CrosshairsAutoHide = $true + } + name = "MousePointerCrosshairs" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module MousePointerCrosshairs --input $config +``` + +## Use cases + +### Presentations and demos + +Configure for clear cursor tracking during presentations: + +```yaml +resources: + - name: Presentation crosshairs + type: Microsoft.PowerToys/MousePointerCrosshairsSettings + properties: + settings: + properties: + CrosshairsColor: "#FFFF00" + CrosshairsOpacity: 85 + CrosshairsRadius: 150 + name: MousePointerCrosshairs + version: 1.0 +``` + +### Design and alignment + +Configure for precise alignment work: + +```yaml +resources: + - name: Design crosshairs + type: Microsoft.PowerToys/MousePointerCrosshairsSettings + properties: + settings: + properties: + CrosshairsIsFixedLengthEnabled: false + CrosshairsThickness: 1 + CrosshairsOpacity: 70 + name: MousePointerCrosshairs + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [MouseHighlighter][03] +- [PowerToys Mouse Utilities Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./MouseHighlighter.md +[04]: https://learn.microsoft.com/windows/powertoys/mouse-utilities diff --git a/doc/dsc/modules/Peek.md b/doc/dsc/modules/Peek.md new file mode 100644 index 0000000000..c4e2e01381 --- /dev/null +++ b/doc/dsc/modules/Peek.md @@ -0,0 +1,200 @@ +--- +description: DSC configuration reference for PowerToys Peek module +ms.date: 10/18/2025 +ms.topic: reference +title: Peek Module +--- + +# Peek Module + +## Synopsis + +Manages configuration for the Peek utility, a quick file preview tool. + +## Description + +The `Peek` module configures PowerToys Peek, a utility that provides quick +file previews without opening files. Activate it with a keyboard shortcut to +preview documents, images, videos, and more in a popup window. + +## Properties + +The Peek module supports the following configurable properties: + +### ActivationShortcut + +Sets the keyboard shortcut to activate Peek for the selected file. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier +- `ctrl` (boolean) - Ctrl key modifier +- `alt` (boolean) - Alt key modifier +- `shift` (boolean) - Shift key modifier +- `code` (integer) - Virtual key code +- `key` (string) - Key name + +**Default:** `Ctrl+Space` + +### CloseAfterLosingFocus + +Controls whether Peek window closes when it loses focus. + +**Type:** boolean +**Default:** `true` + +## Examples + +### Example 1 - Configure activation shortcut with direct execution + +This example customizes the Peek activation shortcut. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ActivationShortcut = @{ + win = $false + ctrl = $true + alt = $false + shift = $false + code = 32 + key = "Space" + } + } + name = "Peek" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module Peek --input $config +``` + +### Example 2 - Configure focus behavior with DSC + +This example configures Peek to remain open after losing focus. + +```bash +dsc config set --file peek-focus.dsc.yaml +``` + +```yaml +# peek-focus.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Peek focus behavior + type: Microsoft.PowerToys/PeekSettings + properties: + settings: + properties: + CloseAfterLosingFocus: false + name: Peek + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Peek. + +```bash +winget configure winget-peek.yaml +``` + +```yaml +# winget-peek.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Peek + type: Microsoft.PowerToys/PeekSettings + properties: + settings: + properties: + CloseAfterLosingFocus: true + name: Peek + version: 1.0 +``` + +### Example 4 - Alternative activation shortcut + +This example uses Ctrl+Shift+Space as the activation shortcut. + +```bash +dsc config set --file peek-altkey.dsc.yaml +``` + +```yaml +# peek-altkey.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Alternative Peek shortcut + type: Microsoft.PowerToys/PeekSettings + properties: + settings: + properties: + ActivationShortcut: + win: false + ctrl: true + alt: false + shift: true + code: 32 + key: Space + name: Peek + version: 1.0 +``` + +## Use cases + +### File browsing + +Configure for quick file preview during browsing: + +```yaml +resources: + - name: File browsing configuration + type: Microsoft.PowerToys/PeekSettings + properties: + settings: + properties: + CloseAfterLosingFocus: true + name: Peek + version: 1.0 +``` + +### Content review + +Configure for extended content review: + +```yaml +resources: + - name: Review configuration + type: Microsoft.PowerToys/PeekSettings + properties: + settings: + properties: + CloseAfterLosingFocus: false + name: Peek + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [ShortcutGuide][03] +- [PowerToys Peek Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./ShortcutGuide.md +[04]: https://learn.microsoft.com/windows/powertoys/peek diff --git a/doc/dsc/modules/PowerAccent.md b/doc/dsc/modules/PowerAccent.md new file mode 100644 index 0000000000..1259701634 --- /dev/null +++ b/doc/dsc/modules/PowerAccent.md @@ -0,0 +1,257 @@ +--- +description: DSC configuration reference for PowerToys PowerAccent module +ms.date: 10/18/2025 +ms.topic: reference +title: PowerAccent Module +--- + +# PowerAccent Module + +## Synopsis + +Manages configuration for the Power Accent utility, a quick accent character selector. + +## Description + +The `PowerAccent` module configures PowerToys Power Accent (Quick Accent), a +utility that provides quick access to accented characters. Hold down a key +and use arrow keys or numbers to select from available accent variations. + +## Properties + +The PowerAccent module supports the following configurable properties: + +### ActivationKey + +Sets which key triggers the accent selection. + +**Type:** string +**Allowed values:** + +- `"LeftRightArrow"` - Hold left or right arrow keys +- `"Space"` - Hold spacebar +- `"Both"` - Hold either left/right arrows or spacebar + +**Default:** `"Both"` + +### InputTime + +Sets how long the activation key must be held (in milliseconds) before showing accents. + +**Type:** integer +**Range:** `100` to `1000` +**Default:** `300` + +### ExcludedApps + +List of applications where Power Accent is disabled. + +**Type:** string (newline-separated list of executable names) + +### ToolbarPosition + +Sets the position of the accent selection toolbar. + +**Type:** string +**Allowed values:** + +- `"Top"` - Above the cursor +- `"Bottom"` - Below the cursor +- `"Left"` - To the left of cursor +- `"Right"` - To the right of cursor +- `"Center"` - Centered on screen + +**Default:** `"Top"` + +### ShowUnicodeDescription + +Controls whether Unicode descriptions are shown for each accent character. + +**Type:** boolean +**Default:** `false` + +### SortByUsageFrequency + +Controls whether accent characters are sorted by usage frequency. + +**Type:** boolean +**Default:** `false` + +### StartSelectionFromTheLeft + +Controls whether selection starts from the left side. + +**Type:** boolean +**Default:** `false` + +## Examples + +### Example 1 - Configure activation method with direct execution + +This example sets spacebar as the activation key. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ActivationKey = "Space" + InputTime = 250 + } + name = "PowerAccent" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module PowerAccent ` + --input $config +``` + +### Example 2 - Configure toolbar appearance with DSC + +This example customizes the toolbar position and display options. + +```bash +dsc config set --file poweraccent-toolbar.dsc.yaml +``` + +```yaml +# poweraccent-toolbar.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Power Accent toolbar + type: Microsoft.PowerToys/PowerAccentSettings + properties: + settings: + properties: + ToolbarPosition: Bottom + ShowUnicodeDescription: true + SortByUsageFrequency: true + name: PowerAccent + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Power Accent for multilingual +typing. + +```bash +winget configure winget-poweraccent.yaml +``` + +```yaml +# winget-poweraccent.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Power Accent + type: Microsoft.PowerToys/PowerAccentSettings + properties: + settings: + properties: + ActivationKey: Space + InputTime: 300 + ToolbarPosition: Top + SortByUsageFrequency: true + name: PowerAccent + version: 1.0 +``` + +### Example 4 - Fast activation configuration + +This example configures for quick accent selection. + +```bash +dsc config set --file poweraccent-fast.dsc.yaml +``` + +```yaml +# poweraccent-fast.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Fast accent activation + type: Microsoft.PowerToys/PowerAccentSettings + properties: + settings: + properties: + InputTime: 150 + SortByUsageFrequency: true + name: PowerAccent + version: 1.0 +``` + +### Example 5 - Exclude applications + +This example excludes specific applications from Power Accent. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ExcludedApps = "notepad.exe`nWordPad.exe" + } + name = "PowerAccent" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module PowerAccent --input $config +``` + +## Use cases + +### Multilingual content creation + +Configure for efficient multilingual typing: + +```yaml +resources: + - name: Multilingual configuration + type: Microsoft.PowerToys/PowerAccentSettings + properties: + settings: + properties: + ActivationKey: Space + SortByUsageFrequency: true + ShowUnicodeDescription: false + name: PowerAccent + version: 1.0 +``` + +### Language learning + +Configure for language learning with Unicode descriptions: + +```yaml +resources: + - name: Learning configuration + type: Microsoft.PowerToys/PowerAccentSettings + properties: + settings: + properties: + ShowUnicodeDescription: true + InputTime: 400 + name: PowerAccent + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [Workspaces][03] +- [PowerToys Quick Accent Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./Workspaces.md +[04]: https://learn.microsoft.com/windows/powertoys/quick-accent diff --git a/doc/dsc/modules/PowerOCR.md b/doc/dsc/modules/PowerOCR.md new file mode 100644 index 0000000000..c9212044ce --- /dev/null +++ b/doc/dsc/modules/PowerOCR.md @@ -0,0 +1,197 @@ +--- +description: DSC configuration reference for PowerToys PowerOCR module +ms.date: 10/18/2025 +ms.topic: reference +title: PowerOCR Module +--- + +# PowerOCR Module + +## Synopsis + +Manages configuration for the Power OCR (Text Extractor) utility, which +extracts text from images and screen regions. + +## Description + +The `PowerOCR` module configures PowerToys Power OCR (Text Extractor), a +utility that uses optical character recognition (OCR) to extract text from +any screen region and copy it to the clipboard. It's useful for capturing +text from images, videos, PDFs, or any on-screen content. + +## Properties + +The PowerOCR module supports the following configurable properties: + +### ActivationShortcut + +Sets the keyboard shortcut to activate text extraction. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier +- `ctrl` (boolean) - Ctrl key modifier +- `alt` (boolean) - Alt key modifier +- `shift` (boolean) - Shift key modifier +- `code` (integer) - Virtual key code +- `key` (string) - Key name + +**Default:** `Win+Shift+T` + +### PreferredLanguage + +Sets the preferred language for OCR recognition. + +**Type:** string +**Default:** System language + +## Examples + +### Example 1 - Configure activation shortcut with direct execution + +This example customizes the OCR activation shortcut. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ActivationShortcut = @{ + win = $true + ctrl = $false + alt = $false + shift = $true + code = 84 + key = "T" + } + } + name = "PowerOCR" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module PowerOCR ` + --input $config +``` + +### Example 2 - Configure language with DSC + +This example sets the preferred OCR language. + +```bash +dsc config set --file powerocr-language.dsc.yaml +``` + +```yaml +# powerocr-language.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Power OCR language + type: Microsoft.PowerToys/PowerOCRSettings + properties: + settings: + properties: + PreferredLanguage: en-US + name: PowerOCR + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Power OCR. + +```bash +winget configure winget-powerocr.yaml +``` + +```yaml +# winget-powerocr.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Power OCR + type: Microsoft.PowerToys/PowerOCRSettings + properties: + settings: + properties: + PreferredLanguage: en-US + name: PowerOCR + version: 1.0 +``` + +### Example 4 - Multilingual configuration + +This example configures for multilingual text extraction. + +```bash +dsc config set --file powerocr-multilingual.dsc.yaml +``` + +```yaml +# powerocr-multilingual.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Multilingual OCR + type: Microsoft.PowerToys/PowerOCRSettings + properties: + settings: + properties: + PreferredLanguage: fr-FR + name: PowerOCR + version: 1.0 +``` + +## Use cases + +### Document digitization + +Configure for extracting text from documents: + +```yaml +resources: + - name: Document OCR + type: Microsoft.PowerToys/PowerOCRSettings + properties: + settings: + properties: + PreferredLanguage: en-US + name: PowerOCR + version: 1.0 +``` + +### International content + +Configure for multilingual content extraction: + +```yaml +resources: + - name: Multilingual OCR + type: Microsoft.PowerToys/PowerOCRSettings + properties: + settings: + properties: + PreferredLanguage: es-ES + name: PowerOCR + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [ZoomIt][03] +- [PowerToys Text Extractor Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./ZoomIt.md +[04]: https://learn.microsoft.com/windows/powertoys/text-extractor diff --git a/doc/dsc/modules/PowerRename.md b/doc/dsc/modules/PowerRename.md new file mode 100644 index 0000000000..73ec2aa87b --- /dev/null +++ b/doc/dsc/modules/PowerRename.md @@ -0,0 +1,230 @@ +--- +description: DSC configuration reference for PowerToys PowerRename module +ms.date: 10/18/2025 +ms.topic: reference +title: PowerRename Module +--- + +# PowerRename Module + +## Synopsis + +Manages configuration for the Power Rename utility, a bulk file and folder renaming tool. + +## Description + +The `PowerRename` module configures PowerToys Power Rename, a Windows shell +extension that enables bulk renaming of files and folders with advanced +features like regular expressions, preview, and undo functionality. It +integrates with the Windows Explorer context menu. + +## Properties + +The PowerRename module supports the following configurable properties: + +### MRUEnabled + +Controls whether the most recently used (MRU) search and replace terms are saved. + +**Type:** boolean +**Default:** `true` + +### MaxMRUSize + +Sets the maximum number of MRU entries to remember. + +**Type:** integer +**Range:** `0` to `20` +**Default:** `10` + +### ShowIcon + +Controls whether the Power Rename icon appears in the Explorer context menu. + +**Type:** boolean +**Default:** `true` + +### ExtendedContextMenuOnly + +Controls whether Power Rename appears only in the extended context menu (Shift+right-click). + +**Type:** boolean +**Default:** `false` + +### UseBoostLib + +Controls whether the Boost library is used for regular expression processing. + +**Type:** boolean +**Default:** `false` + +## Examples + +### Example 1 - Configure MRU settings with direct execution + +This example configures the most recently used list behavior. + +```powershell +$config = @{ + settings = @{ + properties = @{ + MRUEnabled = $true + MaxMRUSize = 15 + } + name = "PowerRename" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module PowerRename --input $config +``` + +### Example 2 - Configure context menu with DSC + +This example configures Power Rename to appear in the extended context menu +only. + +```bash +dsc config set --file powerrename-context.dsc.yaml +``` + +```yaml +# powerrename-context.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Power Rename context menu + type: Microsoft.PowerToys/PowerRenameSettings + properties: + settings: + properties: + ExtendedContextMenuOnly: true + ShowIcon: true + name: PowerRename + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Power Rename. + +```bash +winget configure winget-powerrename.yaml +``` + +```yaml +# winget-powerrename.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Power Rename + type: Microsoft.PowerToys/PowerRenameSettings + properties: + settings: + properties: + MRUEnabled: true + MaxMRUSize: 20 + ShowIcon: true + UseBoostLib: true + name: PowerRename + version: 1.0 +``` + +### Example 4 - Clean context menu configuration + +This example minimizes context menu clutter. + +```bash +dsc config set --file powerrename-minimal.dsc.yaml +``` + +```yaml +# powerrename-minimal.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Minimal context menu + type: Microsoft.PowerToys/PowerRenameSettings + properties: + settings: + properties: + ExtendedContextMenuOnly: true + ShowIcon: false + name: PowerRename + version: 1.0 +``` + +### Example 5 - Advanced regex configuration + +This example enables the Boost library for advanced regex features. + +```powershell +$config = @{ + settings = @{ + properties = @{ + UseBoostLib = $true + MRUEnabled = $true + MaxMRUSize = 15 + } + name = "PowerRename" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module PowerRename --input $config +``` + +## Use cases + +### Content management + +Configure for frequent file renaming tasks: + +```yaml +resources: + - name: Content management + type: Microsoft.PowerToys/PowerRenameSettings + properties: + settings: + properties: + MRUEnabled: true + MaxMRUSize: 20 + ShowIcon: true + name: PowerRename + version: 1.0 +``` + +### Clean interface + +Configure for minimal context menu presence: + +```yaml +resources: + - name: Clean interface + type: Microsoft.PowerToys/PowerRenameSettings + properties: + settings: + properties: + ExtendedContextMenuOnly: true + name: PowerRename + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [AdvancedPaste][03] +- [PowerToys PowerRename Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./AdvancedPaste.md +[04]: https://learn.microsoft.com/windows/powertoys/powerrename diff --git a/doc/dsc/modules/RegistryPreview.md b/doc/dsc/modules/RegistryPreview.md new file mode 100644 index 0000000000..98860e04f9 --- /dev/null +++ b/doc/dsc/modules/RegistryPreview.md @@ -0,0 +1,173 @@ +--- +description: DSC configuration reference for PowerToys RegistryPreview module +ms.date: 10/18/2025 +ms.topic: reference +title: RegistryPreview Module +--- + +# RegistryPreview Module + +## Synopsis + +Manages configuration for the Registry Preview utility, which visualizes and edits Windows registry files (.reg). + +## Description + +The `RegistryPreview` module configures PowerToys Registry Preview, a utility +that provides a visual preview and editing interface for Windows registry +(.reg) files. It helps you understand and safely edit registry files before +applying them to your system. + +## Properties + +The RegistryPreview module supports the following configurable properties: + +### DefaultRegApp + +Controls whether Registry Preview is set as the default application for .reg files. + +**Type:** boolean +**Default:** `false` + +## Examples + +### Example 1 - Set as default .reg handler with direct execution + +This example sets Registry Preview as the default application for .reg files. + +```powershell +$config = @{ + settings = @{ + properties = @{ + DefaultRegApp = $true + } + name = "RegistryPreview" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module RegistryPreview --input $config +``` + +### Example 2 - Configure with DSC + +This example configures Registry Preview as the default handler. + +```bash +dsc config set --file registrypreview-default.dsc.yaml +``` + +```yaml +# registrypreview-default.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Set Registry Preview as default + type: Microsoft.PowerToys/RegistryPreviewSettings + properties: + settings: + properties: + DefaultRegApp: true + name: RegistryPreview + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and sets Registry Preview as the default .reg +handler. + +```bash +winget configure winget-registrypreview.yaml +``` + +```yaml +# winget-registrypreview.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Registry Preview + type: Microsoft.PowerToys/RegistryPreviewSettings + properties: + settings: + properties: + DefaultRegApp: true + name: RegistryPreview + version: 1.0 +``` + +### Example 4 - Disable as default handler + +This example ensures Registry Preview is not the default .reg handler. + +```bash +dsc config set --file registrypreview-notdefault.dsc.yaml +``` + +```yaml +# registrypreview-notdefault.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Do not use as default + type: Microsoft.PowerToys/RegistryPreviewSettings + properties: + settings: + properties: + DefaultRegApp: false + name: RegistryPreview + version: 1.0 +``` + +## Use cases + +### System administration + +Configure as default for safe registry file handling: + +```yaml +resources: + - name: Admin configuration + type: Microsoft.PowerToys/RegistryPreviewSettings + properties: + settings: + properties: + DefaultRegApp: true + name: RegistryPreview + version: 1.0 +``` + +### Optional tool + +Keep as optional tool without default file association: + +```yaml +resources: + - name: Optional tool + type: Microsoft.PowerToys/RegistryPreviewSettings + properties: + settings: + properties: + DefaultRegApp: false + name: RegistryPreview + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [FileLocksmith][03] +- [PowerToys Registry Preview Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./FileLocksmith.md +[04]: https://learn.microsoft.com/windows/powertoys/registry-preview diff --git a/doc/dsc/modules/ShortcutGuide.md b/doc/dsc/modules/ShortcutGuide.md new file mode 100644 index 0000000000..1b7595a9af --- /dev/null +++ b/doc/dsc/modules/ShortcutGuide.md @@ -0,0 +1,259 @@ +--- +description: DSC configuration reference for PowerToys ShortcutGuide module +ms.date: 10/18/2025 +ms.topic: reference +title: ShortcutGuide Module +--- + +# ShortcutGuide Module + +## Synopsis + +Manages configuration for the Shortcut Guide utility, which displays available keyboard shortcuts. + +## Description + +The `ShortcutGuide` module configures PowerToys Shortcut Guide, a utility that +displays an overlay showing available Windows keyboard shortcuts when you hold +the Windows key. It helps users discover and learn keyboard shortcuts. + +## Properties + +The ShortcutGuide module supports the following configurable properties: + +### OpenShortcutGuide + +Sets the keyboard shortcut or method to open the shortcut guide. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier +- `ctrl` (boolean) - Ctrl key modifier +- `alt` (boolean) - Alt key modifier +- `shift` (boolean) - Shift key modifier +- `code` (integer) - Virtual key code +- `key` (string) - Key name + +**Default:** Hold Windows key for 900ms + +### OverlayOpacity + +Sets the opacity of the shortcut guide overlay (0-100). + +**Type:** integer +**Range:** `0` to `100` +**Default:** `90` + +### Theme + +Sets the theme for the shortcut guide. + +**Type:** string +**Allowed values:** `"light"`, `"dark"`, `"system"` +**Default:** `"dark"` + +### PressTime + +Sets how long the Windows key must be held before showing the guide (in milliseconds). + +**Type:** integer +**Range:** `100` to `10000` +**Default:** `900` + +### ExcludedApps + +List of applications where Shortcut Guide is disabled. + +**Type:** string (newline-separated list of executable names) + +## Examples + +### Example 1 - Configure activation time with direct execution + +This example sets a faster activation time for the shortcut guide. + +```powershell +$config = @{ + settings = @{ + properties = @{ + PressTime = 600 + } + name = "ShortcutGuide" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module ShortcutGuide ` + --input $config +``` + +### Example 2 - Configure appearance with DSC + +This example customizes the overlay appearance. + +```bash +dsc config set --file shortcutguide-appearance.dsc.yaml +``` + +```yaml +# shortcutguide-appearance.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Shortcut Guide appearance + type: Microsoft.PowerToys/ShortcutGuideSettings + properties: + settings: + properties: + OverlayOpacity: 95 + Theme: light + name: ShortcutGuide + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Shortcut Guide. + +```bash +winget configure winget-shortcutguide.yaml +``` + +```yaml +# winget-shortcutguide.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Shortcut Guide + type: Microsoft.PowerToys/ShortcutGuideSettings + properties: + settings: + properties: + PressTime: 700 + OverlayOpacity: 90 + Theme: dark + name: ShortcutGuide + version: 1.0 +``` + +### Example 4 - Quick activation + +This example configures for quick activation with a short press time. + +```bash +dsc config set --file shortcutguide-quick.dsc.yaml +``` + +```yaml +# shortcutguide-quick.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Quick activation + type: Microsoft.PowerToys/ShortcutGuideSettings + properties: + settings: + properties: + PressTime: 400 + name: ShortcutGuide + version: 1.0 +``` + +### Example 5 - High opacity for visibility + +This example maximizes opacity for better visibility. + +```powershell +$config = @{ + settings = @{ + properties = @{ + OverlayOpacity = 100 + Theme = "dark" + } + name = "ShortcutGuide" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module ShortcutGuide --input $config +``` + +### Example 6 - Exclude applications + +This example excludes Shortcut Guide from specific applications. + +```bash +dsc config set --file shortcutguide-exclusions.dsc.yaml +``` + +```yaml +# shortcutguide-exclusions.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Exclude apps + type: Microsoft.PowerToys/ShortcutGuideSettings + properties: + settings: + properties: + ExcludedApps: | + Game.exe + FullScreenApp.exe + name: ShortcutGuide + version: 1.0 +``` + +## Use cases + +### New users + +Configure for easy keyboard shortcut discovery: + +```yaml +resources: + - name: New user configuration + type: Microsoft.PowerToys/ShortcutGuideSettings + properties: + settings: + properties: + PressTime: 800 + OverlayOpacity: 95 + name: ShortcutGuide + version: 1.0 +``` + +### Power users + +Configure for quick access without accidental activation: + +```yaml +resources: + - name: Power user configuration + type: Microsoft.PowerToys/ShortcutGuideSettings + properties: + settings: + properties: + PressTime: 1200 + OverlayOpacity: 85 + name: ShortcutGuide + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [Peek][03] +- [PowerToys Keyboard Shortcut Guide Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./Peek.md +[04]: https://learn.microsoft.com/windows/powertoys/shortcut-guide diff --git a/doc/dsc/modules/Workspaces.md b/doc/dsc/modules/Workspaces.md new file mode 100644 index 0000000000..34bf50e441 --- /dev/null +++ b/doc/dsc/modules/Workspaces.md @@ -0,0 +1,238 @@ +--- +description: DSC configuration reference for PowerToys Workspaces module +ms.date: 10/18/2025 +ms.topic: reference +title: Workspaces Module +--- + +# Workspaces Module + +## Synopsis + +Manages configuration for the Workspaces utility, which launches application sets and arranges windows. + +## Description + +The `Workspaces` module configures PowerToys Workspaces, a utility that allows +you to save and restore sets of applications with their window positions. It +enables you to quickly switch between different work contexts by launching and +arranging multiple applications at once. + +## Properties + +The Workspaces module supports the following configurable properties: + +### LaunchHotkey + +Sets the keyboard shortcut to launch the Workspaces editor. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier +- `ctrl` (boolean) - Ctrl key modifier +- `alt` (boolean) - Alt key modifier +- `shift` (boolean) - Shift key modifier +- `code` (integer) - Virtual key code +- `key` (string) - Key name + +**Default:** `Win+Shift+;` (VK code 186) + +### MoveExistingWindows + +Controls whether existing application windows are moved when launching a workspace. + +**Type:** boolean +**Default:** `false` + +### SpanZonesAcrossMonitors + +Controls whether workspace zones can span across multiple monitors. + +**Type:** boolean +**Default:** `false` + +## Examples + +### Example 1 - Configure launch hotkey with direct execution + +This example sets a custom hotkey to launch the Workspaces editor. + +```powershell +$config = @{ + settings = @{ + properties = @{ + LaunchHotkey = @{ + win = $true + ctrl = $true + alt = $false + shift = $false + code = 87 + key = "W" + } + } + name = "Workspaces" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module Workspaces --input $config +``` + +### Example 2 - Configure window behavior with DSC + +This example enables moving existing windows when launching workspaces. + +```bash +dsc config set --file workspaces-behavior.dsc.yaml +``` + +```yaml +# workspaces-behavior.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Workspaces window behavior + type: Microsoft.PowerToys/WorkspacesSettings + properties: + settings: + properties: + MoveExistingWindows: true + SpanZonesAcrossMonitors: false + name: Workspaces + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures Workspaces. + +```bash +winget configure winget-workspaces.yaml +``` + +```yaml +# winget-workspaces.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure Workspaces + type: Microsoft.PowerToys/WorkspacesSettings + properties: + settings: + properties: + LaunchHotkey: + win: true + ctrl: false + alt: false + shift: true + code: 186 + key: ";" + MoveExistingWindows: true + name: Workspaces + version: 1.0 +``` + +### Example 4 - Multi-monitor setup + +This example configures for multi-monitor workspace management. + +```bash +dsc config set --file workspaces-multimonitor.dsc.yaml +``` + +```yaml +# workspaces-multimonitor.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Multi-monitor configuration + type: Microsoft.PowerToys/WorkspacesSettings + properties: + settings: + properties: + SpanZonesAcrossMonitors: true + MoveExistingWindows: true + name: Workspaces + version: 1.0 +``` + +### Example 5 - Simple hotkey + +This example sets a simple single-key hotkey combination. + +```powershell +$config = @{ + settings = @{ + properties = @{ + LaunchHotkey = @{ + win = $true + ctrl = $false + alt = $true + shift = $false + code = 192 + key = "~" + } + } + name = "Workspaces" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module Workspaces --input $config +``` + +## Use cases + +### Development environments + +Configure for quick switching between development workspaces: + +```yaml +resources: + - name: Development workspace + type: Microsoft.PowerToys/WorkspacesSettings + properties: + settings: + properties: + MoveExistingWindows: true + SpanZonesAcrossMonitors: true + name: Workspaces + version: 1.0 +``` + +### Single monitor usage + +Configure for single-monitor workflow: + +```yaml +resources: + - name: Single monitor setup + type: Microsoft.PowerToys/WorkspacesSettings + properties: + settings: + properties: + SpanZonesAcrossMonitors: false + MoveExistingWindows: false + name: Workspaces + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [ColorPicker Module][03] - For additional PowerToys configuration +- [PowerToys Workspaces Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./ColorPicker.md +[04]: https://learn.microsoft.com/windows/powertoys/workspaces diff --git a/doc/dsc/modules/ZoomIt.md b/doc/dsc/modules/ZoomIt.md new file mode 100644 index 0000000000..7292665bbe --- /dev/null +++ b/doc/dsc/modules/ZoomIt.md @@ -0,0 +1,215 @@ +--- +description: DSC configuration reference for PowerToys ZoomIt module +ms.date: 10/18/2025 +ms.topic: reference +title: ZoomIt Module +--- + +# ZoomIt Module + +## Synopsis + +Manages configuration for the ZoomIt utility, which provides screen zoom, annotation, and presentation tools. + +## Description + +The `ZoomIt` module configures PowerToys ZoomIt, a screen zoom and annotation utility for presentations and demonstrations. It provides live zoom, screen drawing, a break timer, and other presentation features activated through customizable keyboard shortcuts. + +## Properties + +The ZoomIt module supports the following configurable properties: + +### ActivationShortcut + +Sets the keyboard shortcut to activate the zoom mode. + +**Type:** object +**Properties:** + +- `win` (boolean) - Windows key modifier +- `ctrl` (boolean) - Ctrl key modifier +- `alt` (boolean) - Alt key modifier +- `shift` (boolean) - Shift key modifier +- `code` (integer) - Virtual key code +- `key` (string) - Key name + +**Default:** `Ctrl+1` (VK code 49) + +## Examples + +### Example 1 - Configure activation shortcut with direct execution + +This example sets a custom keyboard shortcut to activate ZoomIt. + +```powershell +$config = @{ + settings = @{ + properties = @{ + ActivationShortcut = @{ + win = $false + ctrl = $true + alt = $false + shift = $true + code = 90 + key = "Z" + } + } + name = "ZoomIt" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +PowerToys.DSC.exe set --resource 'settings' --module ZoomIt --input $config +``` + +### Example 2 - Configure with Microsoft DSC + +This example configures the ZoomIt activation shortcut using Microsoft DSC. + +```bash +dsc config set --file zoomit-config.dsc.yaml +``` + +```yaml +# zoomit-config.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure ZoomIt shortcut + type: Microsoft.PowerToys/ZoomItSettings + properties: + settings: + properties: + ActivationShortcut: + win: false + ctrl: true + alt: false + shift: false + code: 49 + key: "1" + name: ZoomIt + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and configures ZoomIt using WinGet. + +```bash +winget configure winget-zoomit.yaml +``` + +```yaml +# winget-zoomit.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure ZoomIt + type: Microsoft.PowerToys/ZoomItSettings + properties: + settings: + properties: + ActivationShortcut: + win: false + ctrl: true + alt: false + shift: true + code: 90 + key: Z + name: ZoomIt + version: 1.0 +``` + +### Example 4 - Presentation mode hotkey + +This example configures an easy-to-remember presentation hotkey. + +```bash +dsc config set --file zoomit-presentation.dsc.yaml +``` + +```yaml +# zoomit-presentation.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Presentation hotkey + type: Microsoft.PowerToys/ZoomItSettings + properties: + settings: + properties: + ActivationShortcut: + win: true + ctrl: false + alt: false + shift: false + code: 187 + key: "=" + name: ZoomIt + version: 1.0 +``` + +## Use cases + +### Presentations + +Configure for easy screen zooming during presentations: + +```yaml +resources: + - name: Presentation setup + type: Microsoft.PowerToys/ZoomItSettings + properties: + settings: + properties: + ActivationShortcut: + win: false + ctrl: true + alt: false + shift: false + code: 49 + key: "1" + name: ZoomIt + version: 1.0 +``` + +### Screen recording + +Configure for quick access during screen recording sessions: + +```yaml +resources: + - name: Recording setup + type: Microsoft.PowerToys/ZoomItSettings + properties: + settings: + properties: + ActivationShortcut: + win: true + ctrl: false + alt: false + shift: true + code: 90 + key: Z + name: ZoomIt + version: 1.0 +``` + +## See also + +- [Settings Resource][01] +- [PowerToys DSC Overview][02] +- [CropAndLock Module][03] - For additional PowerToys configuration +- [PowerToys ZoomIt Documentation][04] + + +[01]: ../settings-resource.md +[02]: ../overview.md +[03]: ./CropAndLock.md +[04]: https://learn.microsoft.com/windows/powertoys/zoomit diff --git a/doc/dsc/overview.md b/doc/dsc/overview.md new file mode 100644 index 0000000000..755f8cd391 --- /dev/null +++ b/doc/dsc/overview.md @@ -0,0 +1,244 @@ +--- +description: Overview of PowerToys Desired State Configuration (DSC) support +ms.date: 10/18/2025 +ms.topic: overview +title: PowerToys DSC Overview +--- + +# PowerToys DSC Overview + +## Synopsis + +PowerToys supports Desired State Configuration (DSC) v3 for declarative configuration management of PowerToys settings. + +## Description + +PowerToys includes Microsoft Desired State Configuration (DSC) support +through the `PowerToys.DSC.exe` command-line tool, enabling you to: + +- Declare and enforce desired configuration states for PowerToys + utilities. +- Automate PowerToys configuration across multiple systems. +- Integrate PowerToys configuration with WinGet and other DSC-compatible + tools. +- Version control your PowerToys settings as code. + +The PowerToys DSC implementation provides a **settings** resource that +manages configuration for all PowerToys utilities (modules). Each utility +can be configured independently, allowing granular control over your +PowerToys environment. + +## Usage methods + +PowerToys DSC can be used in three ways: + +### 1. Direct execution with PowerToys.DSC.exe + +Execute DSC operations directly using the PowerToys.DSC.exe command-line +tool: + +```powershell +# Get current settings for a module +PowerToys.DSC.exe get --resource 'settings' --module Awake + +# Set settings for a module +$input = '{"settings":{...}}' +PowerToys.DSC.exe set --resource 'settings' --module Awake --input $input + +# Test if settings match desired state +PowerToys.DSC.exe test --resource 'settings' --module Awake --input $input +``` + +For detailed information, see [PowerToys.DSC.exe command reference][01]. + +### 2. Microsoft Desired State Configuration (DSC) + +Use PowerToys DSC resources in standard DSC configuration documents: + +```yaml +# powertoys-config.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Awake + type: Microsoft.PowerToys/AwakeSettings + properties: + settings: + properties: + keepDisplayOn: true + mode: 1 + name: Awake + version: 0.0.1 +``` + +### 3. WinGet Configuration + +Integrate PowerToys configuration with WinGet package installation: + +```yaml +# winget-powertoys.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure FancyZones + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + fancyzones_shiftDrag: true + fancyzones_mouseSwitch: true + name: FancyZones + version: 1.0 +``` + +## Available resources + +PowerToys DSC provides the following resource: + +| Resource | Description | +| ---------- | ---------------------------------------------------- | +| `settings` | Manages configuration for PowerToys utility modules. | + +For detailed information about the settings resource, see [Settings +Resource Reference][03]. + +## Available modules + +The settings resource supports configuration for the following PowerToys +utilities: + +| Module | Description | Documentation | +| ---------------------- | -------------------------------------------- | ------------------------------------- | +| App | General PowerToys application settings. | [App module][04] | +| AdvancedPaste | Advanced clipboard operations. | [AdvancedPaste module][05] | +| AlwaysOnTop | Pin windows to stay on top. | [AlwaysOnTop module][06] | +| Awake | Keep computer awake. | [Awake module][07] | +| ColorPicker | System-wide color picker utility. | [ColorPicker module][08] | +| CropAndLock | Crop and lock portions of windows. | [CropAndLock module][09] | +| EnvironmentVariables | Manage environment variables. | [EnvironmentVariables module][10] | +| FancyZones | Window layout manager. | [FancyZones module][11] | +| FileLocksmith | Identify what's locking files. | [FileLocksmith module][12] | +| FindMyMouse | Locate your mouse cursor. | [FindMyMouse module][13] | +| Hosts | Quick hosts file editor. | [Hosts module][14] | +| ImageResizer | Resize images from context menu. | [ImageResizer module][15] | +| KeyboardManager | Remap keys and create shortcuts. | [KeyboardManager module][16] | +| MeasureTool | Measure pixels on screen. | [MeasureTool module][17] | +| MouseHighlighter | Highlight mouse cursor. | [MouseHighlighter module][18] | +| MouseJump | Jump across large or multiple displays. | [MouseJump module][19] | +| MousePointerCrosshairs | Display crosshairs centered on mouse. | [MousePointerCrosshairs module][20] | +| Peek | Quick file previewer. | [Peek module][21] | +| PowerAccent | Quick accent character selector. | [PowerAccent module][22] | +| PowerOCR | Extract text from images. | [PowerOCR module][23] | +| PowerRename | Bulk rename files. | [PowerRename module][24] | +| RegistryPreview | Visualize and edit registry files. | [RegistryPreview module][25] | +| ShortcutGuide | Display keyboard shortcuts. | [ShortcutGuide module][26] | +| Workspaces | Save and restore application sets. | [Workspaces module][27] | +| ZoomIt | Screen zoom and annotation tool. | [ZoomIt module][28] | + +## Common operations + +### List all supported modules + +```powershell +PowerToys.DSC.exe modules --resource 'settings' +``` + +### Get current configuration + +```powershell +# Get configuration for a specific module. +PowerToys.DSC.exe get --resource 'settings' --module FancyZones + +# Export configuration (identical to get). +PowerToys.DSC.exe export --resource 'settings' --module FancyZones +``` + +### Apply configuration + +```powershell +# Set configuration for a module. +$input = '{"settings":{...}}' +PowerToys.DSC.exe set --resource 'settings' --module FancyZones --input $input +``` + +### Validate configuration + +```powershell +# Test if current state matches desired state. +$input = '{"settings":{...}}' +PowerToys.DSC.exe test --resource 'settings' --module FancyZones --input $input +``` + +### Generate schema + +```powershell +# Get JSON schema for a module's settings. +PowerToys.DSC.exe schema --resource 'settings' --module FancyZones +``` + +### Generate DSC manifest + +```powershell +# Generate manifest for a specific module. +$outputDir = "C:\manifests" +PowerToys.DSC.exe manifest --resource 'settings' --module FancyZones ` + --outputDir $outputDir + +# Generate manifests for all modules. +PowerToys.DSC.exe manifest --resource 'settings' --outputDir $outputDir +``` + +## Examples + +For complete examples, see: + +- [Settings Resource Examples][29] +- Individual module documentation in the [modules][30] folder + +## See also + +- [Settings Resource Reference][03] +- [PowerToys.DSC.exe Command Reference][01] +- [Module Documentation][30] +- [Microsoft DSC Documentation][31] +- [WinGet Configuration Documentation][32] + + +[01]: ./modules/ +[03]: ./settings-resource.md +[04]: ./modules/App.md +[05]: ./modules/AdvancedPaste.md +[06]: ./modules/AlwaysOnTop.md +[07]: ./modules/Awake.md +[08]: ./modules/ColorPicker.md +[09]: ./modules/CropAndLock.md +[10]: ./modules/EnvironmentVariables.md +[11]: ./modules/FancyZones.md +[12]: ./modules/FileLocksmith.md +[13]: ./modules/FindMyMouse.md +[14]: ./modules/Hosts.md +[15]: ./modules/ImageResizer.md +[16]: ./modules/KeyboardManager.md +[17]: ./modules/MeasureTool.md +[18]: ./modules/MouseHighlighter.md +[19]: ./modules/MouseJump.md +[20]: ./modules/MousePointerCrosshairs.md +[21]: ./modules/Peek.md +[22]: ./modules/PowerAccent.md +[23]: ./modules/PowerOCR.md +[24]: ./modules/PowerRename.md +[25]: ./modules/RegistryPreview.md +[26]: ./modules/ShortcutGuide.md +[27]: ./modules/Workspaces.md +[28]: ./modules/ZoomIt.md +[29]: ./settings-resource.md#examples +[30]: ./modules/ +[31]: https://learn.microsoft.com/powershell/dsc/overview +[32]: https://learn.microsoft.com/windows/package-manager/configuration/ diff --git a/doc/dsc/settings-resource.md b/doc/dsc/settings-resource.md new file mode 100644 index 0000000000..581674368b --- /dev/null +++ b/doc/dsc/settings-resource.md @@ -0,0 +1,458 @@ +--- +description: Reference for the PowerToys DSC settings resource +ms.date: 10/18/2025 +ms.topic: reference +title: Settings Resource +--- + +# Settings Resource + +## Synopsis + +Manages configuration settings for PowerToys utilities (modules). + +## Description + +The `settings` resource provides Microsoft Desired State Configuration (DSC) +support for managing PowerToys configuration. It enables declarative +configuration of PowerToys utilities, allowing you to define, test, and +enforce desired states for each module. + +Each PowerToys utility (module) has its own configurable properties that can +be managed through this resource. The settings resource supports standard DSC +operations: get, set, test, export, schema, and manifest generation. + +## Supported modules + +The settings resource supports the following PowerToys modules: + +- **App** - General application settings (enable/disable utilities, run at + startup, theme, etc.). +- **AdvancedPaste** - Advanced clipboard and paste operations. +- **AlwaysOnTop** - Window pinning configuration. +- **Awake** - Keep-awake timer settings. +- **ColorPicker** - Color picker activation and format settings. +- **CropAndLock** - Window cropping settings. +- **EnvironmentVariables** - Environment variable editor settings. +- **FancyZones** - Window layout and zone configuration. +- **FileLocksmith** - File lock detection settings. +- **FindMyMouse** - Mouse locator settings. +- **Hosts** - Hosts file editor settings. +- **ImageResizer** - Image resize configuration. +- **KeyboardManager** - Key remapping and shortcut settings. +- **MeasureTool** - Screen measurement tool settings. +- **MouseHighlighter** - Mouse highlighting configuration. +- **MouseJump** - Mouse jump navigation settings. +- **MousePointerCrosshairs** - Crosshair display settings. +- **Peek** - File preview settings. +- **PowerAccent** - Accent character selection settings. +- **PowerOCR** - Text extraction settings. +- **PowerRename** - Bulk rename configuration. +- **RegistryPreview** - Registry file preview settings. +- **ShortcutGuide** - Keyboard shortcut overlay settings. +- **Workspaces** - Application workspace settings. +- **ZoomIt** - Screen zoom and annotation settings. + +For detailed property information for each module, see the individual [module +documentation][01]. + +## Operations + +### List supported modules + +List all modules that can be configured with the settings resource. + +**Direct execution:** + +```powershell +# List all configurable modules. +PowerToys.DSC.exe modules --resource 'settings' +``` + +### Get current state + +Retrieve the current configuration state for a module. + +**Direct execution:** + +```powershell +# Get current settings for a module. +PowerToys.DSC.exe get --resource 'settings' --module +``` + +**DSC configuration:** + +```yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Get Awake settings + type: Microsoft.PowerToys/AwakeSettings + properties: {} +``` + +**WinGet configuration:** + +```yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Get FancyZones settings + type: Microsoft.PowerToys/FancyZonesSettings + properties: {} +``` + +### Export current state + +Export the current configuration state. The output is identical to the `get` +operation. + +**Direct execution:** + +```powershell +# Export current settings for a module. +PowerToys.DSC.exe export --resource 'settings' --module +``` + +### Set desired state + +Apply a configuration to a module, updating only the properties that differ +from the desired state. + +**Direct execution:** + +```powershell +# Set desired configuration for a module. +$input = '{ + "settings": { + "properties": { + "keepDisplayOn": true, + "mode": 1 + }, + "name": "Awake", + "version": "0.0.1" + } +}' +PowerToys.DSC.exe set --resource 'settings' --module Awake --input $input +``` + +**DSC configuration:** + +```yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Configure Awake + type: Microsoft.PowerToys/AwakeSettings + properties: + settings: + properties: + keepDisplayOn: true + mode: 1 + name: Awake + version: 0.0.1 +``` + +**WinGet configuration:** + +```yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install and configure PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + + - name: Configure FancyZones + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + fancyzones_shiftDrag: true + fancyzones_mouseSwitch: true + fancyzones_displayOrWorkAreaChange_moveWindows: true + name: FancyZones + version: 1.0 +``` + +### Test desired state + +Verify whether the current configuration matches the desired state. + +**Direct execution:** + +```powershell +# Test if current state matches desired state. +$input = '{ + "settings": { + "properties": { + "keepDisplayOn": true, + "mode": 1 + }, + "name": "Awake", + "version": "0.0.1" + } +}' +PowerToys.DSC.exe test --resource 'settings' --module Awake --input $input +``` + +The output includes an `_inDesiredState` property indicating whether the +configuration matches (`true`) or differs (`false`). + +**DSC configuration:** + +```yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Test Awake configuration + type: Microsoft.PowerToys/AwakeSettings + properties: + settings: + properties: + keepDisplayOn: true + mode: 1 + name: Awake + version: 0.0.1 +``` + +### Get schema + +Generate the JSON schema for a module's settings, describing all configurable +properties and their types. + +**Direct execution:** + +```powershell +# Get JSON schema for a module. +PowerToys.DSC.exe schema --resource 'settings' --module Awake + +# Format for readability. +PowerToys.DSC.exe schema --resource 'settings' --module Awake ` + | ConvertFrom-Json | ConvertTo-Json -Depth 10 +``` + +### Generate manifest + +Create a DSC resource manifest file for one or all modules. + +**Direct execution:** + +```powershell +# Generate manifest for a specific module. +$outputDir = "C:\manifests" +PowerToys.DSC.exe manifest --resource 'settings' --module Awake ` + --outputDir $outputDir + +# Generate manifests for all modules. +PowerToys.DSC.exe manifest --resource 'settings' --outputDir $outputDir + +# Print manifest to console (omit --outputDir). +PowerToys.DSC.exe manifest --resource 'settings' --module Awake +``` + +## Examples + +### Example 1 - Enable and configure FancyZones + +This example enables FancyZones and configures window dragging behavior using +direct execution. + +```powershell +# Get current FancyZones settings. +$current = PowerToys.DSC.exe get --resource 'settings' --module FancyZones ` + | ConvertFrom-Json + +# Modify settings. +$desired = @{ + settings = @{ + properties = @{ + fancyzones_shiftDrag = $true + fancyzones_mouseSwitch = $true + fancyzones_displayOrWorkAreaChange_moveWindows = $true + } + name = "FancyZones" + version = "1.0" + } +} | ConvertTo-Json -Depth 10 -Compress + +# Apply configuration. +PowerToys.DSC.exe set --resource 'settings' --module FancyZones ` + --input $desired +``` + +### Example 2 - Configure multiple utilities with DSC + +This example configures multiple PowerToys utilities in a single DSC +configuration. + +```yaml +# powertoys-multi.dsc.yaml +$schema: https://aka.ms/dsc/schemas/v3/bundled/config/document.json +resources: + - name: Enable PowerToys utilities + type: Microsoft.PowerToys/AppSettings + properties: + settings: + properties: + Enabled: + Awake: true + FancyZones: true + PowerRename: true + ColorPicker: true + name: App + version: 1.0 + + - name: Configure Awake + type: Microsoft.PowerToys/AwakeSettings + properties: + settings: + properties: + keepDisplayOn: true + mode: 1 + name: Awake + version: 0.0.1 + + - name: Configure ColorPicker + type: Microsoft.PowerToys/ColorPickerSettings + properties: + settings: + properties: + changecursor: true + copiedcolorrepresentation: "HEX" + name: ColorPicker + version: 1.0 +``` + +### Example 3 - Install and configure with WinGet + +This example installs PowerToys and applies configuration using WinGet. + +```yaml +# winget-powertoys-setup.yaml +$schema: https://raw.githubusercontent.com/PowerShell/DSC/main/schemas/2023/08/config/document.json +metadata: + winget: + processor: dscv3 +resources: + - name: Install PowerToys + type: Microsoft.WinGet.DSC/WinGetPackage + properties: + id: Microsoft.PowerToys + source: winget + ensure: Present + + - name: Configure general settings + type: Microsoft.PowerToys/AppSettings + properties: + settings: + properties: + run_elevated: true + startup: true + theme: "dark" + name: App + version: 1.0 + + - name: Configure FancyZones + type: Microsoft.PowerToys/FancyZonesSettings + properties: + settings: + properties: + fancyzones_shiftDrag: true + fancyzones_zoneSetChange_moveWindows: true + name: FancyZones + version: 1.0 + + - name: Configure ImageResizer + type: Microsoft.PowerToys/ImageResizerSettings + properties: + settings: + properties: + ImageResizerSizes: + - Name: Small + Width: 854 + Height: 480 + Unit: Pixel + Fit: Fit + - Name: Medium + Width: 1920 + Height: 1080 + Unit: Pixel + Fit: Fit + name: ImageResizer + version: 1.0 +``` + +Apply the configuration: + +```powershell +winget configure winget-powertoys-setup.yaml +``` + +### Example 4 - Test configuration drift + +This example tests whether the current configuration matches the desired +state. + +```powershell +# Define desired state. +$desired = @{ + settings = @{ + properties = @{ + keepDisplayOn = $true + mode = 1 + } + name = "Awake" + version = "0.0.1" + } +} | ConvertTo-Json -Depth 10 -Compress + +# Test for drift. +$result = PowerToys.DSC.exe test --resource 'settings' --module Awake ` + --input $desired | ConvertFrom-Json + +if ($result._inDesiredState) { + Write-Host "Configuration is in desired state" +} else { + Write-Host "Configuration has drifted from desired state" + + # Apply configuration. + PowerToys.DSC.exe set --resource 'settings' --module Awake ` + --input $desired +} +``` + +### Example 5 - Export all module configurations + +This example exports configuration for all modules. + +```powershell +# Get list of all modules. +$modules = PowerToys.DSC.exe modules --resource 'settings' + +# Export each module's configuration. +$configurations = @{} +foreach ($module in $modules) { + $config = PowerToys.DSC.exe export --resource 'settings' ` + --module $module | ConvertFrom-Json + $configurations[$module] = $config +} + +# Save to file. +$configurations | ConvertTo-Json -Depth 10 ` + | Out-File "powertoys-backup.json" +``` + +## See also + +- [PowerToys DSC Overview][02] +- [Module Documentation][01] +- [WinGet Configuration][03] + + +[01]: ./modules/ +[02]: ./overview.md +[03]: https://learn.microsoft.com/windows/package-manager/configuration/