mirror of
https://github.com/ChrisTitusTech/winutil.git
synced 2024-11-14 14:45:52 -06:00
Merge branch 'main' of https://github.com/ChrisTitusTech/winutil
This commit is contained in:
commit
311a291964
@ -15,10 +15,18 @@
|
|||||||
"Winget": "Alacritty.Alacritty",
|
"Winget": "Alacritty.Alacritty",
|
||||||
"choco": "alacritty"
|
"choco": "alacritty"
|
||||||
},
|
},
|
||||||
|
"WPFInstallangryipscanner": {
|
||||||
|
"Winget": "angryziber.AngryIPScanner",
|
||||||
|
"choco": "angryip"
|
||||||
|
},
|
||||||
"WPFInstallanydesk": {
|
"WPFInstallanydesk": {
|
||||||
"winget": "AnyDeskSoftwareGmbH.AnyDesk",
|
"winget": "AnyDeskSoftwareGmbH.AnyDesk",
|
||||||
"choco": "anydesk"
|
"choco": "anydesk"
|
||||||
},
|
},
|
||||||
|
"WPFInstallanki": {
|
||||||
|
"winget": "Anki.Anki",
|
||||||
|
"choco": "anki"
|
||||||
|
},
|
||||||
"WPFInstallaimp": {
|
"WPFInstallaimp": {
|
||||||
"winget": "AIMP.AIMP",
|
"winget": "AIMP.AIMP",
|
||||||
"choco": "aimp"
|
"choco": "aimp"
|
||||||
@ -41,7 +49,7 @@
|
|||||||
},
|
},
|
||||||
"WPFInstallbluestacks": {
|
"WPFInstallbluestacks": {
|
||||||
"winget": "BlueStack.BlueStacks",
|
"winget": "BlueStack.BlueStacks",
|
||||||
"choco": "na"
|
"choco": "bluestacks"
|
||||||
},
|
},
|
||||||
"WPFInstallbrave": {
|
"WPFInstallbrave": {
|
||||||
"winget": "Brave.Brave",
|
"winget": "Brave.Brave",
|
||||||
@ -51,10 +59,18 @@
|
|||||||
"winget": "Klocman.BulkCrapUninstaller",
|
"winget": "Klocman.BulkCrapUninstaller",
|
||||||
"choco": "bulk-crap-uninstaller"
|
"choco": "bulk-crap-uninstaller"
|
||||||
},
|
},
|
||||||
|
"WPFInstallcalibre": {
|
||||||
|
"winget": "calibre.calibre",
|
||||||
|
"choco": "calibre"
|
||||||
|
},
|
||||||
"WPFInstallchrome": {
|
"WPFInstallchrome": {
|
||||||
"winget": "Google.Chrome",
|
"winget": "Google.Chrome",
|
||||||
"choco": "googlechrome"
|
"choco": "googlechrome"
|
||||||
},
|
},
|
||||||
|
"WPFInstallcopyq": {
|
||||||
|
"winget": "copyq",
|
||||||
|
"choco": "copyq"
|
||||||
|
},
|
||||||
"WPFInstallchromium": {
|
"WPFInstallchromium": {
|
||||||
"winget": "eloston.ungoogled-chromium",
|
"winget": "eloston.ungoogled-chromium",
|
||||||
"choco": "chromium"
|
"choco": "chromium"
|
||||||
@ -63,6 +79,14 @@
|
|||||||
"winget": "CiderCollective.Cider",
|
"winget": "CiderCollective.Cider",
|
||||||
"choco": "cider"
|
"choco": "cider"
|
||||||
},
|
},
|
||||||
|
"WPFInstallclink": {
|
||||||
|
"winget": "chrisant996.Clink",
|
||||||
|
"choco": "clink"
|
||||||
|
},
|
||||||
|
"WPFInstallclipgrab": {
|
||||||
|
"winget": "na",
|
||||||
|
"choco": "clipgrab"
|
||||||
|
},
|
||||||
"WPFInstallcpuz": {
|
"WPFInstallcpuz": {
|
||||||
"winget": "CPUID.CPU-Z",
|
"winget": "CPUID.CPU-Z",
|
||||||
"choco": "cpu-z"
|
"choco": "cpu-z"
|
||||||
@ -75,6 +99,10 @@
|
|||||||
"winget": "DelugeTeam.Deluge",
|
"winget": "DelugeTeam.Deluge",
|
||||||
"choco": "deluge"
|
"choco": "deluge"
|
||||||
},
|
},
|
||||||
|
"WPFInstalldevtoys": {
|
||||||
|
"winget": "devtoys",
|
||||||
|
"choco": "devToys"
|
||||||
|
},
|
||||||
"WPFInstalldiscord": {
|
"WPFInstalldiscord": {
|
||||||
"winget": "Discord.Discord",
|
"winget": "Discord.Discord",
|
||||||
"choco": "discord"
|
"choco": "discord"
|
||||||
@ -99,6 +127,10 @@
|
|||||||
"winget": "Microsoft.DotNet.DesktopRuntime.7",
|
"winget": "Microsoft.DotNet.DesktopRuntime.7",
|
||||||
"choco": "dotnet-7.0-runtime"
|
"choco": "dotnet-7.0-runtime"
|
||||||
},
|
},
|
||||||
|
"WPFInstalldolphin": {
|
||||||
|
"winget": "KDE.Dolphin",
|
||||||
|
"choco": "na"
|
||||||
|
},
|
||||||
"WPFInstallduplicati": {
|
"WPFInstallduplicati": {
|
||||||
"winget": "Duplicati.Duplicati",
|
"winget": "Duplicati.Duplicati",
|
||||||
"choco": "duplicati"
|
"choco": "duplicati"
|
||||||
@ -131,9 +163,13 @@
|
|||||||
"winget": "Mozilla.Firefox",
|
"winget": "Mozilla.Firefox",
|
||||||
"choco": "firefox"
|
"choco": "firefox"
|
||||||
},
|
},
|
||||||
|
"WPFInstallfloorp": {
|
||||||
|
"winget": "Ablaze.Floorp",
|
||||||
|
"choco": "na"
|
||||||
|
},
|
||||||
"WPFInstallflameshot": {
|
"WPFInstallflameshot": {
|
||||||
"winget": "Flameshot.Flameshot",
|
"winget": "Flameshot.Flameshot",
|
||||||
"choco": "na"
|
"choco": "flameshot"
|
||||||
},
|
},
|
||||||
"WPFInstallflux": {
|
"WPFInstallflux": {
|
||||||
"winget": "flux.flux",
|
"winget": "flux.flux",
|
||||||
@ -167,6 +203,10 @@
|
|||||||
"winget": "Git.Git;GitHub.GitHubDesktop",
|
"winget": "Git.Git;GitHub.GitHubDesktop",
|
||||||
"choco": "git;github-desktop"
|
"choco": "git;github-desktop"
|
||||||
},
|
},
|
||||||
|
"WPFInstallgitextensions": {
|
||||||
|
"winget": "Git.Git;GitExtensionsTeam.GitExtensions",
|
||||||
|
"choco": "git;gitextensions"
|
||||||
|
},
|
||||||
"WPFInstallglaryutilities": {
|
"WPFInstallglaryutilities": {
|
||||||
"Winget": "Glarysoft.GlaryUtilities",
|
"Winget": "Glarysoft.GlaryUtilities",
|
||||||
"choco": "glaryutilities-free"
|
"choco": "glaryutilities-free"
|
||||||
@ -195,6 +235,10 @@
|
|||||||
"winget": "HandBrake.HandBrake",
|
"winget": "HandBrake.HandBrake",
|
||||||
"choco": "handbrake"
|
"choco": "handbrake"
|
||||||
},
|
},
|
||||||
|
"WPFInstallheidisql": {
|
||||||
|
"winget": "HeidiSQL.HeidiSQL",
|
||||||
|
"choco": "heidisql"
|
||||||
|
},
|
||||||
"WPFInstallheroiclauncher": {
|
"WPFInstallheroiclauncher": {
|
||||||
"winget": "HeroicGamesLauncher.HeroicGamesLauncher",
|
"winget": "HeroicGamesLauncher.HeroicGamesLauncher",
|
||||||
"choco": "na"
|
"choco": "na"
|
||||||
@ -303,14 +347,26 @@
|
|||||||
"winget": "LibreWolf.LibreWolf",
|
"winget": "LibreWolf.LibreWolf",
|
||||||
"choco": "librewolf"
|
"choco": "librewolf"
|
||||||
},
|
},
|
||||||
|
"WPFInstalllinphone": {
|
||||||
|
"winget": "BelledonneCommunications.Linphone",
|
||||||
|
"choco": "linphone"
|
||||||
|
},
|
||||||
"WPFInstallmalwarebytes": {
|
"WPFInstallmalwarebytes": {
|
||||||
"winget": "Malwarebytes.Malwarebytes",
|
"winget": "Malwarebytes.Malwarebytes",
|
||||||
"choco": "malwarebytes"
|
"choco": "malwarebytes"
|
||||||
},
|
},
|
||||||
|
"WPFInstallmasscode": {
|
||||||
|
"winget": "antonreshetov.massCode",
|
||||||
|
"choco": "na"
|
||||||
|
},
|
||||||
"WPFInstallmatrix": {
|
"WPFInstallmatrix": {
|
||||||
"winget": "Element.Element",
|
"winget": "Element.Element",
|
||||||
"choco": "element-desktop"
|
"choco": "element-desktop"
|
||||||
},
|
},
|
||||||
|
"WPFInstallmercury": {
|
||||||
|
"winget": "Alex313031.Mercury",
|
||||||
|
"choco": "na"
|
||||||
|
},
|
||||||
"WPFInstallmonitorian": {
|
"WPFInstallmonitorian": {
|
||||||
"winget": "emoacht.Monitorian",
|
"winget": "emoacht.Monitorian",
|
||||||
"choco": "monitorian"
|
"choco": "monitorian"
|
||||||
@ -347,6 +403,10 @@
|
|||||||
"winget": "Neovim.Neovim",
|
"winget": "Neovim.Neovim",
|
||||||
"choco": "neovim"
|
"choco": "neovim"
|
||||||
},
|
},
|
||||||
|
"WPFInstallnextclouddesktop": {
|
||||||
|
"winget": "Nextcloud.NextcloudDesktop",
|
||||||
|
"choco": "nextcloud-client"
|
||||||
|
},
|
||||||
"WPFInstallnglide": {
|
"WPFInstallnglide": {
|
||||||
"winget": "ZeusSoftware.nGlide",
|
"winget": "ZeusSoftware.nGlide",
|
||||||
"choco": "na"
|
"choco": "na"
|
||||||
@ -403,6 +463,10 @@
|
|||||||
"winget": "Apache.OpenOffice",
|
"winget": "Apache.OpenOffice",
|
||||||
"choco": "openoffice"
|
"choco": "openoffice"
|
||||||
},
|
},
|
||||||
|
"WPFInstallopenrgb": {
|
||||||
|
"winget": "CalcProgrammer1.OpenRGB",
|
||||||
|
"choco": "openrgb"
|
||||||
|
},
|
||||||
"WPFInstallopenshell": {
|
"WPFInstallopenshell": {
|
||||||
"winget": "Open-Shell.Open-Shell-Menu",
|
"winget": "Open-Shell.Open-Shell-Menu",
|
||||||
"choco": "open-shell"
|
"choco": "open-shell"
|
||||||
@ -415,10 +479,18 @@
|
|||||||
"winget": "Oracle.VirtualBox",
|
"winget": "Oracle.VirtualBox",
|
||||||
"choco": "virtualbox"
|
"choco": "virtualbox"
|
||||||
},
|
},
|
||||||
|
"WPFInstallownclouddesktop": {
|
||||||
|
"winget": "ownCloud.ownCloudDesktop",
|
||||||
|
"choco": "owncloud-client"
|
||||||
|
},
|
||||||
"WPFInstallPaintdotnet": {
|
"WPFInstallPaintdotnet": {
|
||||||
"winget": "dotPDNLLC.paintdotnet",
|
"winget": "dotPDNLLC.paintdotnet",
|
||||||
"choco": "paint.net"
|
"choco": "paint.net"
|
||||||
},
|
},
|
||||||
|
"WPFInstallpdfsam": {
|
||||||
|
"winget": "PDFsam.PDFsam",
|
||||||
|
"choco": "pdfsam"
|
||||||
|
},
|
||||||
"WPFInstallpeazip": {
|
"WPFInstallpeazip": {
|
||||||
"winget": "Giorgiotani.Peazip",
|
"winget": "Giorgiotani.Peazip",
|
||||||
"choco": "peazip"
|
"choco": "peazip"
|
||||||
@ -431,13 +503,21 @@
|
|||||||
"winget": "Microsoft.PowerShell",
|
"winget": "Microsoft.PowerShell",
|
||||||
"choco": "powershell-core"
|
"choco": "powershell-core"
|
||||||
},
|
},
|
||||||
|
"WPFInstallposh": {
|
||||||
|
"winget": "JanDeDobbeleer.OhMyPosh",
|
||||||
|
"choco": "oh-my-posh"
|
||||||
|
},
|
||||||
"WPFInstallpowertoys": {
|
"WPFInstallpowertoys": {
|
||||||
"winget": "Microsoft.PowerToys",
|
"winget": "Microsoft.PowerToys",
|
||||||
"choco": "powertoys"
|
"choco": "powertoys"
|
||||||
},
|
},
|
||||||
|
"WPFInstallportmaster": {
|
||||||
|
"winget": "portmaster",
|
||||||
|
"choco": "portmaster"
|
||||||
|
},
|
||||||
"WPFInstallprismlauncher": {
|
"WPFInstallprismlauncher": {
|
||||||
"winget": "PrismLauncher.PrismLauncher",
|
"winget": "PrismLauncher.PrismLauncher",
|
||||||
"choco": "na"
|
"choco": "prismlauncher"
|
||||||
},
|
},
|
||||||
"WPFInstallprocesslasso": {
|
"WPFInstallprocesslasso": {
|
||||||
"winget": "BitSum.ProcessLasso",
|
"winget": "BitSum.ProcessLasso",
|
||||||
@ -493,7 +573,7 @@
|
|||||||
},
|
},
|
||||||
"WPFInstallshell": {
|
"WPFInstallshell": {
|
||||||
"winget": "Nilesoft.Shell",
|
"winget": "Nilesoft.Shell",
|
||||||
"choco": "na"
|
"choco": "nilesoft-shell"
|
||||||
},
|
},
|
||||||
"WPFInstallsignal": {
|
"WPFInstallsignal": {
|
||||||
"winget": "OpenWhisperSystems.Signal",
|
"winget": "OpenWhisperSystems.Signal",
|
||||||
@ -519,11 +599,19 @@
|
|||||||
"winget": "Valve.Steam",
|
"winget": "Valve.Steam",
|
||||||
"choco": "steam-client"
|
"choco": "steam-client"
|
||||||
},
|
},
|
||||||
|
"WPFInstallstarship": {
|
||||||
|
"winget": "starship",
|
||||||
|
"choco": "starship"
|
||||||
|
},
|
||||||
"WPFInstallstrawberry": {
|
"WPFInstallstrawberry": {
|
||||||
"winget": "StrawberryMusicPlayer.Strawberry",
|
"winget": "StrawberryMusicPlayer.Strawberry",
|
||||||
"choco": "strawberrymusicplayer"
|
"choco": "strawberrymusicplayer"
|
||||||
},
|
},
|
||||||
"WPFInstallsublime": {
|
"WPFInstallsublimemerge": {
|
||||||
|
"winget": "SublimeHQ.SublimeMerge",
|
||||||
|
"choco": "sublimemerge"
|
||||||
|
},
|
||||||
|
"WPFInstallsublimetext": {
|
||||||
"winget": "SublimeHQ.SublimeText.4",
|
"winget": "SublimeHQ.SublimeText.4",
|
||||||
"choco": "sublimetext4"
|
"choco": "sublimetext4"
|
||||||
},
|
},
|
||||||
|
@ -11,9 +11,13 @@
|
|||||||
"ButtonConfigBackgroundColor": "#444444",
|
"ButtonConfigBackgroundColor": "#444444",
|
||||||
"ButtonUpdatesBackgroundColor": "#555555",
|
"ButtonUpdatesBackgroundColor": "#555555",
|
||||||
"ButtonInstallForegroundColor": "#FFFFFF",
|
"ButtonInstallForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonTweaksForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonConfigForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonUpdatesForegroundColor": "#FFFFFF",
|
||||||
"ButtonBackgroundColor": "#CACACA",
|
"ButtonBackgroundColor": "#CACACA",
|
||||||
"ButtonBackgroundPressedColor": "#FFFFFF",
|
"ButtonBackgroundPressedColor": "#FFFFFF",
|
||||||
"ButtonBackgroundMouseoverColor": "AliceBlue",
|
"ButtonBackgroundMouseoverColor": "#A55A64",
|
||||||
|
"ButtonBackgroundSelectedColor": "#BADFFF",
|
||||||
"ButtonForegroundColor": "#000000",
|
"ButtonForegroundColor": "#000000",
|
||||||
"ButtonBorderThickness": "0",
|
"ButtonBorderThickness": "0",
|
||||||
"ButtonMargin": "0,3,0,3",
|
"ButtonMargin": "0,3,0,3",
|
||||||
@ -31,12 +35,16 @@
|
|||||||
"ButtonConfigBackgroundColor": "#444444",
|
"ButtonConfigBackgroundColor": "#444444",
|
||||||
"ButtonUpdatesBackgroundColor": "#555555",
|
"ButtonUpdatesBackgroundColor": "#555555",
|
||||||
"ButtonInstallForegroundColor": "#FFFFFF",
|
"ButtonInstallForegroundColor": "#FFFFFF",
|
||||||
"ButtonBackgroundColor": "#000000",
|
"ButtonTweaksForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonConfigForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonUpdatesForegroundColor": "#FFFFFF",
|
||||||
|
"ButtonBackgroundColor": "#000019",
|
||||||
"ButtonBackgroundPressedColor": "#FFFFFF",
|
"ButtonBackgroundPressedColor": "#FFFFFF",
|
||||||
"ButtonBackgroundMouseoverColor": "#A55A64",
|
"ButtonBackgroundMouseoverColor": "#A55A64",
|
||||||
|
"ButtonBackgroundSelectedColor": "#FF5733",
|
||||||
"ButtonForegroundColor": "#9CCC65",
|
"ButtonForegroundColor": "#9CCC65",
|
||||||
"ButtonBorderThickness": "3",
|
"ButtonBorderThickness": "1",
|
||||||
"ButtonMargin": "2",
|
"ButtonMargin": "1",
|
||||||
"ButtonCornerRadius": "4"
|
"ButtonCornerRadius": "2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
48
functions/private/Copy-Files.ps1
Normal file
48
functions/private/Copy-Files.ps1
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
function Copy-Files {
|
||||||
|
<#
|
||||||
|
|
||||||
|
.DESCRIPTION
|
||||||
|
This function will make all modifications to the registry
|
||||||
|
|
||||||
|
.EXAMPLE
|
||||||
|
|
||||||
|
Set-WinUtilRegistry -Name "PublishUserActivities" -Path "HKLM:\SOFTWARE\Policies\Microsoft\Windows\System" -Type "DWord" -Value "0"
|
||||||
|
|
||||||
|
#>
|
||||||
|
param (
|
||||||
|
[string] $Path,
|
||||||
|
[string] $Destination,
|
||||||
|
[switch] $Recurse = $false,
|
||||||
|
[switch] $Force = $false
|
||||||
|
)
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
$files = Get-ChildItem -Path $path -Recurse:$recurse
|
||||||
|
Write-Host "Copy $($files.Count)(s) from $path to $destination"
|
||||||
|
|
||||||
|
foreach($file in $files)
|
||||||
|
{
|
||||||
|
$status = "Copy files {0} on {1}: {2}" -f $counter, $files.Count, $file.Name
|
||||||
|
Write-Progress -Activity "Copy Windows files" -Status $status -PercentComplete ($counter++/$files.count*100)
|
||||||
|
$restpath = $file.FullName -Replace $path, ''
|
||||||
|
|
||||||
|
if($file.PSIsContainer -eq $true)
|
||||||
|
{
|
||||||
|
Write-Debug "Creating $($destination + $restpath)"
|
||||||
|
New-Item ($destination+$restpath) -Force:$force -Type Directory -ErrorAction SilentlyContinue
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Write-Debug "Copy from $($file.FullName) to $($destination+$restpath)"
|
||||||
|
Copy-Item $file.FullName ($destination+$restpath) -ErrorAction SilentlyContinue -Force:$force
|
||||||
|
Set-ItemProperty -Path ($destination+$restpath) -Name IsReadOnly -Value $false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Write-Progress -Activity "Copy Windows files" -Status "Ready" -Completed
|
||||||
|
}
|
||||||
|
Catch{
|
||||||
|
Write-Warning "Unable to Copy all the files due to unhandled exception"
|
||||||
|
Write-Warning $psitem.Exception.StackTrace
|
||||||
|
}
|
||||||
|
}
|
42
functions/private/Get-LocalizedYesNo.ps1
Normal file
42
functions/private/Get-LocalizedYesNo.ps1
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
function Get-LocalizedYesNo {
|
||||||
|
<#
|
||||||
|
.SYNOPSIS
|
||||||
|
This function runs takeown.exe and captures its output to extract yes no in a localized Windows
|
||||||
|
|
||||||
|
.DESCRIPTION
|
||||||
|
The function retrieves lines from the output of takeown.exe until there are at least 2 characters
|
||||||
|
captured in a specific format, such as "Yes=<first character>, No=<second character>".
|
||||||
|
|
||||||
|
.EXAMPLE
|
||||||
|
$yesNoArray = Get-LocalizedYesNo
|
||||||
|
Write-Host "Yes=$($yesNoArray[0]), No=$($yesNoArray[1])"
|
||||||
|
#>
|
||||||
|
|
||||||
|
# Run takeown.exe and capture its output
|
||||||
|
$takeownOutput = & takeown.exe /? | Out-String
|
||||||
|
|
||||||
|
# Parse the output and retrieve lines until there are at least 2 characters in the array
|
||||||
|
$found = $false
|
||||||
|
$charactersArray = @()
|
||||||
|
foreach ($line in $takeownOutput -split "`r`n")
|
||||||
|
{
|
||||||
|
if ($found)
|
||||||
|
{
|
||||||
|
$characters = $line -split '(")([A-Za-z])(")' | Where-Object { $_ -match '^[A-Za-z]$' }
|
||||||
|
$charactersArray += $characters
|
||||||
|
|
||||||
|
if ($charactersArray.Count -ge 2)
|
||||||
|
{
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
elseif ($line -match "/D ")
|
||||||
|
{
|
||||||
|
$found = $true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Debug "According to takeown.exe local Yes is $charactersArray[0]"
|
||||||
|
# Return the array of characters
|
||||||
|
return $charactersArray
|
||||||
|
}
|
@ -11,7 +11,7 @@ function Get-WinUtilVariables {
|
|||||||
#>
|
#>
|
||||||
param (
|
param (
|
||||||
[Parameter()]
|
[Parameter()]
|
||||||
[ValidateSet("CheckBox", "Button")]
|
[ValidateSet("CheckBox", "Button", "ToggleButton")]
|
||||||
[string]$Type
|
[string]$Type
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -14,6 +14,8 @@ function Install-WinUtilWinget {
|
|||||||
.SYNOPSIS
|
.SYNOPSIS
|
||||||
Installs Winget if it is not already installed
|
Installs Winget if it is not already installed
|
||||||
|
|
||||||
|
.DESCRIPTION
|
||||||
|
This function will download the latest version of winget and install it. If winget is already installed, it will do nothing.
|
||||||
#>
|
#>
|
||||||
Try{
|
Try{
|
||||||
Write-Host "Checking if Winget is Installed..."
|
Write-Host "Checking if Winget is Installed..."
|
||||||
|
564
functions/private/MicroWin-Helper.ps1
Normal file
564
functions/private/MicroWin-Helper.ps1
Normal file
@ -0,0 +1,564 @@
|
|||||||
|
function Remove-Features([switch] $dumpFeatures = $false, [switch] $keepDefender = $false) {
|
||||||
|
<#
|
||||||
|
|
||||||
|
.SYNOPSIS
|
||||||
|
Removes certain features from ISO image
|
||||||
|
|
||||||
|
.PARAMETER Name
|
||||||
|
dumpFeatures - Dumps all features found in the ISO into a file called allfeaturesdump.txt. This file can be examined and used to decide what to remove.
|
||||||
|
keepDefender - Should Defender be removed from the ISO?
|
||||||
|
|
||||||
|
.EXAMPLE
|
||||||
|
Remove-Features -keepDefender:$false
|
||||||
|
|
||||||
|
#>
|
||||||
|
$appxlist = dism /image:$scratchDir /Get-Features | Select-String -Pattern "Feature Name : " -CaseSensitive -SimpleMatch
|
||||||
|
$appxlist = $appxlist -split "Feature Name : " | Where-Object {$_}
|
||||||
|
if ($dumpFeatures)
|
||||||
|
{
|
||||||
|
$appxlist > allfeaturesdump.txt
|
||||||
|
}
|
||||||
|
|
||||||
|
$appxlist = $appxlist | Where-Object {
|
||||||
|
$_ -NotLike "*Printing*" -AND
|
||||||
|
$_ -NotLike "*TelnetClient*" -AND
|
||||||
|
$_ -NotLike "*PowerShell*" -AND
|
||||||
|
$_ -NotLike "*NetFx*"
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($keepDefender) { $appxlist = $appxlist | Where-Object { $_ -NotLike "*Defender*" }}
|
||||||
|
|
||||||
|
foreach($feature in $appxlist)
|
||||||
|
{
|
||||||
|
$status = "Removing feature $feature"
|
||||||
|
Write-Progress -Activity "Removing features" -Status $status -PercentComplete ($counter++/$appxlist.Count*100)
|
||||||
|
Write-Debug "Removing feature $feature"
|
||||||
|
# dism /image:$scratchDir /Disable-Feature /FeatureName:$feature /Remove /NoRestart > $null
|
||||||
|
}
|
||||||
|
Write-Progress -Activity "Removing features" -Status "Ready" -Completed
|
||||||
|
}
|
||||||
|
|
||||||
|
function Remove-Packages
|
||||||
|
{
|
||||||
|
$appxlist = dism /Image:$scratchDir /Get-Packages | Select-String -Pattern "Package Identity : " -CaseSensitive -SimpleMatch
|
||||||
|
$appxlist = $appxlist -split "Package Identity : " | Where-Object {$_}
|
||||||
|
|
||||||
|
$appxlist = $appxlist | Where-Object {
|
||||||
|
$_ -NotLike "*ApplicationModel*" -AND
|
||||||
|
$_ -NotLike "*indows-Client-LanguagePack*" -AND
|
||||||
|
$_ -NotLike "*LanguageFeatures-Basic*" -AND
|
||||||
|
$_ -NotLike "*Package_for_ServicingStack*" -AND
|
||||||
|
$_ -NotLike "*.NET*" -AND
|
||||||
|
$_ -NotLike "*Store*" -AND
|
||||||
|
$_ -NotLike "*VCLibs*" -AND
|
||||||
|
$_ -NotLike "*AAD.BrokerPlugin",
|
||||||
|
$_ -NotLike "*LockApp*" -AND
|
||||||
|
$_ -NotLike "*Notepad*" -AND
|
||||||
|
$_ -NotLike "*immersivecontrolpanel*" -AND
|
||||||
|
$_ -NotLike "*ContentDeliveryManager*" -AND
|
||||||
|
$_ -NotLike "*PinningConfirMationDialog*" -AND
|
||||||
|
$_ -NotLike "*SecHealthUI*" -AND
|
||||||
|
$_ -NotLike "*SecureAssessmentBrowser*" -AND
|
||||||
|
$_ -NotLike "*PrintDialog*" -AND
|
||||||
|
$_ -NotLike "*AssignedAccessLockApp*" -AND
|
||||||
|
$_ -NotLike "*OOBENetworkConnectionFlow*" -AND
|
||||||
|
$_ -NotLike "*Apprep.ChxApp*" -AND
|
||||||
|
$_ -NotLike "*CBS*" -AND
|
||||||
|
$_ -NotLike "*OOBENetworkCaptivePortal*" -AND
|
||||||
|
$_ -NotLike "*PeopleExperienceHost*" -AND
|
||||||
|
$_ -NotLike "*ParentalControls*" -AND
|
||||||
|
$_ -NotLike "*Win32WebViewHost*" -AND
|
||||||
|
$_ -NotLike "*InputApp*" -AND
|
||||||
|
$_ -NotLike "*AccountsControl*" -AND
|
||||||
|
$_ -NotLike "*AsyncTextService*" -AND
|
||||||
|
$_ -NotLike "*CapturePicker*" -AND
|
||||||
|
$_ -NotLike "*CredDialogHost*" -AND
|
||||||
|
$_ -NotLike "*BioEnrollMent*" -AND
|
||||||
|
$_ -NotLike "*ShellExperienceHost*" -AND
|
||||||
|
$_ -NotLike "*DesktopAppInstaller*" -AND
|
||||||
|
$_ -NotLike "*WebMediaExtensions*" -AND
|
||||||
|
$_ -NotLike "*WMIC*" -AND
|
||||||
|
$_ -NotLike "*UI.XaML*"
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($appx in $appxlist)
|
||||||
|
{
|
||||||
|
$status = "Removing $appx"
|
||||||
|
Write-Progress -Activity "Removing Apps" -Status $status -PercentComplete ($counter++/$appxlist.Count*100)
|
||||||
|
dism /image:$scratchDir /Remove-Package /PackageName:$appx /NoRestart
|
||||||
|
}
|
||||||
|
Write-Progress -Activity "Removing Apps" -Status "Ready" -Completed
|
||||||
|
}
|
||||||
|
|
||||||
|
function Remove-ProvisionedPackages
|
||||||
|
{
|
||||||
|
$appxProvisionedPackages = Get-AppxProvisionedPackage -Path "$($scratchDir)" | Where-Object {
|
||||||
|
$_.PackageName -NotLike "*AppInstaller*" -AND
|
||||||
|
$_.PackageName -NotLike "*Store*" -and
|
||||||
|
$_.PackageName -NotLike "*dism*" -and
|
||||||
|
$_.PackageName -NotLike "*Foundation*" -and
|
||||||
|
$_.PackageName -NotLike "*FodMetadata*" -and
|
||||||
|
$_.PackageName -NotLike "*LanguageFeatures*" -and
|
||||||
|
$_.PackageName -NotLike "*Notepad*" -and
|
||||||
|
$_.PackageName -NotLike "*Printing*" -and
|
||||||
|
$_.PackageName -NotLike "*Wifi*" -and
|
||||||
|
$_.PackageName -NotLike "*Foundation*"
|
||||||
|
}
|
||||||
|
|
||||||
|
$counter = 0
|
||||||
|
foreach ($appx in $appxProvisionedPackages)
|
||||||
|
{
|
||||||
|
$status = "Removing Provisioned $appx"
|
||||||
|
Write-Progress -Activity "Removing Provisioned Apps" -Status $status -PercentComplete ($counter++/$appxProvisionedPackages.Count*100)
|
||||||
|
dism /image:$scratchDir /Remove-ProvisionedAppxPackage /PackageName:$appx /NoRestart
|
||||||
|
|
||||||
|
}
|
||||||
|
Write-Progress -Activity "Removing Provisioned Apps" -Status "Ready" -Completed
|
||||||
|
}
|
||||||
|
|
||||||
|
function Copy-ToUSB([string] $fileToCopy)
|
||||||
|
{
|
||||||
|
foreach ($volume in Get-Volume) {
|
||||||
|
if ($volume -and $volume.FileSystemLabel -ieq "ventoy") {
|
||||||
|
$destinationPath = "$($volume.DriveLetter):\"
|
||||||
|
#Copy-Item -Path $fileToCopy -Destination $destinationPath -Force
|
||||||
|
# Get the total size of the file
|
||||||
|
$totalSize = (Get-Item $fileToCopy).length
|
||||||
|
|
||||||
|
Copy-Item -Path $fileToCopy -Destination $destinationPath -Verbose -Force -Recurse -Container -PassThru |
|
||||||
|
ForEach-Object {
|
||||||
|
# Calculate the percentage completed
|
||||||
|
$completed = ($_.BytesTransferred / $totalSize) * 100
|
||||||
|
|
||||||
|
# Display the progress bar
|
||||||
|
Write-Progress -Activity "Copying File" -Status "Progress" -PercentComplete $completed -CurrentOperation ("{0:N2} MB / {1:N2} MB" -f ($_.BytesTransferred / 1MB), ($totalSize / 1MB))
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "File copied to Ventoy drive $($volume.DriveLette)"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Write-Host "Ventoy USB Key is not inserted"
|
||||||
|
}
|
||||||
|
|
||||||
|
function Remove-FileOrDirectory([string] $pathToDelete, [string] $mask = "", [switch] $Directory = $false)
|
||||||
|
{
|
||||||
|
if(([string]::IsNullOrEmpty($pathToDelete))) { return }
|
||||||
|
if (-not (Test-Path -Path "$($pathToDelete)")) { return }
|
||||||
|
|
||||||
|
$yesNo = Get-LocalizedYesNo
|
||||||
|
|
||||||
|
# Specify the path to the directory
|
||||||
|
# $directoryPath = "$($scratchDir)\Windows\System32\LogFiles\WMI\RtBackup"
|
||||||
|
# takeown /a /r /d $yesNo[0] /f "$($directoryPath)" > $null
|
||||||
|
# icacls "$($directoryPath)" /q /c /t /reset > $null
|
||||||
|
# icacls $directoryPath /setowner "*S-1-5-32-544"
|
||||||
|
# icacls $directoryPath /grant "*S-1-5-32-544:(OI)(CI)F" /t /c /q
|
||||||
|
# Remove-Item -Path $directoryPath -Recurse -Force
|
||||||
|
|
||||||
|
# # Grant full control to BUILTIN\Administrators using icacls
|
||||||
|
# $directoryPath = "$($scratchDir)\Windows\System32\WebThreatDefSvc"
|
||||||
|
# takeown /a /r /d $yesNo[0] /f "$($directoryPath)" > $null
|
||||||
|
# icacls "$($directoryPath)" /q /c /t /reset > $null
|
||||||
|
# icacls $directoryPath /setowner "*S-1-5-32-544"
|
||||||
|
# icacls $directoryPath /grant "*S-1-5-32-544:(OI)(CI)F" /t /c /q
|
||||||
|
# Remove-Item -Path $directoryPath -Recurse -Force
|
||||||
|
|
||||||
|
$itemsToDelete = [System.Collections.ArrayList]::new()
|
||||||
|
|
||||||
|
if ($mask -eq "")
|
||||||
|
{
|
||||||
|
Write-Debug "Adding $($pathToDelete) to array."
|
||||||
|
[void]$itemsToDelete.Add($pathToDelete)
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Write-Debug "Adding $($pathToDelete) to array and mask is $($mask)"
|
||||||
|
if ($Directory) { $itemsToDelete = Get-ChildItem $pathToDelete -Include $mask -Recurse -Directory }
|
||||||
|
else { $itemsToDelete = Get-ChildItem $pathToDelete -Include $mask -Recurse }
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach($itemToDelete in $itemsToDelete)
|
||||||
|
{
|
||||||
|
$status = "Deleteing $($itemToDelete)"
|
||||||
|
Write-Progress -Activity "Removing Items" -Status $status -PercentComplete ($counter++/$itemsToDelete.Count*100)
|
||||||
|
|
||||||
|
if (Test-Path -Path "$($itemToDelete)" -PathType Container)
|
||||||
|
{
|
||||||
|
$status = "Deleting directory: $($itemToDelete)"
|
||||||
|
|
||||||
|
takeown /r /d $yesNo[0] /a /f "$($itemToDelete)"
|
||||||
|
icacls "$($itemToDelete)" /q /c /t /reset
|
||||||
|
icacls $itemToDelete /setowner "*S-1-5-32-544"
|
||||||
|
icacls $itemToDelete /grant "*S-1-5-32-544:(OI)(CI)F" /t /c /q
|
||||||
|
Remove-Item -Force -Recurse "$($itemToDelete)"
|
||||||
|
}
|
||||||
|
elseif (Test-Path -Path "$($itemToDelete)" -PathType Leaf)
|
||||||
|
{
|
||||||
|
$status = "Deleting file: $($itemToDelete)"
|
||||||
|
|
||||||
|
takeown /a /f "$($itemToDelete)"
|
||||||
|
icacls "$($itemToDelete)" /q /c /t /reset
|
||||||
|
icacls "$($itemToDelete)" /setowner "*S-1-5-32-544"
|
||||||
|
icacls "$($itemToDelete)" /grant "*S-1-5-32-544:(OI)(CI)F" /t /c /q
|
||||||
|
Remove-Item -Force "$($itemToDelete)"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Write-Progress -Activity "Removing Items" -Status "Ready" -Completed
|
||||||
|
}
|
||||||
|
|
||||||
|
function New-Unattend {
|
||||||
|
|
||||||
|
# later if we wont to remove even more bloat EU requires MS to remove everything from English(world)
|
||||||
|
# Below is an example how to do it we probably should create a drop down with common locals
|
||||||
|
# <settings pass="specialize">
|
||||||
|
# <!-- Specify English (World) locale -->
|
||||||
|
# <component name="Microsoft-Windows-International-Core" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
# <SetupUILanguage>
|
||||||
|
# <UILanguage>en-US</UILanguage>
|
||||||
|
# </SetupUILanguage>
|
||||||
|
# <InputLocale>en-US</InputLocale>
|
||||||
|
# <SystemLocale>en-US</SystemLocale>
|
||||||
|
# <UILanguage>en-US</UILanguage>
|
||||||
|
# <UserLocale>en-US</UserLocale>
|
||||||
|
# </component>
|
||||||
|
# </settings>
|
||||||
|
|
||||||
|
# <settings pass="oobeSystem">
|
||||||
|
# <!-- Specify English (World) locale -->
|
||||||
|
# <component name="Microsoft-Windows-International-Core" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
# <InputLocale>en-US</InputLocale>
|
||||||
|
# <SystemLocale>en-US</SystemLocale>
|
||||||
|
# <UILanguage>en-US</UILanguage>
|
||||||
|
# <UserLocale>en-US</UserLocale>
|
||||||
|
# </component>
|
||||||
|
# </settings>
|
||||||
|
# using here string to embedd unattend
|
||||||
|
# <RunSynchronousCommand wcm:action="add">
|
||||||
|
# <Order>1</Order>
|
||||||
|
# <Path>net user administrator /active:yes</Path>
|
||||||
|
# </RunSynchronousCommand>
|
||||||
|
|
||||||
|
$unattend = @'
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<unattend xmlns="urn:schemas-microsoft-com:unattend"
|
||||||
|
xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<settings pass="specialize">
|
||||||
|
<component name="Microsoft-Windows-SQMApi" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<CEIPEnabled>0</CEIPEnabled>
|
||||||
|
</component>
|
||||||
|
<component name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<ConfigureChatAutoInstall>false</ConfigureChatAutoInstall>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<settings pass="auditUser">
|
||||||
|
<component name="Microsoft-Windows-Deployment" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<RunSynchronous>
|
||||||
|
<RunSynchronousCommand wcm:action="add">
|
||||||
|
<Order>1</Order>
|
||||||
|
<CommandLine>CMD /C echo LAU GG>C:\Windows\LogAuditUser.txt</CommandLine>
|
||||||
|
<Description>StartMenu</Description>
|
||||||
|
</RunSynchronousCommand>
|
||||||
|
</RunSynchronous>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
<settings pass="oobeSystem">
|
||||||
|
<component name="Microsoft-Windows-Shell-Setup" processorArchitecture="amd64" publicKeyToken="31bf3856ad364e35" language="neutral" versionScope="nonSxS" xmlns:wcm="http://schemas.microsoft.com/WMIConfig/2002/State" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
|
||||||
|
<OOBE>
|
||||||
|
<HideOEMRegistrationScreen>true</HideOEMRegistrationScreen>
|
||||||
|
<SkipUserOOBE>false</SkipUserOOBE>
|
||||||
|
<SkipMachineOOBE>false</SkipMachineOOBE>
|
||||||
|
<HideOnlineAccountScreens>true</HideOnlineAccountScreens>
|
||||||
|
<HideWirelessSetupInOOBE>true</HideWirelessSetupInOOBE>
|
||||||
|
<HideEULAPage>true</HideEULAPage>
|
||||||
|
<ProtectYourPC>3</ProtectYourPC>
|
||||||
|
</OOBE>
|
||||||
|
<FirstLogonCommands>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<Order>1</Order>
|
||||||
|
<CommandLine>cmd.exe /c echo 23>c:\windows\csup.txt</CommandLine>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<Order>2</Order>
|
||||||
|
<CommandLine>CMD /C echo GG>C:\Windows\LogOobeSystem.txt</CommandLine>
|
||||||
|
</SynchronousCommand>
|
||||||
|
<SynchronousCommand wcm:action="add">
|
||||||
|
<Order>3</Order>
|
||||||
|
<CommandLine>powershell -ExecutionPolicy Bypass -File c:\windows\FirstStartup.ps1</CommandLine>
|
||||||
|
</SynchronousCommand>
|
||||||
|
</FirstLogonCommands>
|
||||||
|
</component>
|
||||||
|
</settings>
|
||||||
|
</unattend>
|
||||||
|
'@
|
||||||
|
$unattend | Out-File -FilePath "$env:temp\unattend.xml" -Force
|
||||||
|
}
|
||||||
|
|
||||||
|
function New-CheckInstall {
|
||||||
|
|
||||||
|
# using here string to embedd firstrun
|
||||||
|
$checkInstall = @'
|
||||||
|
@echo off
|
||||||
|
if exist "C:\windows\cpu.txt" (
|
||||||
|
echo C:\windows\cpu.txt exists
|
||||||
|
) else (
|
||||||
|
echo C:\windows\cpu.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\windows\SerialNumber.txt" (
|
||||||
|
echo C:\windows\SerialNumber.txt exists
|
||||||
|
) else (
|
||||||
|
echo C:\windows\SerialNumber.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\unattend.xml" (
|
||||||
|
echo C:\unattend.xml exists
|
||||||
|
) else (
|
||||||
|
echo C:\unattend.xml does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\Setup\Scripts\SetupComplete.cmd" (
|
||||||
|
echo C:\Windows\Setup\Scripts\SetupComplete.cmd exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\Setup\Scripts\SetupComplete.cmd does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\Panther\unattend.xml" (
|
||||||
|
echo C:\Windows\Panther\unattend.xml exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\Panther\unattend.xml does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\System32\Sysprep\unattend.xml" (
|
||||||
|
echo C:\Windows\System32\Sysprep\unattend.xml exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\System32\Sysprep\unattend.xml does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\FirstStartup.ps1" (
|
||||||
|
echo C:\Windows\FirstStartup.ps1 exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\FirstStartup.ps1 does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\winutil.ps1" (
|
||||||
|
echo C:\Windows\winutil.ps1 exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\winutil.ps1 does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\LogSpecialize.txt" (
|
||||||
|
echo C:\Windows\LogSpecialize.txt exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\LogSpecialize.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\LogAuditUser.txt" (
|
||||||
|
echo C:\Windows\LogAuditUser.txt exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\LogAuditUser.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "C:\Windows\LogOobeSystem.txt" (
|
||||||
|
echo C:\Windows\LogOobeSystem.txt exists
|
||||||
|
) else (
|
||||||
|
echo C:\Windows\LogOobeSystem.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "c:\windows\csup.txt" (
|
||||||
|
echo c:\windows\csup.txt exists
|
||||||
|
) else (
|
||||||
|
echo c:\windows\csup.txt does not exist
|
||||||
|
)
|
||||||
|
if exist "c:\windows\LogFirstRun.txt" (
|
||||||
|
echo c:\windows\LogFirstRun.txt exists
|
||||||
|
) else (
|
||||||
|
echo c:\windows\LogFirstRun.txt does not exist
|
||||||
|
)
|
||||||
|
'@
|
||||||
|
$checkInstall | Out-File -FilePath "$env:temp\checkinstall.cmd" -Force -Encoding Ascii
|
||||||
|
}
|
||||||
|
|
||||||
|
function New-FirstRun {
|
||||||
|
|
||||||
|
# using here string to embedd firstrun
|
||||||
|
$firstRun = @'
|
||||||
|
# Set the global error action preference to continue
|
||||||
|
$ErrorActionPreference = "Continue"
|
||||||
|
function Remove-RegistryValue
|
||||||
|
{
|
||||||
|
param (
|
||||||
|
[Parameter(Mandatory = $true)]
|
||||||
|
[string]$RegistryPath,
|
||||||
|
|
||||||
|
[Parameter(Mandatory = $true)]
|
||||||
|
[string]$ValueName
|
||||||
|
)
|
||||||
|
|
||||||
|
# Check if the registry path exists
|
||||||
|
if (Test-Path -Path $RegistryPath)
|
||||||
|
{
|
||||||
|
$registryValue = Get-ItemProperty -Path $RegistryPath -Name $ValueName -ErrorAction SilentlyContinue
|
||||||
|
|
||||||
|
# Check if the registry value exists
|
||||||
|
if ($registryValue)
|
||||||
|
{
|
||||||
|
# Remove the registry value
|
||||||
|
Remove-ItemProperty -Path $RegistryPath -Name $ValueName -Force
|
||||||
|
Write-Host "Registry value '$ValueName' removed from '$RegistryPath'."
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Write-Host "Registry value '$ValueName' not found in '$RegistryPath'."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Write-Host "Registry path '$RegistryPath' not found."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function Stop-UnnecessaryServices
|
||||||
|
{
|
||||||
|
$servicesAuto = @"
|
||||||
|
"AudioSrv",
|
||||||
|
"AudioEndpointBuilder",
|
||||||
|
"BFE",
|
||||||
|
"BITS",
|
||||||
|
"BrokerInfrastructure",
|
||||||
|
"CDPSvc",
|
||||||
|
"CDPUserSvc_dc2a4",
|
||||||
|
"CoreMessagingRegistrar",
|
||||||
|
"CryptSvc",
|
||||||
|
"DPS",
|
||||||
|
"DcomLaunch",
|
||||||
|
"Dhcp",
|
||||||
|
"DispBrokerDesktopSvc",
|
||||||
|
"Dnscache",
|
||||||
|
"DoSvc",
|
||||||
|
"DusmSvc",
|
||||||
|
"EventLog",
|
||||||
|
"EventSystem",
|
||||||
|
"FontCache",
|
||||||
|
"LSM",
|
||||||
|
"LanmanServer",
|
||||||
|
"LanmanWorkstation",
|
||||||
|
"MapsBroker",
|
||||||
|
"MpsSvc",
|
||||||
|
"OneSyncSvc_dc2a4",
|
||||||
|
"Power",
|
||||||
|
"ProfSvc",
|
||||||
|
"RpcEptMapper",
|
||||||
|
"RpcSs",
|
||||||
|
"SCardSvr",
|
||||||
|
"SENS",
|
||||||
|
"SamSs",
|
||||||
|
"Schedule",
|
||||||
|
"SgrmBroker",
|
||||||
|
"ShellHWDetection",
|
||||||
|
"Spooler",
|
||||||
|
"SysMain",
|
||||||
|
"SystemEventsBroker",
|
||||||
|
"TextInputManagementService",
|
||||||
|
"Themes",
|
||||||
|
"TrkWks",
|
||||||
|
"UserManager",
|
||||||
|
"VGAuthService",
|
||||||
|
"VMTools",
|
||||||
|
"WSearch",
|
||||||
|
"Wcmsvc",
|
||||||
|
"WinDefend",
|
||||||
|
"Winmgmt",
|
||||||
|
"WlanSvc",
|
||||||
|
"WpnService",
|
||||||
|
"WpnUserService_dc2a4",
|
||||||
|
"cbdhsvc_dc2a4",
|
||||||
|
"edgeupdate",
|
||||||
|
"gpsvc",
|
||||||
|
"iphlpsvc",
|
||||||
|
"mpssvc",
|
||||||
|
"nsi",
|
||||||
|
"sppsvc",
|
||||||
|
"tiledatamodelsvc",
|
||||||
|
"vm3dservice",
|
||||||
|
"webthreatdefusersvc_dc2a4",
|
||||||
|
"wscsvc"
|
||||||
|
"@
|
||||||
|
|
||||||
|
$allServices = Get-Service | Where-Object { $_.StartType -eq "Automatic" -and $servicesAuto -NotContains $_.Name}
|
||||||
|
foreach($service in $allServices)
|
||||||
|
{
|
||||||
|
Stop-Service -Name $service.Name -PassThru
|
||||||
|
Set-Service $service.Name -StartupType Manual
|
||||||
|
"Stopping service $($service.Name)" | Out-File -FilePath c:\windows\LogFirstRun.txt -Append -NoClobber
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
"FirstStartup has worked" | Out-File -FilePath c:\windows\LogFirstRun.txt -Append -NoClobber
|
||||||
|
|
||||||
|
$Theme = "HKCU:\SOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize"
|
||||||
|
Set-ItemProperty -Path $Theme -Name AppsUseLightTheme -Value 1
|
||||||
|
Set-ItemProperty -Path $Theme -Name SystemUsesLightTheme -Value 1
|
||||||
|
|
||||||
|
# figure this out later how to set updates to security only
|
||||||
|
#Import-Module -Name PSWindowsUpdate;
|
||||||
|
#Stop-Service -Name wuauserv
|
||||||
|
#Set-WUSettings -MicrosoftUpdateEnabled -AutoUpdateOption 'Never'
|
||||||
|
#Start-Service -Name wuauserv
|
||||||
|
|
||||||
|
Stop-UnnecessaryServices
|
||||||
|
|
||||||
|
$taskbarPath = "$env:AppData\Microsoft\Internet Explorer\Quick Launch\User Pinned\TaskBar"
|
||||||
|
# Delete all files on the Taskbar
|
||||||
|
Get-ChildItem -Path $taskbarPath -File | Remove-Item -Force
|
||||||
|
Remove-RegistryValue -RegistryPath "HKCU:\Software\Microsoft\Windows\CurrentVersion\Explorer\Taskband" -ValueName "FavoritesRemovedChanges"
|
||||||
|
Remove-RegistryValue -RegistryPath "HKCU:\Software\Microsoft\Windows\CurrentVersion\Explorer\Taskband" -ValueName "FavoritesChanges"
|
||||||
|
Remove-RegistryValue -RegistryPath "HKCU:\Software\Microsoft\Windows\CurrentVersion\Explorer\Taskband" -ValueName "Favorites"
|
||||||
|
|
||||||
|
# Stop-Process -Name explorer -Force
|
||||||
|
|
||||||
|
$process = Get-Process -Name "explorer"
|
||||||
|
Stop-Process -InputObject $process
|
||||||
|
# Wait for the process to exit
|
||||||
|
Wait-Process -InputObject $process
|
||||||
|
Start-Sleep -Seconds 3
|
||||||
|
|
||||||
|
# Delete Edge Icon from the desktop
|
||||||
|
$edgeShortcutFiles = Get-ChildItem -Path $desktopPath -Filter "*Edge*.lnk"
|
||||||
|
# Check if Edge shortcuts exist on the desktop
|
||||||
|
if ($edgeShortcutFiles)
|
||||||
|
{
|
||||||
|
foreach ($shortcutFile in $edgeShortcutFiles)
|
||||||
|
{
|
||||||
|
# Remove each Edge shortcut
|
||||||
|
Remove-Item -Path $shortcutFile.FullName -Force
|
||||||
|
Write-Host "Edge shortcut '$($shortcutFile.Name)' removed from the desktop."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Remove-Item -Path "$env:USERPROFILE\Desktop\*.lnk"
|
||||||
|
Remove-Item -Path "C:\Users\Default\Desktop\*.lnk"
|
||||||
|
|
||||||
|
# ************************************************
|
||||||
|
# Create WinUtil shortcut on the desktop
|
||||||
|
#
|
||||||
|
$desktopPath = "$($env:USERPROFILE)\Desktop"
|
||||||
|
# Specify the target PowerShell command
|
||||||
|
$command = "powershell.exe -NoProfile -ExecutionPolicy Bypass -Command 'irm https://christitus.com/win | iex'"
|
||||||
|
# Specify the path for the shortcut
|
||||||
|
$shortcutPath = Join-Path $desktopPath 'winutil.lnk'
|
||||||
|
# Create a shell object
|
||||||
|
$shell = New-Object -ComObject WScript.Shell
|
||||||
|
|
||||||
|
# Create a shortcut object
|
||||||
|
$shortcut = $shell.CreateShortcut($shortcutPath)
|
||||||
|
|
||||||
|
if (Test-Path -Path "c:\Windows\cttlogo.png")
|
||||||
|
{
|
||||||
|
$shortcut.IconLocation = "c:\Windows\cttlogo.png"
|
||||||
|
}
|
||||||
|
|
||||||
|
# Set properties of the shortcut
|
||||||
|
$shortcut.TargetPath = "powershell.exe"
|
||||||
|
$shortcut.Arguments = "-NoProfile -ExecutionPolicy Bypass -Command `"$command`""
|
||||||
|
# Save the shortcut
|
||||||
|
$shortcut.Save()
|
||||||
|
Write-Host "Shortcut created at: $shortcutPath"
|
||||||
|
#
|
||||||
|
# Done create WinUtil shortcut on the desktop
|
||||||
|
# ************************************************
|
||||||
|
|
||||||
|
Start-Process explorer
|
||||||
|
|
||||||
|
'@
|
||||||
|
$firstRun | Out-File -FilePath "$env:temp\FirstStartup.ps1" -Force
|
||||||
|
}
|
@ -15,16 +15,16 @@ function Remove-WinUtilAPPX {
|
|||||||
$Name
|
$Name
|
||||||
)
|
)
|
||||||
|
|
||||||
Try{
|
Try {
|
||||||
Write-Host "Removing $Name"
|
Write-Host "Removing $Name"
|
||||||
Get-AppxPackage "*$Name*" | Remove-AppxPackage -ErrorAction SilentlyContinue
|
Get-AppxPackage "*$Name*" | Remove-AppxPackage -ErrorAction SilentlyContinue
|
||||||
Get-AppxProvisionedPackage -Online | Where-Object DisplayName -like "*$Name*" | Remove-AppxProvisionedPackage -Online -ErrorAction SilentlyContinue
|
Get-AppxProvisionedPackage -Online | Where-Object DisplayName -like "*$Name*" | Remove-AppxProvisionedPackage -Online -ErrorAction SilentlyContinue
|
||||||
}
|
}
|
||||||
Catch [System.Exception] {
|
Catch [System.Exception] {
|
||||||
if($psitem.Exception.Message -like "*The requested operation requires elevation*"){
|
if ($psitem.Exception.Message -like "*The requested operation requires elevation*") {
|
||||||
Write-Warning "Unable to uninstall $name due to a Security Exception"
|
Write-Warning "Unable to uninstall $name due to a Security Exception"
|
||||||
}
|
}
|
||||||
Else{
|
else {
|
||||||
Write-Warning "Unable to uninstall $name due to unhandled exception"
|
Write-Warning "Unable to uninstall $name due to unhandled exception"
|
||||||
Write-Warning $psitem.Exception.StackTrace
|
Write-Warning $psitem.Exception.StackTrace
|
||||||
}
|
}
|
||||||
|
@ -46,11 +46,14 @@ function Invoke-WPFButton {
|
|||||||
"WPFPaneluser" {Invoke-WPFControlPanel -Panel $button}
|
"WPFPaneluser" {Invoke-WPFControlPanel -Panel $button}
|
||||||
"WPFUpdatesdefault" {Invoke-WPFUpdatesdefault}
|
"WPFUpdatesdefault" {Invoke-WPFUpdatesdefault}
|
||||||
"WPFFixesUpdate" {Invoke-WPFFixesUpdate}
|
"WPFFixesUpdate" {Invoke-WPFFixesUpdate}
|
||||||
|
"WPFFixesWinget" {Invoke-WPFFixesWinget}
|
||||||
"WPFFixesNetwork" {Invoke-WPFFixesNetwork}
|
"WPFFixesNetwork" {Invoke-WPFFixesNetwork}
|
||||||
"WPFUpdatesdisable" {Invoke-WPFUpdatesdisable}
|
"WPFUpdatesdisable" {Invoke-WPFUpdatesdisable}
|
||||||
"WPFUpdatessecurity" {Invoke-WPFUpdatessecurity}
|
"WPFUpdatessecurity" {Invoke-WPFUpdatessecurity}
|
||||||
"WPFWinUtilShortcut" {Invoke-WPFShortcut -ShortcutToAdd "WinUtil"}
|
"WPFWinUtilShortcut" {Invoke-WPFShortcut -ShortcutToAdd "WinUtil"}
|
||||||
"WPFGetInstalled" {Invoke-WPFGetInstalled -CheckBox "winget"}
|
"WPFGetInstalled" {Invoke-WPFGetInstalled -CheckBox "winget"}
|
||||||
"WPFGetInstalledTweaks" {Invoke-WPFGetInstalled -CheckBox "tweaks"}
|
"WPFGetInstalledTweaks" {Invoke-WPFGetInstalled -CheckBox "tweaks"}
|
||||||
|
"WPFGetIso" {Invoke-WPFGetIso}
|
||||||
|
"WPFMicrowin" {Invoke-WPFMicrowin}
|
||||||
}
|
}
|
||||||
}
|
}
|
13
functions/public/Invoke-WPFFixesWinget.ps1
Normal file
13
functions/public/Invoke-WPFFixesWinget.ps1
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
function Invoke-WPFFixesWinget {
|
||||||
|
|
||||||
|
<#
|
||||||
|
|
||||||
|
.SYNOPSIS
|
||||||
|
Fixes Winget by running choco install winget
|
||||||
|
.DESCRIPTION
|
||||||
|
BravoNorris for the fantastic idea of a button to reinstall winget
|
||||||
|
#>
|
||||||
|
|
||||||
|
Start-Process -FilePath "choco" -ArgumentList "install winget -y" -NoNewWindow -Wait
|
||||||
|
|
||||||
|
}
|
@ -29,7 +29,6 @@ Function Invoke-WPFFormVariables {
|
|||||||
Write-Host "====Chris Titus Tech====="
|
Write-Host "====Chris Titus Tech====="
|
||||||
Write-Host "=====Windows Toolbox====="
|
Write-Host "=====Windows Toolbox====="
|
||||||
|
|
||||||
|
|
||||||
#====DEBUG GUI Elements====
|
#====DEBUG GUI Elements====
|
||||||
|
|
||||||
#Write-Host "Found the following interactable elements from our form" -ForegroundColor Cyan
|
#Write-Host "Found the following interactable elements from our form" -ForegroundColor Cyan
|
||||||
|
125
functions/public/Invoke-WPFGetIso.ps1
Normal file
125
functions/public/Invoke-WPFGetIso.ps1
Normal file
@ -0,0 +1,125 @@
|
|||||||
|
function Invoke-WPFGetIso {
|
||||||
|
<#
|
||||||
|
.DESCRIPTION
|
||||||
|
Function to get the path to Iso file for MicroWin, unpack that isom=, read basic information and populate the UI Options
|
||||||
|
#>
|
||||||
|
|
||||||
|
Write-Host "Invoking WPFGetIso"
|
||||||
|
|
||||||
|
if($sync.ProcessRunning){
|
||||||
|
$msg = "GetIso process is currently running."
|
||||||
|
[System.Windows.MessageBox]::Show($msg, "Winutil", [System.Windows.MessageBoxButton]::OK, [System.Windows.MessageBoxImage]::Warning)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host " _ __ __ _ "
|
||||||
|
Write-Host " /\/\ (_) ___ _ __ ___ / / /\ \ \(_) _ __ "
|
||||||
|
Write-Host " / \ | | / __|| '__| / _ \ \ \/ \/ /| || '_ \ "
|
||||||
|
Write-Host "/ /\/\ \| || (__ | | | (_) | \ /\ / | || | | | "
|
||||||
|
Write-Host "\/ \/|_| \___||_| \___/ \/ \/ |_||_| |_| "
|
||||||
|
|
||||||
|
$oscdImgFound = [bool] (Get-Command -ErrorAction Ignore -Type Application oscdimg)
|
||||||
|
Write-Host "oscdimge.exe on system: $oscdImgFound"
|
||||||
|
|
||||||
|
if (!$oscdImgFound)
|
||||||
|
{
|
||||||
|
[System.Windows.MessageBox]::Show("oscdimge.exe is not found on the system, you need to download it first before running this function!")
|
||||||
|
|
||||||
|
# the step below needs choco to download oscdimg
|
||||||
|
$chocoFound = [bool] (Get-Command -ErrorAction Ignore -Type Application choco)
|
||||||
|
Write-Host "choco on system: $oscdImgFound"
|
||||||
|
if (!$chocoFound)
|
||||||
|
{
|
||||||
|
[System.Windows.MessageBox]::Show("choco.exe is not found on the system, you need choco to download oscdimg.exe")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
Start-Process -Verb runas -FilePath powershell.exe -ArgumentList "choco install windows-adk-oscdimg"
|
||||||
|
[System.Windows.MessageBox]::Show("oscdimg is installed, now close, reopen PowerShell terminal and re-launch winutil.ps1 !!!")
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
[System.Reflection.Assembly]::LoadWithPartialName("System.windows.forms") | Out-Null
|
||||||
|
$openFileDialog = New-Object System.Windows.Forms.OpenFileDialog
|
||||||
|
$openFileDialog.initialDirectory = $initialDirectory
|
||||||
|
$openFileDialog.filter = "ISO files (*.iso)| *.iso"
|
||||||
|
$openFileDialog.ShowDialog() | Out-Null
|
||||||
|
$filePath = $openFileDialog.FileName
|
||||||
|
|
||||||
|
if ([string]::IsNullOrEmpty($filePath))
|
||||||
|
{
|
||||||
|
Write-Host "No ISO is chosen"
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "File path $($filePath)"
|
||||||
|
if (-not (Test-Path -Path $filePath -PathType Leaf))
|
||||||
|
{
|
||||||
|
$msg = "File you've chosen doesn't exist"
|
||||||
|
[System.Windows.MessageBox]::Show($msg, "Winutil", [System.Windows.MessageBoxButton]::OK, [System.Windows.MessageBoxImage]::Error)
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "Mounting Iso. Please wait."
|
||||||
|
$mountedISO = Mount-DiskImage -PassThru "$filePath"
|
||||||
|
Write-Host "Done mounting Iso $mountedISO"
|
||||||
|
$driveLetter = (Get-Volume -DiskImage $mountedISO).DriveLetter
|
||||||
|
Write-Host "Iso mounted to '$driveLetter'"
|
||||||
|
# storing off values in hidden fields for further steps
|
||||||
|
# there is probably a better way of doing this, I don't have time to figure this out
|
||||||
|
$sync.MicrowinIsoDrive.Text = $driveLetter
|
||||||
|
|
||||||
|
Write-Host "Setting up mount dir and scratch dirs"
|
||||||
|
$mountDir = "c:\microwin"
|
||||||
|
$scratchDir = "c:\microwinscratch"
|
||||||
|
$sync.MicrowinMountDir.Text = $mountDir
|
||||||
|
$sync.MicrowinScratchDir.Text = $scratchDir
|
||||||
|
Write-Host "Done setting up mount dir and scratch dirs"
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
$data = @($driveLetter, $filePath)
|
||||||
|
New-Item -ItemType Directory -Force -Path "$($mountDir)" | Out-Null
|
||||||
|
New-Item -ItemType Directory -Force -Path "$($scratchDir)" | Out-Null
|
||||||
|
Write-Host "Copying Windows image. This will take awhile, please don't use UI or cancel this step!"
|
||||||
|
|
||||||
|
# xcopy we can verify files and also not copy files that already exist, but hard to measure
|
||||||
|
# xcopy.exe /E /I /H /R /Y /J $DriveLetter":" $mountDir >$null
|
||||||
|
$totalTime = Measure-Command { Copy-Files "$($driveLetter):" $mountDir -Recurse -Force }
|
||||||
|
Write-Host "Copy complete! Total Time: $($totalTime.Minutes)m$($totalTime.Seconds)s"
|
||||||
|
|
||||||
|
$wimFile = "$mountDir\sources\install.wim"
|
||||||
|
Write-Host "Getting image information $wimFile"
|
||||||
|
|
||||||
|
if (-not (Test-Path -Path $wimFile -PathType Leaf))
|
||||||
|
{
|
||||||
|
$msg = "install wim file doesn't exist in the image, are you sure you used Windows image??"
|
||||||
|
[System.Windows.MessageBox]::Show($msg, "Winutil", [System.Windows.MessageBoxButton]::OK, [System.Windows.MessageBoxImage]::Error)
|
||||||
|
throw
|
||||||
|
}
|
||||||
|
Get-WindowsImage -ImagePath $wimFile | ForEach-Object {
|
||||||
|
$imageIdx = $_.ImageIndex
|
||||||
|
$imageName = $_.ImageName
|
||||||
|
$sync.MicrowinWindowsFlavors.Items.Add("$imageIdx : $imageName")
|
||||||
|
}
|
||||||
|
$sync.MicrowinWindowsFlavors.SelectedIndex = 0
|
||||||
|
Get-Volume $driveLetter | Get-DiskImage | Dismount-DiskImage
|
||||||
|
Write-Host "Selected value '$($sync.MicrowinWindowsFlavors.SelectedValue)'....."
|
||||||
|
|
||||||
|
$sync.MicrowinOptionsPanel.Visibility = 'Visible'
|
||||||
|
} catch {
|
||||||
|
Write-Host "Dismounting bad image..."
|
||||||
|
Get-Volume $driveLetter | Get-DiskImage | Dismount-DiskImage
|
||||||
|
Remove-Item -Recurse -Force "$($scratchDir)"
|
||||||
|
Remove-Item -Recurse -Force "$($mountDir)"
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "Done reading and unpacking ISO"
|
||||||
|
Write-Host ""
|
||||||
|
Write-Host "*********************************"
|
||||||
|
Write-Host "Check the UI for further steps!!!"
|
||||||
|
|
||||||
|
$sync.ProcessRunning = $false
|
||||||
|
}
|
||||||
|
|
||||||
|
|
335
functions/public/Invoke-WPFMicrowin.ps1
Normal file
335
functions/public/Invoke-WPFMicrowin.ps1
Normal file
@ -0,0 +1,335 @@
|
|||||||
|
function Invoke-WPFMicrowin {
|
||||||
|
<#
|
||||||
|
.DESCRIPTION
|
||||||
|
Invoke MicroWin routines...
|
||||||
|
#>
|
||||||
|
|
||||||
|
if($sync.ProcessRunning) {
|
||||||
|
$msg = "GetIso process is currently running."
|
||||||
|
[System.Windows.MessageBox]::Show($msg, "Winutil", [System.Windows.MessageBoxButton]::OK, [System.Windows.MessageBoxImage]::Warning)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
$index = $sync.MicrowinWindowsFlavors.SelectedValue.Split(":")[0].Trim()
|
||||||
|
Write-Host "Index chosen: '$index' from $($sync.MicrowinWindowsFlavors.SelectedValue)"
|
||||||
|
|
||||||
|
$keepPackages = $sync.WPFMicrowinKeepProvisionedPackages.IsChecked
|
||||||
|
$keepProvisionedPackages = $sync.WPFMicrowinKeepAppxPackages.IsChecked
|
||||||
|
$keepDefender = $sync.WPFMicrowinKeepDefender.IsChecked
|
||||||
|
$keepEdge = $sync.WPFMicrowinKeepEdge.IsChecked
|
||||||
|
$copyToUSB = $sync.WPFMicrowinCopyToUsb.IsChecked
|
||||||
|
$injectDrivers = $sync.MicrowinInjectDrivers.IsChecked
|
||||||
|
|
||||||
|
$mountDir = $sync.MicrowinMountDir.Text
|
||||||
|
$scratchDir = $sync.MicrowinScratchDir.Text
|
||||||
|
|
||||||
|
$mountDirExists = Test-Path $mountDir
|
||||||
|
$scratchDirExists = Test-Path $scratchDir
|
||||||
|
if (-not $mountDirExists -or -not $scratchDirExists)
|
||||||
|
{
|
||||||
|
Write-Error "Required directories '$mountDirExists' '$scratchDirExists' and do not exist."
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
Write-Host "Mounting Windows image. This may take a while."
|
||||||
|
dism /mount-image /imagefile:$mountDir\sources\install.wim /index:$index /mountdir:$scratchDir
|
||||||
|
Write-Host "Mounting complete! Performing removal of applications..."
|
||||||
|
|
||||||
|
if ($injectDrivers)
|
||||||
|
{
|
||||||
|
$driverPath = $sync.MicrowinDriverLocation.Text
|
||||||
|
if (Test-Path $driverPath)
|
||||||
|
{
|
||||||
|
Write-Host "Adding Windows Drivers image($scratchDir) drivers($driverPath) "
|
||||||
|
dism /image:$scratchDir /add-driver /driver:$driverPath /recurse | Out-Host
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Write-Host "Path to drivers is invalid continuing without driver injection"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host "Remove Features from the image"
|
||||||
|
Remove-Features -keepDefender:$keepDefender
|
||||||
|
Write-Host "Removing features complete!"
|
||||||
|
|
||||||
|
Write-Host "Removing Appx Bloat"
|
||||||
|
if (!$keepPackages)
|
||||||
|
{
|
||||||
|
Remove-Packages
|
||||||
|
}
|
||||||
|
if (!$keepProvisionedPackages)
|
||||||
|
{
|
||||||
|
Remove-ProvisionedPackages
|
||||||
|
}
|
||||||
|
|
||||||
|
# special code, for some reason when you try to delete some inbox apps
|
||||||
|
# we have to get and delete log files directory.
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\LogFiles\WMI\RtBackup" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\WebThreatDefSvc" -Directory
|
||||||
|
|
||||||
|
# Defender is hidden in 2 places we removed a feature above now need to remove it from the disk
|
||||||
|
if (!$keepDefender)
|
||||||
|
{
|
||||||
|
Write-Host "Removing Defender"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Windows Defender" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Windows Defender"
|
||||||
|
}
|
||||||
|
if (!$keepEdge)
|
||||||
|
{
|
||||||
|
Write-Host "Removing Edge"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Microsoft" -mask "*edge*" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Microsoft" -mask "*edge*" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\SystemApps" -mask "*edge*" -Directory
|
||||||
|
}
|
||||||
|
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\DiagTrack" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\InboxApps" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\SecurityHealthSystray.exe"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\LocationNotificationWindows.exe"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Windows Photo Viewer" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Windows Photo Viewer" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Windows Media Player" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Windows Media Player" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Windows Mail" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Windows Mail" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files (x86)\Internet Explorer" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Program Files\Internet Explorer" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\GameBarPresenceWriter"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\OneDriveSetup.exe"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\System32\OneDrive.ico"
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\SystemApps" -mask "*Windows.Search*" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\SystemApps" -mask "*narratorquickstart*" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\SystemApps" -mask "*Xbox*" -Directory
|
||||||
|
Remove-FileOrDirectory -pathToDelete "$($scratchDir)\Windows\SystemApps" -mask "*ParentalControls*" -Directory
|
||||||
|
Write-Host "Removal complete!"
|
||||||
|
|
||||||
|
# *************************** Automation black ***************************
|
||||||
|
# this doesn't work for some reason, this script is not being run at the end of the install
|
||||||
|
# if someone knows how to fix this, feel free to modify
|
||||||
|
New-Item -ItemType Directory -Force -Path $scratchDir\Windows\Setup\Scripts\
|
||||||
|
"wmic cpu get Name > C:\windows\cpu.txt" | Out-File -FilePath "$($scratchDir)\Windows\Setup\Scripts\SetupComplete.cmd" -NoClobber -Append
|
||||||
|
"wmic bios get serialnumber > C:\windows\SerialNumber.txt" | Out-File -FilePath "$($scratchDir)\Windows\Setup\Scripts\SetupComplete.cmd" -NoClobber -Append
|
||||||
|
"devmgmt.msc /s" | Out-File -FilePath "$($scratchDir)\Windows\Setup\Scripts\SetupComplete.cmd" -NoClobber -Append
|
||||||
|
|
||||||
|
Write-Host "Create unattend.xml"
|
||||||
|
New-Unattend
|
||||||
|
Write-Host "Done Create unattend.xml"
|
||||||
|
Write-Host "Copy unattend.xml file into the ISO"
|
||||||
|
New-Item -ItemType Directory -Force -Path "$($scratchDir)\Windows\Panther"
|
||||||
|
Copy-Item "$env:temp\unattend.xml" "$($scratchDir)\Windows\Panther\unattend.xml" -force
|
||||||
|
New-Item -ItemType Directory -Force -Path "$($scratchDir)\Windows\System32\Sysprep"
|
||||||
|
Copy-Item "$env:temp\unattend.xml" "$($scratchDir)\Windows\System32\Sysprep\unattend.xml" -force
|
||||||
|
Copy-Item "$env:temp\unattend.xml" "$($scratchDir)\unattend.xml" -force
|
||||||
|
Write-Host "Done Copy unattend.xml"
|
||||||
|
|
||||||
|
Write-Host "Create FirstRun"
|
||||||
|
New-FirstRun
|
||||||
|
Write-Host "Done create FirstRun"
|
||||||
|
Write-Host "Copy FirstRun.ps1 into the ISO"
|
||||||
|
Copy-Item "$env:temp\FirstStartup.ps1" "$($scratchDir)\Windows\FirstStartup.ps1" -force
|
||||||
|
Write-Host "Done copy FirstRun.ps1"
|
||||||
|
|
||||||
|
Write-Host "Copy link to winutil.ps1 into the ISO"
|
||||||
|
$desktopDir = "$($scratchDir)\Windows\Users\Default\Desktop"
|
||||||
|
New-Item -ItemType Directory -Force -Path "$desktopDir"
|
||||||
|
dism /image:$($scratchDir) /set-profilepath:"$($scratchDir)\Windows\Users\Default"
|
||||||
|
$command = "powershell.exe -NoProfile -ExecutionPolicy Bypass -Command 'irm https://christitus.com/win | iex'"
|
||||||
|
$shortcutPath = "$desktopDir\WinUtil.lnk"
|
||||||
|
$shell = New-Object -ComObject WScript.Shell
|
||||||
|
$shortcut = $shell.CreateShortcut($shortcutPath)
|
||||||
|
|
||||||
|
if (Test-Path -Path "$env:TEMP\cttlogo.png")
|
||||||
|
{
|
||||||
|
$pngPath = "$env:TEMP\cttlogo.png"
|
||||||
|
$icoPath = "$env:TEMP\cttlogo.ico"
|
||||||
|
Add-Type -AssemblyName System.Drawing
|
||||||
|
$pngImage = [System.Drawing.Image]::FromFile($pngPath)
|
||||||
|
$pngImage.Save($icoPath, [System.Drawing.Imaging.ImageFormat]::Icon)
|
||||||
|
Write-Host "ICO file created at: $icoPath"
|
||||||
|
Copy-Item "$env:TEMP\cttlogo.png" "$($scratchDir)\Windows\cttlogo.png" -force
|
||||||
|
Copy-Item "$env:TEMP\cttlogo.ico" "$($scratchDir)\cttlogo.ico" -force
|
||||||
|
$shortcut.IconLocation = "c:\cttlogo.ico"
|
||||||
|
}
|
||||||
|
|
||||||
|
$shortcut.TargetPath = "powershell.exe"
|
||||||
|
$shortcut.Arguments = "-NoProfile -ExecutionPolicy Bypass -Command `"$command`""
|
||||||
|
$shortcut.Save()
|
||||||
|
Write-Host "Shortcut to winutil created at: $shortcutPath"
|
||||||
|
# *************************** Automation black ***************************
|
||||||
|
|
||||||
|
Write-Host "Copy checkinstall.cmd into the ISO"
|
||||||
|
New-CheckInstall
|
||||||
|
Copy-Item "$env:temp\checkinstall.cmd" "$($scratchDir)\Windows\checkinstall.cmd" -force
|
||||||
|
Write-Host "Done copy checkinstall.cmd"
|
||||||
|
|
||||||
|
Write-Host "Creating a directory that allows to bypass Wifi setup"
|
||||||
|
New-Item -ItemType Directory -Force -Path "$($scratchDir)\Windows\System32\OOBE\BYPASSNRO"
|
||||||
|
|
||||||
|
Write-Host "Loading registry"
|
||||||
|
reg load HKLM\zCOMPONENTS "$($scratchDir)\Windows\System32\config\COMPONENTS"
|
||||||
|
reg load HKLM\zDEFAULT "$($scratchDir)\Windows\System32\config\default"
|
||||||
|
reg load HKLM\zNTUSER "$($scratchDir)\Users\Default\ntuser.dat"
|
||||||
|
reg load HKLM\zSOFTWARE "$($scratchDir)\Windows\System32\config\SOFTWARE"
|
||||||
|
reg load HKLM\zSYSTEM "$($scratchDir)\Windows\System32\config\SYSTEM"
|
||||||
|
|
||||||
|
Write-Host "Disabling Teams"
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Communications" /v "ConfigureChatAutoInstall" /t REG_DWORD /d 0 /f >$null 2>&1
|
||||||
|
reg add "HKLM\zSOFTWARE\Policies\Microsoft\Windows\Windows Chat" /v ChatIcon /t REG_DWORD /d 2 /f >$null 2>&1
|
||||||
|
reg add "HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Advanced" /v "TaskbarMn" /t REG_DWORD /d 0 /f >$null 2>&1
|
||||||
|
reg query "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Communications" /v "ConfigureChatAutoInstall" >$null 2>&1
|
||||||
|
# Write-Host Error code $LASTEXITCODE
|
||||||
|
Write-Host "Done disabling Teams"
|
||||||
|
|
||||||
|
Write-Host "Bypassing system requirements (system image)"
|
||||||
|
reg add "HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache" /v "SV1" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache" /v "SV2" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache" /v "SV1" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache" /v "SV2" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassCPUCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassRAMCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassSecureBootCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassStorageCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassTPMCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\MoSetup" /v "AllowUpgradesWithUnsupportedTPMOrCPU" /t REG_DWORD /d 1 /f
|
||||||
|
|
||||||
|
if (!$keepEdge)
|
||||||
|
{
|
||||||
|
Write-Host "Removing Edge icon from taskbar"
|
||||||
|
reg delete "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Taskband" /v "Favorites" /f >$null 2>&1
|
||||||
|
reg delete "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Taskband" /v "FavoritesChanges" /f >$null 2>&1
|
||||||
|
reg delete "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Taskband" /v "Pinned" /f >$null 2>&1
|
||||||
|
reg delete "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Taskband" /v "LayoutCycle" /f >$null 2>&1
|
||||||
|
Write-Host "Edge icon removed from taskbar"
|
||||||
|
}
|
||||||
|
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Search" /v "SearchboxTaskbarMode" /t REG_DWORD /d 0 /f
|
||||||
|
Write-Host "Setting all services to start manually"
|
||||||
|
reg add "HKLM\zSOFTWARE\CurrentControlSet\Services" /v Start /t REG_DWORD /d 3 /f
|
||||||
|
# Write-Host $LASTEXITCODE
|
||||||
|
|
||||||
|
Write-Host "Enabling Local Accounts on OOBE"
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\OOBE" /v "BypassNRO" /t REG_DWORD /d "1" /f
|
||||||
|
|
||||||
|
Write-Host "Disabling Sponsored Apps"
|
||||||
|
reg add "HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "OemPreInstalledAppsEnabled" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "PreInstalledAppsEnabled" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\SOFTWARE\Microsoft\Windows\CurrentVersion\ContentDeliveryManager" /v "SilentInstalledAppsEnabled" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zSOFTWARE\Policies\Microsoft\Windows\CloudContent" /v "DisableWindowsConsumerFeatures" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\PolicyManager\current\device\Start" /v "ConfigureStartPins" /t REG_SZ /d '{\"pinnedList\": [{}]}' /f
|
||||||
|
Write-Host "Done removing Sponsored Apps"
|
||||||
|
|
||||||
|
Write-Host "Disabling Reserved Storage"
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\ReserveManager" /v "ShippedWithReserves" /t REG_DWORD /d 0 /f
|
||||||
|
|
||||||
|
Write-Host "Changing theme to dark. This only works on Activated Windows"
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize" /v "AppsUseLightTheme" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zSOFTWARE\Microsoft\Windows\CurrentVersion\Themes\Personalize" /v "SystemUsesLightTheme" /t REG_DWORD /d 0 /f
|
||||||
|
|
||||||
|
} catch {
|
||||||
|
Write-Error "An unexpected error occurred: $_"
|
||||||
|
} finally {
|
||||||
|
Write-Host "Unmounting Registry..."
|
||||||
|
reg unload HKLM\zCOMPONENTS
|
||||||
|
reg unload HKLM\zDEFAULT
|
||||||
|
reg unload HKLM\zNTUSER
|
||||||
|
reg unload HKLM\zSOFTWARE
|
||||||
|
reg unload HKLM\zSYSTEM
|
||||||
|
|
||||||
|
Write-Host "Cleaning up image..."
|
||||||
|
dism /image:$scratchDir /Cleanup-Image /StartComponentCleanup /ResetBase
|
||||||
|
Write-Host "Cleanup complete."
|
||||||
|
|
||||||
|
Write-Host "Unmounting image..."
|
||||||
|
dism /unmount-image /mountdir:$scratchDir /commit
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
|
||||||
|
Write-Host "Exporting image into $mountDir\sources\install2.wim"
|
||||||
|
dism /Export-Image /SourceImageFile:"$mountDir\sources\install.wim" /SourceIndex:$index /DestinationImageFile:"$mountDir\sources\install2.wim" /compress:max
|
||||||
|
Write-Host "Remove old '$mountDir\sources\install.wim' and rename $mountDir\sources\install2.wim"
|
||||||
|
Remove-Item "$mountDir\sources\install.wim"
|
||||||
|
Rename-Item "$mountDir\sources\install2.wim" "$mountDir\sources\install.wim"
|
||||||
|
|
||||||
|
if (-not (Test-Path -Path "$mountDir\sources\install.wim"))
|
||||||
|
{
|
||||||
|
Write-Error "Somethig went wrong and '$mountDir\sources\install.wim' doesn't exist. Please report this bug to the devs"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
Write-Host "Windows image completed. Continuing with boot.wim."
|
||||||
|
|
||||||
|
# Next step boot image
|
||||||
|
Write-Host "Mounting boot image $mountDir\sources\boot.wim into $scratchDir"
|
||||||
|
dism /mount-image /imagefile:"$mountDir\sources\boot.wim" /index:2 /mountdir:"$scratchDir"
|
||||||
|
|
||||||
|
Write-Host "Loading registry..."
|
||||||
|
reg load HKLM\zCOMPONENTS "$($scratchDir)\Windows\System32\config\COMPONENTS" >$null
|
||||||
|
reg load HKLM\zDEFAULT "$($scratchDir)\Windows\System32\config\default" >$null
|
||||||
|
reg load HKLM\zNTUSER "$($scratchDir)\Users\Default\ntuser.dat" >$null
|
||||||
|
reg load HKLM\zSOFTWARE "$($scratchDir)\Windows\System32\config\SOFTWARE" >$null
|
||||||
|
reg load HKLM\zSYSTEM "$($scratchDir)\Windows\System32\config\SYSTEM" >$null
|
||||||
|
Write-Host "Bypassing system requirements on the setup image"
|
||||||
|
reg add "HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache" /v "SV1" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zDEFAULT\Control Panel\UnsupportedHardwareNotificationCache" /v "SV2" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache" /v "SV1" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zNTUSER\Control Panel\UnsupportedHardwareNotificationCache" /v "SV2" /t REG_DWORD /d 0 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassCPUCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassRAMCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassSecureBootCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassStorageCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\LabConfig" /v "BypassTPMCheck" /t REG_DWORD /d 1 /f
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\MoSetup" /v "AllowUpgradesWithUnsupportedTPMOrCPU" /t REG_DWORD /d 1 /f
|
||||||
|
# Fix Computer Restarted Unexpectedly Error on New Bare Metal Install
|
||||||
|
reg add "HKLM\zSYSTEM\Setup\Status\ChildCompletion" /v "setup.exe" /t REG_DWORD /d 3 /f
|
||||||
|
} catch {
|
||||||
|
Write-Error "An unexpected error occurred: $_"
|
||||||
|
} finally {
|
||||||
|
Write-Host "Unmounting Registry..."
|
||||||
|
reg unload HKLM\zCOMPONENTS
|
||||||
|
reg unload HKLM\zDEFAULT
|
||||||
|
reg unload HKLM\zNTUSER
|
||||||
|
reg unload HKLM\zSOFTWARE
|
||||||
|
reg unload HKLM\zSYSTEM
|
||||||
|
|
||||||
|
Write-Host "Unmounting image..."
|
||||||
|
dism /unmount-image /mountdir:$scratchDir /commit
|
||||||
|
|
||||||
|
Write-Host "Creating ISO image"
|
||||||
|
#& oscdimg.exe -m -o -u2 -udfver102 -bootdata:2#p0,e,b$mountDir\boot\etfsboot.com#pEF,e,b$mountDir\efi\microsoft\boot\efisys.bin $mountDir $env:temp\microwin.iso
|
||||||
|
Start-Process -FilePath "oscdimg.exe" -ArgumentList "-m -o -u2 -udfver102 -bootdata:2#p0,e,b$mountDir\boot\etfsboot.com#pEF,e,b$mountDir\efi\microsoft\boot\efisys.bin $mountDir $env:temp\microwin.iso" -NoNewWindow -Wait
|
||||||
|
|
||||||
|
if ($copyToUSB)
|
||||||
|
{
|
||||||
|
Write-Host "Copying microwin.iso to the USB drive"
|
||||||
|
Copy-ToUSB("$env:temp\microwin.iso")
|
||||||
|
Write-Host "Done Copying microwin.iso to USB drive!"
|
||||||
|
}
|
||||||
|
|
||||||
|
Write-Host " _____ "
|
||||||
|
Write-Host "(____ \ "
|
||||||
|
Write-Host " _ \ \ ___ ____ ____ "
|
||||||
|
Write-Host "| | | / _ \| _ \ / _ ) "
|
||||||
|
Write-Host "| |__/ / |_| | | | ( (/ / "
|
||||||
|
Write-Host "|_____/ \___/|_| |_|\____) "
|
||||||
|
|
||||||
|
# Check if the ISO was successfully created - CTT edit
|
||||||
|
if ($LASTEXITCODE -eq 0) {
|
||||||
|
Write-Host "Done. ISO image is located here: $env:temp\microwin.iso"
|
||||||
|
Write-Host "Performing Cleanup"
|
||||||
|
Remove-Item -Recurse -Force "$($scratchDir)"
|
||||||
|
Remove-Item -Recurse -Force "$($mountDir)"
|
||||||
|
} else {
|
||||||
|
Write-Host "ISO creation failed. The "$($mountDir)" directory has not been removed."
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
$sync.MicrowinOptionsPanel.Visibility = 'Collapsed'
|
||||||
|
|
||||||
|
$sync.MicrowinFinalIsoLocation.Text = "$env:temp\microwin.iso"
|
||||||
|
|
||||||
|
$sync.ProcessRunning = $false
|
||||||
|
}
|
||||||
|
}
|
@ -11,17 +11,21 @@ function Invoke-WPFTab {
|
|||||||
#>
|
#>
|
||||||
|
|
||||||
Param ($ClickedTab)
|
Param ($ClickedTab)
|
||||||
$Tabs = Get-WinUtilVariables | Where-Object {$psitem -like "WPFTab?BT"}
|
|
||||||
$TabNav = Get-WinUtilVariables | Where-Object {$psitem -like "WPFTabNav"}
|
|
||||||
$x = [int]($ClickedTab -replace "WPFTab","" -replace "BT","") - 1
|
|
||||||
|
|
||||||
0..($Tabs.Count -1 ) | ForEach-Object {
|
$tabNav = Get-WinUtilVariables | Where-Object {$psitem -like "WPFTabNav"}
|
||||||
|
$tabNumber = [int]($ClickedTab -replace "WPFTab","" -replace "BT","") - 1
|
||||||
|
|
||||||
if ($x -eq $psitem){
|
$filter = Get-WinUtilVariables -Type ToggleButton | Where-Object {$psitem -like "WPFTab?BT"}
|
||||||
$sync.$TabNav.Items[$psitem].IsSelected = $true
|
$sync.GetEnumerator() | Where-Object {$psitem.Key -in $filter} | ForEach-Object {
|
||||||
|
if ($ClickedTab -ne $PSItem.name) {
|
||||||
|
$sync[$PSItem.Name].IsChecked = $false
|
||||||
|
# $tabNumber = [int]($PSItem.Name -replace "WPFTab","" -replace "BT","") - 1
|
||||||
|
# $sync.$tabNav.Items[$tabNumber].IsSelected = $false
|
||||||
}
|
}
|
||||||
else{
|
else {
|
||||||
$sync.$TabNav.Items[$psitem].IsSelected = $false
|
$sync["$ClickedTab"].IsChecked = $true
|
||||||
|
$tabNumber = [int]($ClickedTab-replace "WPFTab","" -replace "BT","") - 1
|
||||||
|
$sync.$tabNav.Items[$tabNumber].IsSelected = $true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -16,8 +16,6 @@ Describe "Functions"{
|
|||||||
fullname = $psitem.FullName
|
fullname = $psitem.FullName
|
||||||
} {
|
} {
|
||||||
Get-ChildItem function:\$basename | should -Not -BeNullOrEmpty
|
Get-ChildItem function:\$basename | should -Not -BeNullOrEmpty
|
||||||
} {
|
|
||||||
get-help $basename -ErrorAction SilentlyContinue | Select-Object -ExpandProperty Description | should -Not -BeNullOrEmpty
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
191
scripts/main.ps1
191
scripts/main.ps1
@ -96,6 +96,16 @@ $sync.keys | ForEach-Object {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$sync.keys | ForEach-Object {
|
||||||
|
if($sync.$psitem){
|
||||||
|
if($($sync["$psitem"].GetType() | Select-Object -ExpandProperty Name) -eq "ToggleButton"){
|
||||||
|
$sync["$psitem"].Add_Click({
|
||||||
|
[System.Object]$Sender = $args[0]
|
||||||
|
Invoke-WPFButton $Sender.name
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
$sync.keys | ForEach-Object {
|
$sync.keys | ForEach-Object {
|
||||||
if($sync.$psitem){
|
if($sync.$psitem){
|
||||||
@ -113,7 +123,6 @@ $sync.keys | ForEach-Object {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
#===========================================================================
|
#===========================================================================
|
||||||
# Setup background config
|
# Setup background config
|
||||||
#===========================================================================
|
#===========================================================================
|
||||||
@ -121,9 +130,7 @@ $sync.keys | ForEach-Object {
|
|||||||
# Load computer information in the background
|
# Load computer information in the background
|
||||||
Invoke-WPFRunspace -ScriptBlock {
|
Invoke-WPFRunspace -ScriptBlock {
|
||||||
$sync.ConfigLoaded = $False
|
$sync.ConfigLoaded = $False
|
||||||
|
|
||||||
$sync.ComputerInfo = Get-ComputerInfo
|
$sync.ComputerInfo = Get-ComputerInfo
|
||||||
|
|
||||||
$sync.ConfigLoaded = $True
|
$sync.ConfigLoaded = $True
|
||||||
} | Out-Null
|
} | Out-Null
|
||||||
|
|
||||||
@ -146,7 +153,181 @@ $sync["Form"].Add_Closing({
|
|||||||
[System.GC]::Collect()
|
[System.GC]::Collect()
|
||||||
})
|
})
|
||||||
|
|
||||||
# Show the form
|
# add some shortcuts for people that don't like clicking
|
||||||
$sync["Form"].ShowDialog() | out-null
|
$commonKeyEvents = {
|
||||||
|
if ($sync.ProcessRunning -eq $true) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
# Escape removes focus from the searchbox that way all shortcuts will start workinf again
|
||||||
|
if ($_.Key -eq "Escape") {
|
||||||
|
if ($sync.CheckboxFilter.IsFocused)
|
||||||
|
{
|
||||||
|
$sync.CheckboxFilter.SelectAll()
|
||||||
|
$sync.CheckboxFilter.Text = ""
|
||||||
|
$sync.CheckboxFilter.Focus()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
# don't ask, I know what I'm doing, just go...
|
||||||
|
if (($_.Key -eq "Q" -and $_.KeyboardDevice.Modifiers -eq "Ctrl"))
|
||||||
|
{
|
||||||
|
$this.Close()
|
||||||
|
}
|
||||||
|
|
||||||
|
# $ret = [System.Windows.Forms.MessageBox]::Show("Are you sure you want to Exit?", "Winutil", [System.Windows.Forms.MessageBoxButtons]::YesNo,
|
||||||
|
# [System.Windows.Forms.MessageBoxIcon]::Question, [System.Windows.Forms.MessageBoxDefaultButton]::Button2)
|
||||||
|
|
||||||
|
# switch ($ret) {
|
||||||
|
# "Yes" {
|
||||||
|
# $this.Close()
|
||||||
|
# }
|
||||||
|
# "No" {
|
||||||
|
# return
|
||||||
|
# }
|
||||||
|
# }
|
||||||
|
|
||||||
|
|
||||||
|
if ($_.KeyboardDevice.Modifiers -eq "Alt") {
|
||||||
|
# this is an example how to handle shortcuts per tab
|
||||||
|
# Alt-I on the MicroWin tab (4) would press GetIso Button
|
||||||
|
# NOTE: All per tab shortcuts have to be handled *before* regular tab keys
|
||||||
|
# if ($_.SystemKey -eq "I") {
|
||||||
|
# $TabNav = Get-WinUtilVariables | Where-Object {$psitem -like "WPFTabNav"}
|
||||||
|
# if ($sync.$TabNav.Items[4].IsSelected -eq $true) {
|
||||||
|
# Invoke-WPFButton "WPFGetIso"
|
||||||
|
# break
|
||||||
|
# }
|
||||||
|
# }
|
||||||
|
if ($_.SystemKey -eq "I") {
|
||||||
|
Invoke-WPFButton "WPFTab1BT"
|
||||||
|
}
|
||||||
|
if ($_.SystemKey -eq "T") {
|
||||||
|
Invoke-WPFButton "WPFTab2BT"
|
||||||
|
}
|
||||||
|
if ($_.SystemKey -eq "C") {
|
||||||
|
Invoke-WPFButton "WPFTab3BT"
|
||||||
|
}
|
||||||
|
if ($_.SystemKey -eq "U") {
|
||||||
|
Invoke-WPFButton "WPFTab4BT"
|
||||||
|
}
|
||||||
|
if ($_.SystemKey -eq "M") {
|
||||||
|
Invoke-WPFButton "WPFTab5BT"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
# shortcut for the filter box
|
||||||
|
if ($_.Key -eq "F" -and $_.KeyboardDevice.Modifiers -eq "Ctrl") {
|
||||||
|
if ($sync.CheckboxFilter.Text -eq "Ctrl-F to filter") {
|
||||||
|
$sync.CheckboxFilter.SelectAll()
|
||||||
|
$sync.CheckboxFilter.Text = ""
|
||||||
|
}
|
||||||
|
$sync.CheckboxFilter.Focus()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$sync["Form"].Add_PreViewKeyDown($commonKeyEvents)
|
||||||
|
|
||||||
|
# adding some left mouse window move on drag capability
|
||||||
|
$sync["Form"].Add_MouseLeftButtonDown({
|
||||||
|
$sync["Form"].DragMove()
|
||||||
|
})
|
||||||
|
|
||||||
|
# setting window icon to make it look more professional
|
||||||
|
$sync["Form"].Add_Loaded({
|
||||||
|
|
||||||
|
$downloadUrl = "https://christitus.com/images/logo-full.png"
|
||||||
|
$destinationPath = Join-Path $env:TEMP "cttlogo.png"
|
||||||
|
|
||||||
|
# Check if the file already exists
|
||||||
|
if (-not (Test-Path $destinationPath)) {
|
||||||
|
# File does not exist, download it
|
||||||
|
$wc = New-Object System.Net.WebClient
|
||||||
|
$wc.DownloadFile($downloadUrl, $destinationPath)
|
||||||
|
Write-Output "File downloaded to: $destinationPath"
|
||||||
|
} else {
|
||||||
|
Write-Output "File already exists at: $destinationPath"
|
||||||
|
}
|
||||||
|
$sync["Form"].Icon = $destinationPath
|
||||||
|
|
||||||
|
Try {
|
||||||
|
[Void][Window]
|
||||||
|
} Catch {
|
||||||
|
Add-Type @"
|
||||||
|
using System;
|
||||||
|
using System.Runtime.InteropServices;
|
||||||
|
public class Window {
|
||||||
|
[DllImport("user32.dll")]
|
||||||
|
[return: MarshalAs(UnmanagedType.Bool)]
|
||||||
|
public static extern bool GetWindowRect(IntPtr hWnd, out RECT lpRect);
|
||||||
|
[DllImport("user32.dll")]
|
||||||
|
[return: MarshalAs(UnmanagedType.Bool)]
|
||||||
|
public static extern bool MoveWindow(IntPtr handle, int x, int y, int width, int height, bool redraw);
|
||||||
|
[DllImport("user32.dll")]
|
||||||
|
[return: MarshalAs(UnmanagedType.Bool)]
|
||||||
|
public static extern bool ShowWindow(IntPtr handle, int state);
|
||||||
|
}
|
||||||
|
public struct RECT {
|
||||||
|
public int Left; // x position of upper-left corner
|
||||||
|
public int Top; // y position of upper-left corner
|
||||||
|
public int Right; // x position of lower-right corner
|
||||||
|
public int Bottom; // y position of lower-right corner
|
||||||
|
}
|
||||||
|
"@
|
||||||
|
}
|
||||||
|
|
||||||
|
$processId = [System.Diagnostics.Process]::GetCurrentProcess().Id
|
||||||
|
$windowHandle = (Get-Process -Id $processId).MainWindowHandle
|
||||||
|
$rect = New-Object RECT
|
||||||
|
[Void][Window]::GetWindowRect($windowHandle,[ref]$rect)
|
||||||
|
|
||||||
|
# only snap upper edge don't move left to right, in case people have multimon setup
|
||||||
|
$x = $rect.Left
|
||||||
|
$y = 0
|
||||||
|
$width = $rect.Right - $rect.Left
|
||||||
|
$height = $rect.Bottom - $rect.Top
|
||||||
|
|
||||||
|
# Move the window to that position...
|
||||||
|
[Void][Window]::MoveWindow($windowHandle, $x, $y, $width, $height, $True)
|
||||||
|
Invoke-WPFTab "WPFTab1BT"
|
||||||
|
$sync["Form"].Focus()
|
||||||
|
})
|
||||||
|
|
||||||
|
$sync["CheckboxFilter"].Add_TextChanged({
|
||||||
|
#Write-host $sync.CheckboxFilter.Text
|
||||||
|
|
||||||
|
$filter = Get-WinUtilVariables -Type Checkbox
|
||||||
|
$CheckBoxes = $sync.GetEnumerator() | Where-Object {$psitem.Key -in $filter}
|
||||||
|
$textToSearch = $sync.CheckboxFilter.Text
|
||||||
|
Foreach ($CheckBox in $CheckBoxes) {
|
||||||
|
#Write-Host "$($sync.CheckboxFilter.Text)"
|
||||||
|
if ($CheckBox -eq $null -or $CheckBox.Value -eq $null -or $CheckBox.Value.Content -eq $null) {
|
||||||
|
continue
|
||||||
|
}
|
||||||
|
if ($CheckBox.Value.Content.ToLower().Contains($textToSearch)) {
|
||||||
|
$CheckBox.Value.Visibility = "Visible"
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$CheckBox.Value.Visibility = "Collapsed"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
$downloadUrl = "https://christitus.com/images/logo-full.png"
|
||||||
|
$destinationPath = Join-Path $env:TEMP "cttlogo.png"
|
||||||
|
|
||||||
|
# Check if the file already exists
|
||||||
|
if (-not (Test-Path $destinationPath)) {
|
||||||
|
# File does not exist, download it
|
||||||
|
$wc = New-Object System.Net.WebClient
|
||||||
|
$wc.DownloadFile($downloadUrl, $destinationPath)
|
||||||
|
Write-Output "File downloaded to: $destinationPath"
|
||||||
|
} else {
|
||||||
|
Write-Output "File already exists at: $destinationPath"
|
||||||
|
}
|
||||||
|
|
||||||
|
# show current windowsd Product ID
|
||||||
|
#Write-Host "Your Windows Product Key: $((Get-WmiObject -query 'select * from SoftwareLicensingService').OA3xOriginalProductKey)"
|
||||||
|
|
||||||
|
$sync["Form"].ShowDialog() | out-null
|
||||||
Stop-Transcript
|
Stop-Transcript
|
@ -9,6 +9,7 @@
|
|||||||
Start-Transcript $ENV:TEMP\Winutil.log -Append
|
Start-Transcript $ENV:TEMP\Winutil.log -Append
|
||||||
|
|
||||||
# Load DLLs
|
# Load DLLs
|
||||||
|
Add-Type -AssemblyName PresentationFramework
|
||||||
Add-Type -AssemblyName System.Windows.Forms
|
Add-Type -AssemblyName System.Windows.Forms
|
||||||
|
|
||||||
# Variable to sync between runspaces
|
# Variable to sync between runspaces
|
||||||
@ -18,9 +19,20 @@ $sync.version = "#{replaceme}"
|
|||||||
$sync.configs = @{}
|
$sync.configs = @{}
|
||||||
$sync.ProcessRunning = $false
|
$sync.ProcessRunning = $false
|
||||||
|
|
||||||
|
$currentPid = [System.Security.Principal.WindowsIdentity]::GetCurrent()
|
||||||
|
$principal = new-object System.Security.Principal.WindowsPrincipal($currentPid)
|
||||||
|
$adminRole=[System.Security.Principal.WindowsBuiltInRole]::Administrator
|
||||||
|
|
||||||
if (!([Security.Principal.WindowsPrincipal][Security.Principal.WindowsIdentity]::GetCurrent()).IsInRole([Security.Principal.WindowsBuiltInRole]::Administrator)) {
|
if ($principal.IsInRole($adminRole))
|
||||||
Write-Output "Winutil needs to be run as Administrator. Attempting to relaunch."
|
{
|
||||||
Start-Process -Verb runas -FilePath powershell.exe -ArgumentList "iwr -useb https://christitus.com/win | iex"
|
$Host.UI.RawUI.WindowTitle = $myInvocation.MyCommand.Definition + "(Admin)"
|
||||||
|
clear-host
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$newProcess = new-object System.Diagnostics.ProcessStartInfo "PowerShell";
|
||||||
|
$newProcess.Arguments = $myInvocation.MyCommand.Definition;
|
||||||
|
$newProcess.Verb = "runas";
|
||||||
|
[System.Diagnostics.Process]::Start($newProcess);
|
||||||
break
|
break
|
||||||
}
|
}
|
1880
winutil.ps1
1880
winutil.ps1
File diff suppressed because it is too large
Load Diff
@ -10,6 +10,86 @@
|
|||||||
Title="Chris Titus Tech's Windows Utility" Height="800" Width="1200">
|
Title="Chris Titus Tech's Windows Utility" Height="800" Width="1200">
|
||||||
|
|
||||||
<Window.Resources>
|
<Window.Resources>
|
||||||
|
<!--Scrollbar Thumbs-->
|
||||||
|
<Style x:Key="ScrollThumbs" TargetType="{x:Type Thumb}">
|
||||||
|
<Setter Property="Template">
|
||||||
|
<Setter.Value>
|
||||||
|
<ControlTemplate TargetType="{x:Type Thumb}">
|
||||||
|
<Grid x:Name="Grid">
|
||||||
|
<Rectangle HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Width="Auto" Height="Auto" Fill="Transparent" />
|
||||||
|
<Border x:Name="Rectangle1" CornerRadius="5" HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Width="Auto" Height="Auto" Background="{TemplateBinding Background}" />
|
||||||
|
</Grid>
|
||||||
|
<ControlTemplate.Triggers>
|
||||||
|
<Trigger Property="Tag" Value="Horizontal">
|
||||||
|
<Setter TargetName="Rectangle1" Property="Width" Value="Auto" />
|
||||||
|
<Setter TargetName="Rectangle1" Property="Height" Value="7" />
|
||||||
|
</Trigger>
|
||||||
|
</ControlTemplate.Triggers>
|
||||||
|
</ControlTemplate>
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
</Style>
|
||||||
|
|
||||||
|
<!--ScrollBars-->
|
||||||
|
<Style x:Key="{x:Type ScrollBar}" TargetType="{x:Type ScrollBar}">
|
||||||
|
<Setter Property="Stylus.IsFlicksEnabled" Value="false" />
|
||||||
|
<Setter Property="Foreground" Value="{MainForegroundColor}" />
|
||||||
|
<Setter Property="Background" Value="{MainBackgroundColor}" />
|
||||||
|
<Setter Property="Width" Value="6" />
|
||||||
|
<Setter Property="Template">
|
||||||
|
<Setter.Value>
|
||||||
|
<ControlTemplate TargetType="{x:Type ScrollBar}">
|
||||||
|
<Grid x:Name="GridRoot" Width="7" Background="{TemplateBinding Background}" >
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="0.00001*" />
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
|
||||||
|
<Track x:Name="PART_Track" Grid.Row="0" IsDirectionReversed="true" Focusable="false">
|
||||||
|
<Track.Thumb>
|
||||||
|
<Thumb x:Name="Thumb" Background="{TemplateBinding Foreground}" Style="{DynamicResource ScrollThumbs}" />
|
||||||
|
</Track.Thumb>
|
||||||
|
<Track.IncreaseRepeatButton>
|
||||||
|
<RepeatButton x:Name="PageUp" Command="ScrollBar.PageDownCommand" Opacity="0" Focusable="false" />
|
||||||
|
</Track.IncreaseRepeatButton>
|
||||||
|
<Track.DecreaseRepeatButton>
|
||||||
|
<RepeatButton x:Name="PageDown" Command="ScrollBar.PageUpCommand" Opacity="0" Focusable="false" />
|
||||||
|
</Track.DecreaseRepeatButton>
|
||||||
|
</Track>
|
||||||
|
</Grid>
|
||||||
|
|
||||||
|
<ControlTemplate.Triggers>
|
||||||
|
<Trigger SourceName="Thumb" Property="IsMouseOver" Value="true">
|
||||||
|
<Setter Value="{ButtonBackgroundMouseoverColor}" TargetName="Thumb" Property="Background" />
|
||||||
|
</Trigger>
|
||||||
|
<Trigger SourceName="Thumb" Property="IsDragging" Value="true">
|
||||||
|
<Setter Value="{ButtonBackgroundSelectedColor}" TargetName="Thumb" Property="Background" />
|
||||||
|
</Trigger>
|
||||||
|
|
||||||
|
<Trigger Property="IsEnabled" Value="false">
|
||||||
|
<Setter TargetName="Thumb" Property="Visibility" Value="Collapsed" />
|
||||||
|
</Trigger>
|
||||||
|
<Trigger Property="Orientation" Value="Horizontal">
|
||||||
|
<Setter TargetName="GridRoot" Property="LayoutTransform">
|
||||||
|
<Setter.Value>
|
||||||
|
<RotateTransform Angle="-90" />
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
<Setter TargetName="PART_Track" Property="LayoutTransform">
|
||||||
|
<Setter.Value>
|
||||||
|
<RotateTransform Angle="-90" />
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
<Setter Property="Width" Value="Auto" />
|
||||||
|
<Setter Property="Height" Value="8" />
|
||||||
|
<Setter TargetName="Thumb" Property="Tag" Value="Horizontal" />
|
||||||
|
<Setter TargetName="PageDown" Property="Command" Value="ScrollBar.PageLeftCommand" />
|
||||||
|
<Setter TargetName="PageUp" Property="Command" Value="ScrollBar.PageRightCommand" />
|
||||||
|
</Trigger>
|
||||||
|
</ControlTemplate.Triggers>
|
||||||
|
</ControlTemplate>
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
</Style>
|
||||||
<Style TargetType="ComboBox">
|
<Style TargetType="ComboBox">
|
||||||
<Setter Property="Foreground" Value="{ComboBoxForegroundColor}" />
|
<Setter Property="Foreground" Value="{ComboBoxForegroundColor}" />
|
||||||
<Setter Property="Background" Value="{ComboBoxBackgroundColor}" />
|
<Setter Property="Background" Value="{ComboBoxBackgroundColor}" />
|
||||||
@ -25,7 +105,8 @@
|
|||||||
ClickMode="Press">
|
ClickMode="Press">
|
||||||
<TextBlock Text="{TemplateBinding SelectionBoxItem}"
|
<TextBlock Text="{TemplateBinding SelectionBoxItem}"
|
||||||
Foreground="{TemplateBinding Foreground}"
|
Foreground="{TemplateBinding Foreground}"
|
||||||
Background="{TemplateBinding Background}"
|
Background="Transparent"
|
||||||
|
HorizontalAlignment="Center" VerticalAlignment="Center" Margin="2"
|
||||||
/>
|
/>
|
||||||
</ToggleButton>
|
</ToggleButton>
|
||||||
<Popup x:Name="Popup"
|
<Popup x:Name="Popup"
|
||||||
@ -40,7 +121,7 @@
|
|||||||
BorderThickness="1"
|
BorderThickness="1"
|
||||||
CornerRadius="4">
|
CornerRadius="4">
|
||||||
<ScrollViewer>
|
<ScrollViewer>
|
||||||
<ItemsPresenter />
|
<ItemsPresenter HorizontalAlignment="Center" VerticalAlignment="Center" Margin="2"/>
|
||||||
</ScrollViewer>
|
</ScrollViewer>
|
||||||
</Border>
|
</Border>
|
||||||
</Popup>
|
</Popup>
|
||||||
@ -53,14 +134,70 @@
|
|||||||
<Setter Property="Foreground" Value="{LabelboxForegroundColor}"/>
|
<Setter Property="Foreground" Value="{LabelboxForegroundColor}"/>
|
||||||
<Setter Property="Background" Value="{LabelBackgroundColor}"/>
|
<Setter Property="Background" Value="{LabelBackgroundColor}"/>
|
||||||
</Style>
|
</Style>
|
||||||
|
<!-- TextBlock template -->
|
||||||
<Style TargetType="TextBlock">
|
<Style TargetType="TextBlock">
|
||||||
<Setter Property="Foreground" Value="{LabelboxForegroundColor}"/>
|
<Setter Property="Foreground" Value="{LabelboxForegroundColor}"/>
|
||||||
<Setter Property="Background" Value="{LabelBackgroundColor}"/>
|
<Setter Property="Background" Value="{LabelBackgroundColor}"/>
|
||||||
</Style>
|
</Style>
|
||||||
|
<!-- Toggle button template x:Key="TabToggleButton" -->
|
||||||
|
<Style TargetType="{x:Type ToggleButton}">
|
||||||
|
<Setter Property="Margin" Value="{ButtonMargin}"/>
|
||||||
|
<Setter Property="Content" Value=""/>
|
||||||
|
<Setter Property="Template">
|
||||||
|
<Setter.Value>
|
||||||
|
<ControlTemplate TargetType="ToggleButton">
|
||||||
|
<Grid>
|
||||||
|
<Border x:Name="ButtonGlow"
|
||||||
|
Background="{TemplateBinding Background}"
|
||||||
|
BorderBrush="{ButtonForegroundColor}"
|
||||||
|
BorderThickness="{ButtonBorderThickness}"
|
||||||
|
CornerRadius="{ButtonCornerRadius}">
|
||||||
|
<Grid>
|
||||||
|
<Border x:Name="BackgroundBorder"
|
||||||
|
Background="{TemplateBinding Background}"
|
||||||
|
BorderBrush="{ButtonBackgroundColor}"
|
||||||
|
BorderThickness="{ButtonBorderThickness}"
|
||||||
|
CornerRadius="{ButtonCornerRadius}">
|
||||||
|
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" Margin="10,2,10,2"/>
|
||||||
|
</Border>
|
||||||
|
</Grid>
|
||||||
|
</Border>
|
||||||
|
</Grid>
|
||||||
|
<ControlTemplate.Triggers>
|
||||||
|
<Trigger Property="IsMouseOver" Value="True">
|
||||||
|
<Setter TargetName="BackgroundBorder" Property="Background" Value="{ButtonBackgroundMouseoverColor}"/>
|
||||||
|
<Setter Property="Effect">
|
||||||
|
<Setter.Value>
|
||||||
|
<DropShadowEffect Opacity="1" ShadowDepth="5" Color="Gold" Direction="-100" BlurRadius="45"/>
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
<Setter Property="Panel.ZIndex" Value="2000"/>
|
||||||
|
</Trigger>
|
||||||
|
<Trigger Property="IsChecked" Value="True">
|
||||||
|
<Setter Property="BorderBrush" Value="Pink"/>
|
||||||
|
<Setter Property="BorderThickness" Value="2"/>
|
||||||
|
<Setter TargetName="BackgroundBorder" Property="Background" Value="{ButtonBackgroundSelectedColor}"/>
|
||||||
|
<Setter Property="Effect">
|
||||||
|
<Setter.Value>
|
||||||
|
<DropShadowEffect Opacity="1" ShadowDepth="2" Color="Gold" Direction="-111" BlurRadius="25"/>
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
</Trigger>
|
||||||
|
<Trigger Property="IsChecked" Value="False">
|
||||||
|
<Setter Property="BorderBrush" Value="Transparent"/>
|
||||||
|
<Setter Property="BorderThickness" Value="{ButtonBorderThickness}"/>
|
||||||
|
</Trigger>
|
||||||
|
</ControlTemplate.Triggers>
|
||||||
|
</ControlTemplate>
|
||||||
|
</Setter.Value>
|
||||||
|
</Setter>
|
||||||
|
</Style>
|
||||||
|
<!-- Button Template -->
|
||||||
<Style TargetType="Button">
|
<Style TargetType="Button">
|
||||||
|
<Setter Property="Margin" Value="{ButtonMargin}"/>
|
||||||
<Setter Property="Foreground" Value="{ButtonForegroundColor}"/>
|
<Setter Property="Foreground" Value="{ButtonForegroundColor}"/>
|
||||||
<Setter Property="Background" Value="{ButtonBackgroundColor}"/>
|
<Setter Property="Background" Value="{ButtonBackgroundColor}"/>
|
||||||
<Setter Property="Margin" Value="{ButtonMargin}"/>
|
|
||||||
<Setter Property="Template">
|
<Setter Property="Template">
|
||||||
<Setter.Value>
|
<Setter.Value>
|
||||||
<ControlTemplate TargetType="Button">
|
<ControlTemplate TargetType="Button">
|
||||||
@ -70,7 +207,7 @@
|
|||||||
BorderBrush="{TemplateBinding BorderBrush}"
|
BorderBrush="{TemplateBinding BorderBrush}"
|
||||||
BorderThickness="{ButtonBorderThickness}"
|
BorderThickness="{ButtonBorderThickness}"
|
||||||
CornerRadius="{ButtonCornerRadius}">
|
CornerRadius="{ButtonCornerRadius}">
|
||||||
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center"/>
|
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" Margin="10,2,10,2"/>
|
||||||
</Border>
|
</Border>
|
||||||
</Grid>
|
</Grid>
|
||||||
<ControlTemplate.Triggers>
|
<ControlTemplate.Triggers>
|
||||||
@ -81,7 +218,7 @@
|
|||||||
<Setter TargetName="BackgroundBorder" Property="Background" Value="{ButtonBackgroundMouseoverColor}"/>
|
<Setter TargetName="BackgroundBorder" Property="Background" Value="{ButtonBackgroundMouseoverColor}"/>
|
||||||
</Trigger>
|
</Trigger>
|
||||||
<Trigger Property="IsEnabled" Value="False">
|
<Trigger Property="IsEnabled" Value="False">
|
||||||
<Setter TargetName="BackgroundBorder" Property="Background" Value="Gray"/>
|
<Setter TargetName="BackgroundBorder" Property="Background" Value="{ButtonBackgroundSelectedColor}"/>
|
||||||
<Setter Property="Foreground" Value="DimGray"/>
|
<Setter Property="Foreground" Value="DimGray"/>
|
||||||
</Trigger>
|
</Trigger>
|
||||||
</ControlTemplate.Triggers>
|
</ControlTemplate.Triggers>
|
||||||
@ -89,6 +226,7 @@
|
|||||||
</Setter.Value>
|
</Setter.Value>
|
||||||
</Setter>
|
</Setter>
|
||||||
</Style>
|
</Style>
|
||||||
|
<!-- Checkbox template -->
|
||||||
<Style TargetType="CheckBox">
|
<Style TargetType="CheckBox">
|
||||||
<Setter Property="Foreground" Value="{MainForegroundColor}"/>
|
<Setter Property="Foreground" Value="{MainForegroundColor}"/>
|
||||||
<Setter Property="Background" Value="{MainBackgroundColor}"/>
|
<Setter Property="Background" Value="{MainBackgroundColor}"/>
|
||||||
@ -122,7 +260,6 @@
|
|||||||
</Grid>
|
</Grid>
|
||||||
<ControlTemplate.Triggers>
|
<ControlTemplate.Triggers>
|
||||||
<Trigger Property="IsChecked" Value="True">
|
<Trigger Property="IsChecked" Value="True">
|
||||||
|
|
||||||
<Setter TargetName="CheckMark" Property="Visibility" Value="Visible"/>
|
<Setter TargetName="CheckMark" Property="Visibility" Value="Visible"/>
|
||||||
</Trigger>
|
</Trigger>
|
||||||
<Trigger Property="IsMouseOver" Value="True">
|
<Trigger Property="IsMouseOver" Value="True">
|
||||||
@ -247,7 +384,7 @@
|
|||||||
|
|
||||||
<ThicknessAnimation Storyboard.TargetName="Ellipse"
|
<ThicknessAnimation Storyboard.TargetName="Ellipse"
|
||||||
Storyboard.TargetProperty="Margin"
|
Storyboard.TargetProperty="Margin"
|
||||||
To="56 2 2 1" Duration="0:0:0.1" />
|
To="46 2 2 1" Duration="0:0:0.1" />
|
||||||
|
|
||||||
<DoubleAnimation Storyboard.TargetName="txtDisable"
|
<DoubleAnimation Storyboard.TargetName="txtDisable"
|
||||||
Storyboard.TargetProperty="(TextBlock.Opacity)"
|
Storyboard.TargetProperty="(TextBlock.Opacity)"
|
||||||
@ -300,13 +437,9 @@
|
|||||||
</Trigger>
|
</Trigger>
|
||||||
</Style.Triggers>
|
</Style.Triggers>
|
||||||
</Style>
|
</Style>
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
</Window.Resources>
|
</Window.Resources>
|
||||||
<Border Name="WPFdummy" Grid.Column="0" Grid.Row="1">
|
<Border Name="WPFdummy" Grid.Column="0" Grid.Row="1">
|
||||||
<Viewbox Stretch="Uniform" VerticalAlignment="Top">
|
<Grid Background="{MainBackgroundColor}" ShowGridLines="False" Name="WPFMainGrid" Width="Auto" Height="Auto">
|
||||||
<Grid Background="{MainBackgroundColor}" ShowGridLines="False" Name="WPFMainGrid">
|
|
||||||
<Grid.RowDefinitions>
|
<Grid.RowDefinitions>
|
||||||
<RowDefinition Height=".1*"/>
|
<RowDefinition Height=".1*"/>
|
||||||
<RowDefinition Height=".9*"/>
|
<RowDefinition Height=".9*"/>
|
||||||
@ -316,18 +449,54 @@
|
|||||||
</Grid.ColumnDefinitions>
|
</Grid.ColumnDefinitions>
|
||||||
<DockPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Row="0" Width="1100">
|
<DockPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Row="0" Width="1100">
|
||||||
<Image Height="50" Width="50" Name="WPFIcon" SnapsToDevicePixels="True" Source="https://christitus.com/images/logo-full.png" Margin="0,10,0,10"/>
|
<Image Height="50" Width="50" Name="WPFIcon" SnapsToDevicePixels="True" Source="https://christitus.com/images/logo-full.png" Margin="0,10,0,10"/>
|
||||||
<Button Content="Install" HorizontalAlignment="Left" Height="40" Width="100"
|
<ToggleButton HorizontalAlignment="Left" Height="40" Width="100"
|
||||||
Background="{ButtonInstallBackgroundColor}" Foreground="{ButtonInstallForegroundColor}" FontWeight="Bold" Name="WPFTab1BT"/>
|
Background="{ButtonInstallBackgroundColor}" Foreground="white" FontWeight="Bold" Name="WPFTab1BT">
|
||||||
<Button Content="Tweaks" HorizontalAlignment="Left" Height="40" Width="100"
|
<ToggleButton.Content>
|
||||||
Background="{ButtonTweaksBackgroundColor}" Foreground="{ButtonInstallForegroundColor}" FontWeight="Bold" Name="WPFTab2BT"/>
|
<TextBlock Background="Transparent" Foreground="{ButtonInstallForegroundColor}" >
|
||||||
<Button Content="Config" HorizontalAlignment="Left" Height="40" Width="100"
|
<Underline>I</Underline>nstall
|
||||||
Background="{ButtonConfigBackgroundColor}" Foreground="{ButtonInstallForegroundColor}" FontWeight="Bold" Name="WPFTab3BT"/>
|
</TextBlock>
|
||||||
<Button Content="Updates" HorizontalAlignment="Left" Height="40" Width="100"
|
</ToggleButton.Content>
|
||||||
Background="{ButtonUpdatesBackgroundColor}" Foreground="{ButtonInstallForegroundColor}" FontWeight="Bold" Name="WPFTab4BT"/>
|
</ToggleButton>
|
||||||
|
<ToggleButton HorizontalAlignment="Left" Height="40" Width="100"
|
||||||
|
Background="{ButtonTweaksBackgroundColor}" Foreground="{ButtonTweaksForegroundColor}" FontWeight="Bold" Name="WPFTab2BT">
|
||||||
|
<ToggleButton.Content>
|
||||||
|
<TextBlock Background="Transparent" Foreground="{ButtonTweaksForegroundColor}">
|
||||||
|
<Underline>T</Underline>weaks
|
||||||
|
</TextBlock>
|
||||||
|
</ToggleButton.Content>
|
||||||
|
</ToggleButton>
|
||||||
|
<ToggleButton HorizontalAlignment="Left" Height="40" Width="100"
|
||||||
|
Background="{ButtonConfigBackgroundColor}" Foreground="{ButtonConfigForegroundColor}" FontWeight="Bold" Name="WPFTab3BT">
|
||||||
|
<ToggleButton.Content>
|
||||||
|
<TextBlock Background="Transparent" Foreground="{ButtonConfigForegroundColor}">
|
||||||
|
<Underline>C</Underline>onfig
|
||||||
|
</TextBlock>
|
||||||
|
</ToggleButton.Content>
|
||||||
|
</ToggleButton>
|
||||||
|
<ToggleButton HorizontalAlignment="Left" Height="40" Width="100"
|
||||||
|
Background="{ButtonUpdatesBackgroundColor}" Foreground="{ButtonUpdatesForegroundColor}" FontWeight="Bold" Name="WPFTab4BT">
|
||||||
|
<ToggleButton.Content>
|
||||||
|
<TextBlock Background="Transparent" Foreground="{ButtonUpdatesForegroundColor}">
|
||||||
|
<Underline>U</Underline>pdates
|
||||||
|
</TextBlock>
|
||||||
|
</ToggleButton.Content>
|
||||||
|
</ToggleButton>
|
||||||
|
<ToggleButton HorizontalAlignment="Left" Height="40" Width="100"
|
||||||
|
Background="{ButtonUpdatesBackgroundColor}" Foreground="{ButtonUpdatesForegroundColor}" FontWeight="Bold" Name="WPFTab5BT">
|
||||||
|
<ToggleButton.Content>
|
||||||
|
<TextBlock Background="Transparent" Foreground="{ButtonUpdatesForegroundColor}">
|
||||||
|
<Underline>M</Underline>icroWin
|
||||||
|
</TextBlock>
|
||||||
|
</ToggleButton.Content>
|
||||||
|
</ToggleButton>
|
||||||
|
<TextBox VerticalContentAlignment="Center" HorizontalAlignment="Right" Name="CheckboxFilter" ToolTip="Press Ctrl-F and type app name to filter application list below. Press Esc to reset the filter"
|
||||||
|
Height="25" Width="200"
|
||||||
|
Foreground="{MainForegroundColor}" Background="{MainBackgroundColor}">Ctrl-F to filter</TextBox>
|
||||||
</DockPanel>
|
</DockPanel>
|
||||||
<TabControl Grid.Row="1" Padding="-1" Name="WPFTabNav" Background="#222222">
|
<ScrollViewer Grid.Row="1" Padding="-1" VerticalScrollBarVisibility="Auto" HorizontalScrollBarVisibility="Auto" Background="Transparent">
|
||||||
|
<TabControl Name="WPFTabNav" Background="#222222" Width="Auto" Height="Auto">
|
||||||
<TabItem Header="Install" Visibility="Collapsed" Name="WPFTab1">
|
<TabItem Header="Install" Visibility="Collapsed" Name="WPFTab1">
|
||||||
<Grid Background="#222222">
|
<Grid Background="Transparent">
|
||||||
<Grid.ColumnDefinitions>
|
<Grid.ColumnDefinitions>
|
||||||
<ColumnDefinition Width="*"/>
|
<ColumnDefinition Width="*"/>
|
||||||
<ColumnDefinition Width="*"/>
|
<ColumnDefinition Width="*"/>
|
||||||
@ -360,7 +529,9 @@
|
|||||||
<CheckBox Name="WPFInstallchromium" Content="Chromium" Margin="5,0"/>
|
<CheckBox Name="WPFInstallchromium" Content="Chromium" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalledge" Content="Edge" Margin="5,0"/>
|
<CheckBox Name="WPFInstalledge" Content="Edge" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallfirefox" Content="Firefox" Margin="5,0"/>
|
<CheckBox Name="WPFInstallfirefox" Content="Firefox" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallfloorp" Content="Floorp" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalllibrewolf" Content="LibreWolf" Margin="5,0"/>
|
<CheckBox Name="WPFInstalllibrewolf" Content="LibreWolf" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallmercury" Content="Mercury" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallthorium" Content="Thorium Browser" Margin="5,0"/>
|
<CheckBox Name="WPFInstallthorium" Content="Thorium Browser" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalltor" Content="Tor Browser" Margin="5,0"/>
|
<CheckBox Name="WPFInstalltor" Content="Tor Browser" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallvivaldi" Content="Vivaldi" Margin="5,0"/>
|
<CheckBox Name="WPFInstallvivaldi" Content="Vivaldi" Margin="5,0"/>
|
||||||
@ -371,6 +542,7 @@
|
|||||||
<CheckBox Name="WPFInstallguilded" Content="Guilded" Margin="5,0"/>
|
<CheckBox Name="WPFInstallguilded" Content="Guilded" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallhexchat" Content="Hexchat" Margin="5,0"/>
|
<CheckBox Name="WPFInstallhexchat" Content="Hexchat" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljami" Content="Jami" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljami" Content="Jami" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstalllinphone" Content="Linphone" Margin="5,0" />
|
||||||
<CheckBox Name="WPFInstallmatrix" Content="Matrix" Margin="5,0"/>
|
<CheckBox Name="WPFInstallmatrix" Content="Matrix" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallsession" Content="Session" Margin="5,0"/>
|
<CheckBox Name="WPFInstallsession" Content="Session" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallsignal" Content="Signal" Margin="5,0"/>
|
<CheckBox Name="WPFInstallsignal" Content="Signal" Margin="5,0"/>
|
||||||
@ -385,8 +557,10 @@
|
|||||||
<StackPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Row="1" Grid.Column="1" Margin="10">
|
<StackPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Row="1" Grid.Column="1" Margin="10">
|
||||||
<Label Content="Development" FontSize="16" Margin="5,0"/>
|
<Label Content="Development" FontSize="16" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljava20" Content="Azul Zulu JDK 20" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljava20" Content="Azul Zulu JDK 20" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallclink" Content="Clink" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalldockerdesktop" Content="Docker Desktop" Margin="5,0"/>
|
<CheckBox Name="WPFInstalldockerdesktop" Content="Docker Desktop" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallgit" Content="Git" Margin="5,0"/>
|
<CheckBox Name="WPFInstallgit" Content="Git" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallgitextensions" Content="Git Extensions" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallgithubdesktop" Content="GitHub Desktop" Margin="5,0"/>
|
<CheckBox Name="WPFInstallgithubdesktop" Content="GitHub Desktop" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallgolang" Content="GoLang" Margin="5,0"/>
|
<CheckBox Name="WPFInstallgolang" Content="GoLang" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljetbrains" Content="Jetbrains Toolbox" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljetbrains" Content="Jetbrains Toolbox" Margin="5,0"/>
|
||||||
@ -398,26 +572,33 @@
|
|||||||
<CheckBox Name="WPFInstalljava8" Content="OpenJDK Java 8" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljava8" Content="OpenJDK Java 8" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljava16" Content="OpenJDK Java 16" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljava16" Content="OpenJDK Java 16" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljava18" Content="Oracle Java 18" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljava18" Content="Oracle Java 18" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallposh" Content="Oh My Posh (Prompt)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallpython3" Content="Python3" Margin="5,0"/>
|
<CheckBox Name="WPFInstallpython3" Content="Python3" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallpostman" Content="Postman" Margin="5,0"/>
|
<CheckBox Name="WPFInstallpostman" Content="Postman" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallrustlang" Content="Rust" Margin="5,0"/>
|
<CheckBox Name="WPFInstallrustlang" Content="Rust" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallsublime" Content="Sublime" Margin="5,0"/>
|
<CheckBox Name="WPFInstallstarship" Content="Starship (Shell Prompt)" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallsublimemerge" Content="Sublime Merge" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallsublimetext" Content="Sublime Text" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallunity" Content="Unity Game Engine" Margin="5,0"/>
|
<CheckBox Name="WPFInstallunity" Content="Unity Game Engine" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallvisualstudio" Content="Visual Studio 2022" Margin="5,0"/>
|
<CheckBox Name="WPFInstallvisualstudio" Content="Visual Studio 2022" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallvscode" Content="VS Code" Margin="5,0"/>
|
<CheckBox Name="WPFInstallvscode" Content="VS Code" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallvscodium" Content="VS Codium" Margin="5,0"/>
|
<CheckBox Name="WPFInstallvscodium" Content="VS Codium" Margin="5,0"/>
|
||||||
|
|
||||||
<Label Content="Document" FontSize="16" Margin="5,0"/>
|
<Label Content="Document" FontSize="16" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallanki" Content="Anki" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalladobe" Content="Adobe Reader DC" Margin="5,0"/>
|
<CheckBox Name="WPFInstalladobe" Content="Adobe Reader DC" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallopenoffice" Content="Apache OpenOffice" Margin="5,0"/>
|
<CheckBox Name="WPFInstallopenoffice" Content="Apache OpenOffice" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallcalibre" Content="Calibre" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallfoxpdf" Content="Foxit PDF" Margin="5,0"/>
|
<CheckBox Name="WPFInstallfoxpdf" Content="Foxit PDF" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalljoplin" Content="Joplin (FOSS Notes)" Margin="5,0"/>
|
<CheckBox Name="WPFInstalljoplin" Content="Joplin (FOSS Notes)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalllibreoffice" Content="LibreOffice" Margin="5,0"/>
|
<CheckBox Name="WPFInstalllibreoffice" Content="LibreOffice" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallmasscode" Content="massCode (Snippet Manager)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallnaps2" Content="NAPS2 (Document Scanner)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallnaps2" Content="NAPS2 (Document Scanner)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallnotepadplus" Content="Notepad++" Margin="5,0"/>
|
<CheckBox Name="WPFInstallnotepadplus" Content="Notepad++" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallobsidian" Content="Obsidian" Margin="5,0"/>
|
<CheckBox Name="WPFInstallobsidian" Content="Obsidian" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallokular" Content="Okular" Margin="5,0"/>
|
<CheckBox Name="WPFInstallokular" Content="Okular" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallonlyoffice" Content="ONLYOffice Desktop" Margin="5,0"/>
|
<CheckBox Name="WPFInstallonlyoffice" Content="ONLYOffice Desktop" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallpdfsam" Content="PDFsam Basic" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallsumatra" Content="Sumatra PDF" Margin="5,0"/>
|
<CheckBox Name="WPFInstallsumatra" Content="Sumatra PDF" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallwinmerge" Content="WinMerge" Margin="5,0"/>
|
<CheckBox Name="WPFInstallwinmerge" Content="WinMerge" Margin="5,0"/>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
@ -454,6 +635,8 @@
|
|||||||
<CheckBox Name="WPFInstallaudacity" Content="Audacity" Margin="5,0"/>
|
<CheckBox Name="WPFInstallaudacity" Content="Audacity" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallblender" Content="Blender (3D Graphics)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallblender" Content="Blender (3D Graphics)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallcider" Content="Cider (FOSS Music Player)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallcider" Content="Cider (FOSS Music Player)" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallclipgrab" Content="Clipgrab" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallcopyq" Content="Copyq (Clipboard Manager)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalleartrumpet" Content="Eartrumpet (Audio)" Margin="5,0"/>
|
<CheckBox Name="WPFInstalleartrumpet" Content="Eartrumpet (Audio)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallflameshot" Content="Flameshot (Screenshots)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallflameshot" Content="Flameshot (Screenshots)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallfoobar" Content="Foobar2000 (Music Player)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallfoobar" Content="Foobar2000 (Music Player)" Margin="5,0"/>
|
||||||
@ -483,8 +666,11 @@
|
|||||||
|
|
||||||
<Label Content="Pro Tools" FontSize="16" Margin="5,0"/>
|
<Label Content="Pro Tools" FontSize="16" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalladvancedip" Content="Advanced IP Scanner" Margin="5,0"/>
|
<CheckBox Name="WPFInstalladvancedip" Content="Advanced IP Scanner" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallangryipscanner" Content="Angry IP Scanner" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallheidisql" Content="HeidiSQL" Margin="5,0" />
|
||||||
<CheckBox Name="WPFInstallmremoteng" Content="mRemoteNG" Margin="5,0"/>
|
<CheckBox Name="WPFInstallmremoteng" Content="mRemoteNG" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallOpenVPN" Content="OpenVPN Connect" Margin="5,0"/>
|
<CheckBox Name="WPFInstallOpenVPN" Content="OpenVPN Connect" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallportmaster" Content="Portmaster" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallputty" Content="Putty" Margin="5,0"/>
|
<CheckBox Name="WPFInstallputty" Content="Putty" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallrustdesk" Content="Rust Remote Desktop (FOSS)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallrustdesk" Content="Rust Remote Desktop (FOSS)" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallsimplewall" Content="SimpleWall" Margin="5,0"/>
|
<CheckBox Name="WPFInstallsimplewall" Content="SimpleWall" Margin="5,0"/>
|
||||||
@ -503,7 +689,9 @@
|
|||||||
<CheckBox Name="WPFInstallcpuz" Content="CPU-Z" Margin="5,0"/>
|
<CheckBox Name="WPFInstallcpuz" Content="CPU-Z" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallddu" Content="Display Driver Uninstaller" Margin="5,0"/>
|
<CheckBox Name="WPFInstallddu" Content="Display Driver Uninstaller" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalldeluge" Content="Deluge" Margin="5,0"/>
|
<CheckBox Name="WPFInstalldeluge" Content="Deluge" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstalldolphin" Content="Dolphin File manager" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallduplicati" Content="Duplicati 2" Margin="5,0"/>
|
<CheckBox Name="WPFInstallduplicati" Content="Duplicati 2" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstalldevtoys" Content="Devtoys" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstalletcher" Content="Etcher USB Creator" Margin="5,0"/>
|
<CheckBox Name="WPFInstalletcher" Content="Etcher USB Creator" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallesearch" Content="Everything Search" Margin="5,0"/>
|
<CheckBox Name="WPFInstallesearch" Content="Everything Search" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallflux" Content="f.lux Redshift" Margin="5,0"/>
|
<CheckBox Name="WPFInstallflux" Content="f.lux Redshift" Margin="5,0"/>
|
||||||
@ -518,9 +706,12 @@
|
|||||||
<CheckBox Name="WPFInstallmonitorian" Content="Monitorian" Margin="5,0"/>
|
<CheckBox Name="WPFInstallmonitorian" Content="Monitorian" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallmsiafterburner" Content="MSI Afterburner" Margin="5,0"/>
|
<CheckBox Name="WPFInstallmsiafterburner" Content="MSI Afterburner" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallnanazip" Content="NanaZip" Margin="5,0"/>
|
<CheckBox Name="WPFInstallnanazip" Content="NanaZip" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallnextclouddesktop" Content="Nextcloud Desktop" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallnvclean" Content="NVCleanstall" Margin="5,0"/>
|
<CheckBox Name="WPFInstallnvclean" Content="NVCleanstall" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallOVirtualBox" Content="Oracle VirtualBox" Margin="5,0"/>
|
<CheckBox Name="WPFInstallOVirtualBox" Content="Oracle VirtualBox" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallopenrgb" Content="OpenRGB" Margin="5,0" />
|
||||||
<CheckBox Name="WPFInstallopenshell" Content="Open Shell (Start Menu)" Margin="5,0"/>
|
<CheckBox Name="WPFInstallopenshell" Content="Open Shell (Start Menu)" Margin="5,0"/>
|
||||||
|
<CheckBox Name="WPFInstallownclouddesktop" Content="ownCloud Desktop" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallpeazip" Content="Peazip" Margin="5,0"/>
|
<CheckBox Name="WPFInstallpeazip" Content="Peazip" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallprocesslasso" Content="Process Lasso" Margin="5,0"/>
|
<CheckBox Name="WPFInstallprocesslasso" Content="Process Lasso" Margin="5,0"/>
|
||||||
<CheckBox Name="WPFInstallqbittorrent" Content="qBittorrent" Margin="5,0"/>
|
<CheckBox Name="WPFInstallqbittorrent" Content="qBittorrent" Margin="5,0"/>
|
||||||
@ -610,8 +801,8 @@
|
|||||||
<CheckBox Name="WPFMiscTweaksEnableipsix" Content="Enable IPv6" Margin="5,0" ToolTip="Enables IPv6."/>
|
<CheckBox Name="WPFMiscTweaksEnableipsix" Content="Enable IPv6" Margin="5,0" ToolTip="Enables IPv6."/>
|
||||||
|
|
||||||
<StackPanel Orientation="Horizontal" Margin="0,5,0,0">
|
<StackPanel Orientation="Horizontal" Margin="0,5,0,0">
|
||||||
<Label Content="DNS" />
|
<Label Content="DNS" HorizontalAlignment="Left" VerticalAlignment="Center"/>
|
||||||
<ComboBox Name="WPFchangedns" Height = "20" Width = "160" HorizontalAlignment = "Left" Margin="5,5">
|
<ComboBox Name="WPFchangedns" Height="32" Width="186" HorizontalAlignment="Left" VerticalAlignment="Center" Margin="5,5">
|
||||||
<ComboBoxItem IsSelected="True" Content = "Default"/>
|
<ComboBoxItem IsSelected="True" Content = "Default"/>
|
||||||
<ComboBoxItem Content = "DHCP"/>
|
<ComboBoxItem Content = "DHCP"/>
|
||||||
<ComboBoxItem Content = "Google"/>
|
<ComboBoxItem Content = "Google"/>
|
||||||
@ -654,7 +845,7 @@
|
|||||||
</StackPanel>
|
</StackPanel>
|
||||||
|
|
||||||
<StackPanel Orientation="Horizontal" Margin="0,10,0,0">
|
<StackPanel Orientation="Horizontal" Margin="0,10,0,0">
|
||||||
<Label Content="Show File Extentions" Style="{StaticResource labelfortweaks}" ToolTip="If enabled then File extensions (e.g., .txt, .jpg) are visible." />
|
<Label Content="Show File Extensions" Style="{StaticResource labelfortweaks}" ToolTip="If enabled then File extensions (e.g., .txt, .jpg) are visible." />
|
||||||
<CheckBox Name="WPFToggleShowExt" Style="{StaticResource ColorfulToggleSwitchStyle}" Margin="2.5,0"/>
|
<CheckBox Name="WPFToggleShowExt" Style="{StaticResource ColorfulToggleSwitchStyle}" Margin="2.5,0"/>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
|
|
||||||
@ -687,6 +878,7 @@
|
|||||||
<Button Name="WPFFixesUpdate" FontSize="14" Content="Reset Windows Update" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
<Button Name="WPFFixesUpdate" FontSize="14" Content="Reset Windows Update" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
||||||
<Button Name="WPFFixesNetwork" FontSize="14" Content="Reset Network" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
<Button Name="WPFFixesNetwork" FontSize="14" Content="Reset Network" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
||||||
<Button Name="WPFPanelDISM" FontSize="14" Content="System Corruption Scan" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
<Button Name="WPFPanelDISM" FontSize="14" Content="System Corruption Scan" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
||||||
|
<Button Name="WPFFixesWinget" FontSize="14" Content="WinGet Reinstall" HorizontalAlignment = "Left" Margin="5,2" Padding="20,5" Width="300"/>
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
<StackPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Column="1" Margin="10,5">
|
<StackPanel Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Column="1" Margin="10,5">
|
||||||
<Label Content="Legacy Windows Panels" FontSize="16"/>
|
<Label Content="Legacy Windows Panels" FontSize="16"/>
|
||||||
@ -719,13 +911,155 @@
|
|||||||
<Button Name="WPFUpdatesdisable" FontSize="16" Content="Disable ALL Updates (NOT RECOMMENDED!)" Margin="20,4,20,10" Padding="10,10,10,10"/>
|
<Button Name="WPFUpdatesdisable" FontSize="16" Content="Disable ALL Updates (NOT RECOMMENDED!)" Margin="20,4,20,10" Padding="10,10,10,10"/>
|
||||||
<TextBlock Margin="20,0,20,0" Padding="10" TextWrapping="WrapWithOverflow" MaxWidth="300">This completely disables ALL Windows Updates and is NOT RECOMMENDED.<LineBreak/><LineBreak/> However, it can be suitable if you use your system for a select purpose and do not actively browse the internet. <LineBreak/><LineBreak/>Note: Your system will be easier to hack and infect without security updates.</TextBlock>
|
<TextBlock Margin="20,0,20,0" Padding="10" TextWrapping="WrapWithOverflow" MaxWidth="300">This completely disables ALL Windows Updates and is NOT RECOMMENDED.<LineBreak/><LineBreak/> However, it can be suitable if you use your system for a select purpose and do not actively browse the internet. <LineBreak/><LineBreak/>Note: Your system will be easier to hack and infect without security updates.</TextBlock>
|
||||||
<TextBlock Text=" " Margin="20,0,20,0" Padding="10" TextWrapping="WrapWithOverflow" MaxWidth="300"/>
|
<TextBlock Text=" " Margin="20,0,20,0" Padding="10" TextWrapping="WrapWithOverflow" MaxWidth="300"/>
|
||||||
|
|
||||||
</StackPanel>
|
</StackPanel>
|
||||||
|
</Grid>
|
||||||
|
</TabItem>
|
||||||
|
<TabItem Header="MicroWin" Visibility="Collapsed" Name="WPFTab5" Width="Auto" Height="Auto">
|
||||||
|
<Grid Width="Auto" Height="Auto">
|
||||||
|
<Grid.ColumnDefinitions>
|
||||||
|
<ColumnDefinition Width="*"/>
|
||||||
|
<ColumnDefinition Width="4*"/>
|
||||||
|
</Grid.ColumnDefinitions>
|
||||||
|
<Grid.RowDefinitions>
|
||||||
|
<RowDefinition Height="*" />
|
||||||
|
</Grid.RowDefinitions>
|
||||||
|
<Border BorderBrush="Yellow" CornerRadius="2" BorderThickness="2" Margin="1" Grid.Row="0" Grid.Column="0">
|
||||||
|
<StackPanel Name="MicrowinMain" Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Grid.Column="0" Grid.Row="0">
|
||||||
|
<StackPanel Background="Transparent" SnapsToDevicePixels="True" Margin="1">
|
||||||
|
<TextBlock Margin="1" Padding="1" TextWrapping="Wrap" Foreground="{ComboBoxForegroundColor}">
|
||||||
|
Choose a Windows ISO file that you've downloaded. <LineBreak/>
|
||||||
|
Check for status in the console.
|
||||||
|
</TextBlock>
|
||||||
|
<TextBox Name="MicrowinFinalIsoLocation" Background="Transparent" BorderThickness="1" BorderBrush="{MainForegroundColor}"
|
||||||
|
Text="ISO location will be printed here"
|
||||||
|
IsReadOnly="True"
|
||||||
|
TextWrapping="Wrap"
|
||||||
|
Foreground="{LabelboxForegroundColor}"
|
||||||
|
/>
|
||||||
|
<Button Name="WPFGetIso" Margin="2" Padding="15">
|
||||||
|
<Button.Content>
|
||||||
|
<TextBlock Background="Transparent" Foreground="{ButtonForegroundColor}">
|
||||||
|
Select Windows <Underline>I</Underline>SO
|
||||||
|
</TextBlock>
|
||||||
|
</Button.Content>
|
||||||
|
</Button>
|
||||||
|
</StackPanel>
|
||||||
|
<!-- Visibility="Hidden" -->
|
||||||
|
<StackPanel Name="MicrowinOptionsPanel" HorizontalAlignment="Left" SnapsToDevicePixels="True" Margin="1" Visibility="Hidden">
|
||||||
|
<TextBlock Margin="6" Padding="1" TextWrapping="Wrap">Chose Windows SKU</TextBlock>
|
||||||
|
<ComboBox x:Name = "MicrowinWindowsFlavors" Margin="1" />
|
||||||
|
<TextBlock Margin="6" Padding="1" TextWrapping="Wrap">Choose Windows features you want to remove from the ISO</TextBlock>
|
||||||
|
<CheckBox Name="WPFMicrowinKeepProvisionedPackages" Content="Keep Provisioned Packages" Margin="5,0" ToolTip="Do not remove Microsoft Provisioned packages from the ISO."/>
|
||||||
|
<CheckBox Name="WPFMicrowinKeepAppxPackages" Content="Keep Appx Packages" Margin="5,0" ToolTip="Do not remove Microsoft Appx packages from the ISO."/>
|
||||||
|
<CheckBox Name="WPFMicrowinKeepDefender" Content="Keep Defender" Margin="5,0" IsChecked="True" ToolTip="Do not remove Microsoft Antivirus from the ISO."/>
|
||||||
|
<CheckBox Name="WPFMicrowinKeepEdge" Content="Keep Edge" Margin="5,0" IsChecked="True" ToolTip="Do not remove Microsoft Edge from the ISO."/>
|
||||||
|
<Rectangle Fill="{MainForegroundColor}" Height="2" HorizontalAlignment="Stretch" Margin="0,10,0,10"/>
|
||||||
|
<CheckBox Name="MicrowinInjectDrivers" Content="Inject drivers (I KNOW WHAT I'M DOING)" Margin="5,0" IsChecked="False" ToolTip="Path to unpacked drivers all sys and inf files for devices that need drivers"/>
|
||||||
|
<TextBox Name="MicrowinDriverLocation" Background="Transparent" BorderThickness="1" BorderBrush="{MainForegroundColor}"
|
||||||
|
Margin="6"
|
||||||
|
Text=""
|
||||||
|
IsReadOnly="False"
|
||||||
|
TextWrapping="Wrap"
|
||||||
|
Foreground="{LabelboxForegroundColor}"
|
||||||
|
ToolTip="Path to unpacked drivers all sys and inf files for devices that need drivers"
|
||||||
|
/>
|
||||||
|
<Rectangle Fill="{MainForegroundColor}" Height="2" HorizontalAlignment="Stretch" Margin="0,10,0,10"/>
|
||||||
|
<CheckBox Name="WPFMicrowinCopyToUsb" Content="Copy to Ventoy" Margin="5,0" IsChecked="False" ToolTip="Copy to USB disk with a label Ventoy"/>
|
||||||
|
<Rectangle Fill="{MainForegroundColor}" Height="2" HorizontalAlignment="Stretch" Margin="0,10,0,10"/>
|
||||||
|
<Button Name="WPFMicrowin" Content="Start the process" Margin="2" Padding="15"/>
|
||||||
|
</StackPanel>
|
||||||
|
<StackPanel HorizontalAlignment="Left" SnapsToDevicePixels="True" Margin="1" Visibility="Collapsed">
|
||||||
|
<TextBlock Name="MicrowinIsoDrive" VerticalAlignment="Center" Margin="1" Padding="1" TextWrapping="WrapWithOverflow" Foreground="{ComboBoxForegroundColor}"/>
|
||||||
|
<TextBlock Name="MicrowinIsoLocation" VerticalAlignment="Center" Margin="1" Padding="1" TextWrapping="WrapWithOverflow" Foreground="{ComboBoxForegroundColor}"/>
|
||||||
|
<TextBlock Name="MicrowinMountDir" VerticalAlignment="Center" Margin="1" Padding="1" TextWrapping="WrapWithOverflow" Foreground="{ComboBoxForegroundColor}"/>
|
||||||
|
<TextBlock Name="MicrowinScratchDir" VerticalAlignment="Center" Margin="1" Padding="1" TextWrapping="WrapWithOverflow" Foreground="{ComboBoxForegroundColor}"/>
|
||||||
|
</StackPanel>
|
||||||
|
</StackPanel>
|
||||||
|
</Border>
|
||||||
|
<Border Background="{MainBackgroundColor}"
|
||||||
|
VerticalAlignment="Stretch"
|
||||||
|
HorizontalAlignment="Stretch"
|
||||||
|
BorderBrush="Yellow"
|
||||||
|
CornerRadius="2"
|
||||||
|
BorderThickness="2"
|
||||||
|
Grid.Row="0" Grid.Column="1"
|
||||||
|
Margin="1">
|
||||||
|
<StackPanel HorizontalAlignment="Left" Background="{MainBackgroundColor}" SnapsToDevicePixels="True" Visibility="Visible"
|
||||||
|
>
|
||||||
|
<TextBlock x:Name = "asciiTextBlock"
|
||||||
|
xml:space ="preserve"
|
||||||
|
HorizontalAlignment = "Center"
|
||||||
|
Margin = "0"
|
||||||
|
VerticalAlignment = "Top"
|
||||||
|
Height = "Auto"
|
||||||
|
Width = "Auto"
|
||||||
|
FontSize = "10"
|
||||||
|
FontFamily = "Courier New"
|
||||||
|
>
|
||||||
|
/\/\ (_) ___ _ __ ___ / / /\ \ \(_) _ __
|
||||||
|
/ \ | | / __|| '__| / _ \ \ \/ \/ /| || '_ \
|
||||||
|
/ /\/\ \| || (__ | | | (_) | \ /\ / | || | | |
|
||||||
|
\/ \/|_| \___||_| \___/ \/ \/ |_||_| |_|
|
||||||
|
</TextBlock>
|
||||||
|
<TextBlock Margin="15,15,15,0"
|
||||||
|
Padding="8,8,8,0"
|
||||||
|
VerticalAlignment="Center"
|
||||||
|
TextWrapping="WrapWithOverflow"
|
||||||
|
Height = "Auto"
|
||||||
|
Width = "Auto"
|
||||||
|
Foreground="{ComboBoxForegroundColor}">
|
||||||
|
<Bold>MicroWin features:</Bold><LineBreak/>
|
||||||
|
- Remove Telemetry and Tracking <LineBreak/>
|
||||||
|
- Add ability to use local accounts <LineBreak/>
|
||||||
|
- Remove Wifi requirement to finish install <LineBreak/>
|
||||||
|
- Ability to remove Edge <LineBreak/>
|
||||||
|
- Ability to remove Defender <LineBreak/>
|
||||||
|
- Remove Teams <LineBreak/>
|
||||||
|
- Apps debloat <LineBreak/>
|
||||||
|
<LineBreak/>
|
||||||
|
<LineBreak/>
|
||||||
|
|
||||||
|
<Bold>INSTRUCTIONS</Bold> <LineBreak/>
|
||||||
|
- Download latest Windows 11 image from Microsoft <LineBreak/>
|
||||||
|
https://www.microsoft.com/software-download/windows11
|
||||||
|
several minutes to process the ISO depending on your machine. <LineBreak/>
|
||||||
|
- Put it somewhere on the C: drive so it is easily accessible <LineBreak/>
|
||||||
|
- Launch WinUtil and MicroWin <LineBreak/>
|
||||||
|
- Click on Get Iso image button and wait for WinUtil to process the Image <LineBreak/>
|
||||||
|
It will be processed and unpacked which could take some time <LineBreak/>
|
||||||
|
- Once done, chose which Windows flavor you want to base your image on <LineBreak/>
|
||||||
|
- Chose which features you want to keep <LineBreak/>
|
||||||
|
- Click Start Process button <LineBreak/>
|
||||||
|
NOTE: Process of creating Windows image will take a long time, please check the Console and wait for it to say "Done" <LineBreak/>
|
||||||
|
<Bold>Once it is done the microwin.iso will be in the %temp% directory</Bold> <LineBreak/>
|
||||||
|
Copy this image to your Ventoy USB Stick, boot to this image. gg,
|
||||||
|
<LineBreak/>
|
||||||
|
If you are injecting drivers make sure to put all your inf, sys and dll file for each driver into a separate directory. For example:
|
||||||
|
</TextBlock>
|
||||||
|
<TextBlock Margin="15,0,15,15"
|
||||||
|
Padding = "1"
|
||||||
|
TextWrapping="WrapWithOverflow"
|
||||||
|
Height = "Auto"
|
||||||
|
Width = "Auto"
|
||||||
|
VerticalAlignment = "Top"
|
||||||
|
Foreground = "{ComboBoxForegroundColor}"
|
||||||
|
xml:space = "preserve"
|
||||||
|
>
|
||||||
|
C:\drivers\
|
||||||
|
|-- Driver1\
|
||||||
|
| |-- Driver1.inf
|
||||||
|
| |-- Driver1.sys
|
||||||
|
|-- Driver2\
|
||||||
|
| |-- Driver2.inf
|
||||||
|
| |-- Driver2.sys
|
||||||
|
|-- OtherFiles...
|
||||||
|
</TextBlock>
|
||||||
|
</StackPanel>
|
||||||
|
</Border>
|
||||||
</Grid>
|
</Grid>
|
||||||
</TabItem>
|
</TabItem>
|
||||||
</TabControl>
|
</TabControl>
|
||||||
|
</ScrollViewer>
|
||||||
</Grid>
|
</Grid>
|
||||||
</Viewbox>
|
|
||||||
</Border>
|
</Border>
|
||||||
</Window>
|
</Window>
|
||||||
|
Loading…
Reference in New Issue
Block a user