@fredlackey/devutils 0.0.1 → 0.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +5 -5
- package/package.json +1 -1
- package/src/commands/install.js +374 -36
- package/src/installs/adobe-creative-cloud.js +527 -25
- package/src/installs/adobe-creative-cloud.md +605 -0
- package/src/installs/appcleaner.js +303 -26
- package/src/installs/appcleaner.md +699 -0
- package/src/installs/apt-transport-https.js +390 -0
- package/src/installs/apt-transport-https.md +678 -0
- package/src/installs/atomicparsley.js +624 -26
- package/src/installs/atomicparsley.md +795 -0
- package/src/installs/aws-cli.js +779 -26
- package/src/installs/aws-cli.md +727 -0
- package/src/installs/balena-etcher.js +688 -26
- package/src/installs/balena-etcher.md +761 -0
- package/src/installs/bambu-studio.js +912 -26
- package/src/installs/bambu-studio.md +780 -0
- package/src/installs/bash-completion.js +554 -23
- package/src/installs/bash-completion.md +833 -0
- package/src/installs/bash.js +399 -26
- package/src/installs/bash.md +993 -0
- package/src/installs/beyond-compare.js +585 -26
- package/src/installs/beyond-compare.md +813 -0
- package/src/installs/build-essential.js +511 -26
- package/src/installs/build-essential.md +977 -0
- package/src/installs/ca-certificates.js +618 -0
- package/src/installs/ca-certificates.md +937 -0
- package/src/installs/caffeine.js +490 -26
- package/src/installs/caffeine.md +839 -0
- package/src/installs/camtasia.js +577 -25
- package/src/installs/camtasia.md +762 -0
- package/src/installs/chatgpt.js +458 -26
- package/src/installs/chatgpt.md +814 -0
- package/src/installs/chocolatey.js +447 -0
- package/src/installs/chocolatey.md +661 -0
- package/src/installs/chrome-canary.js +472 -26
- package/src/installs/chrome-canary.md +641 -0
- package/src/installs/chromium.js +645 -26
- package/src/installs/chromium.md +838 -0
- package/src/installs/claude-code.js +558 -26
- package/src/installs/claude-code.md +1173 -0
- package/src/installs/curl.js +361 -26
- package/src/installs/curl.md +714 -0
- package/src/installs/cursor.js +561 -26
- package/src/installs/cursor.md +970 -0
- package/src/installs/dbschema.js +674 -26
- package/src/installs/dbschema.md +925 -0
- package/src/installs/dependencies.md +435 -0
- package/src/installs/development-tools.js +600 -0
- package/src/installs/development-tools.md +977 -0
- package/src/installs/docker.js +1010 -25
- package/src/installs/docker.md +1109 -0
- package/src/installs/drawio.js +1001 -26
- package/src/installs/drawio.md +795 -0
- package/src/installs/elmedia-player.js +328 -25
- package/src/installs/elmedia-player.md +556 -0
- package/src/installs/ffmpeg.js +870 -25
- package/src/installs/ffmpeg.md +852 -0
- package/src/installs/file.js +464 -0
- package/src/installs/file.md +987 -0
- package/src/installs/gemini-cli.js +793 -26
- package/src/installs/gemini-cli.md +1153 -0
- package/src/installs/git.js +382 -26
- package/src/installs/git.md +907 -0
- package/src/installs/gitego.js +931 -26
- package/src/installs/gitego.md +1172 -0
- package/src/installs/go.js +913 -26
- package/src/installs/go.md +958 -0
- package/src/installs/google-chrome.js +801 -25
- package/src/installs/google-chrome.md +862 -0
- package/src/installs/gpg.js +412 -73
- package/src/installs/gpg.md +1056 -0
- package/src/installs/homebrew.js +1015 -26
- package/src/installs/homebrew.md +988 -0
- package/src/installs/imageoptim.js +950 -26
- package/src/installs/imageoptim.md +1119 -0
- package/src/installs/installers.json +2297 -0
- package/src/installs/jq.js +382 -26
- package/src/installs/jq.md +809 -0
- package/src/installs/keyboard-maestro.js +701 -26
- package/src/installs/keyboard-maestro.md +825 -0
- package/src/installs/latex.js +771 -26
- package/src/installs/latex.md +1095 -0
- package/src/installs/lftp.js +338 -26
- package/src/installs/lftp.md +907 -0
- package/src/installs/lsb-release.js +346 -0
- package/src/installs/lsb-release.md +814 -0
- package/src/installs/messenger.js +829 -26
- package/src/installs/messenger.md +900 -0
- package/src/installs/microsoft-office.js +550 -26
- package/src/installs/microsoft-office.md +760 -0
- package/src/installs/microsoft-teams.js +782 -25
- package/src/installs/microsoft-teams.md +886 -0
- package/src/installs/node.js +886 -26
- package/src/installs/node.md +1153 -0
- package/src/installs/nordpass.js +698 -26
- package/src/installs/nordpass.md +921 -0
- package/src/installs/nvm.js +977 -26
- package/src/installs/nvm.md +1057 -0
- package/src/installs/openssh.js +734 -64
- package/src/installs/openssh.md +1056 -0
- package/src/installs/pandoc.js +644 -26
- package/src/installs/pandoc.md +1036 -0
- package/src/installs/pinentry.js +492 -26
- package/src/installs/pinentry.md +1142 -0
- package/src/installs/pngyu.js +851 -26
- package/src/installs/pngyu.md +896 -0
- package/src/installs/postman.js +781 -26
- package/src/installs/postman.md +940 -0
- package/src/installs/procps.js +425 -0
- package/src/installs/procps.md +851 -0
- package/src/installs/safari-tech-preview.js +355 -25
- package/src/installs/safari-tech-preview.md +533 -0
- package/src/installs/sfnt2woff.js +640 -26
- package/src/installs/sfnt2woff.md +795 -0
- package/src/installs/shellcheck.js +463 -26
- package/src/installs/shellcheck.md +1005 -0
- package/src/installs/slack.js +722 -25
- package/src/installs/slack.md +865 -0
- package/src/installs/snagit.js +566 -25
- package/src/installs/snagit.md +844 -0
- package/src/installs/software-properties-common.js +372 -0
- package/src/installs/software-properties-common.md +805 -0
- package/src/installs/spotify.js +858 -25
- package/src/installs/spotify.md +901 -0
- package/src/installs/studio-3t.js +803 -26
- package/src/installs/studio-3t.md +918 -0
- package/src/installs/sublime-text.js +780 -25
- package/src/installs/sublime-text.md +914 -0
- package/src/installs/superwhisper.js +687 -25
- package/src/installs/superwhisper.md +630 -0
- package/src/installs/tailscale.js +727 -26
- package/src/installs/tailscale.md +1100 -0
- package/src/installs/tar.js +389 -0
- package/src/installs/tar.md +946 -0
- package/src/installs/termius.js +780 -26
- package/src/installs/termius.md +844 -0
- package/src/installs/terraform.js +761 -26
- package/src/installs/terraform.md +899 -0
- package/src/installs/tidal.js +752 -25
- package/src/installs/tidal.md +864 -0
- package/src/installs/tmux.js +328 -26
- package/src/installs/tmux.md +1030 -0
- package/src/installs/tree.js +393 -26
- package/src/installs/tree.md +833 -0
- package/src/installs/unzip.js +460 -0
- package/src/installs/unzip.md +879 -0
- package/src/installs/vim.js +403 -26
- package/src/installs/vim.md +1040 -0
- package/src/installs/vlc.js +803 -26
- package/src/installs/vlc.md +927 -0
- package/src/installs/vscode.js +825 -26
- package/src/installs/vscode.md +1002 -0
- package/src/installs/wget.js +415 -0
- package/src/installs/wget.md +791 -0
- package/src/installs/whatsapp.js +710 -25
- package/src/installs/whatsapp.md +854 -0
- package/src/installs/winpty.js +352 -0
- package/src/installs/winpty.md +620 -0
- package/src/installs/woff2.js +535 -26
- package/src/installs/woff2.md +977 -0
- package/src/installs/wsl.js +572 -0
- package/src/installs/wsl.md +699 -0
- package/src/installs/xcode-clt.js +520 -0
- package/src/installs/xcode-clt.md +351 -0
- package/src/installs/xcode.js +542 -26
- package/src/installs/xcode.md +573 -0
- package/src/installs/yarn.js +806 -26
- package/src/installs/yarn.md +1074 -0
- package/src/installs/yq.js +636 -26
- package/src/installs/yq.md +944 -0
- package/src/installs/yt-dlp.js +683 -26
- package/src/installs/yt-dlp.md +946 -0
- package/src/installs/yum-utils.js +297 -0
- package/src/installs/yum-utils.md +648 -0
- package/src/installs/zoom.js +740 -25
- package/src/installs/zoom.md +884 -0
- package/src/scripts/README.md +567 -45
- package/src/scripts/STATUS.md +208 -0
- package/src/scripts/afk.js +395 -7
- package/src/scripts/backup-all.js +731 -9
- package/src/scripts/backup-source.js +711 -8
- package/src/scripts/brewd.js +373 -7
- package/src/scripts/brewi.js +505 -9
- package/src/scripts/brewr.js +512 -9
- package/src/scripts/brews.js +462 -9
- package/src/scripts/brewu.js +488 -7
- package/src/scripts/c.js +185 -7
- package/src/scripts/ccurl.js +325 -8
- package/src/scripts/certbot-crontab-init.js +488 -8
- package/src/scripts/certbot-init.js +641 -9
- package/src/scripts/ch.js +339 -7
- package/src/scripts/claude-danger.js +253 -8
- package/src/scripts/clean-dev.js +419 -8
- package/src/scripts/clear-dns-cache.js +525 -7
- package/src/scripts/clone.js +417 -7
- package/src/scripts/code-all.js +420 -7
- package/src/scripts/count-files.js +195 -8
- package/src/scripts/count-folders.js +195 -8
- package/src/scripts/count.js +248 -8
- package/src/scripts/d.js +203 -7
- package/src/scripts/datauri.js +373 -8
- package/src/scripts/delete-files.js +363 -7
- package/src/scripts/docker-clean.js +410 -8
- package/src/scripts/dp.js +426 -7
- package/src/scripts/e.js +375 -9
- package/src/scripts/empty-trash.js +497 -7
- package/src/scripts/evm.js +428 -9
- package/src/scripts/fetch-github-repos.js +441 -10
- package/src/scripts/get-channel.js +329 -8
- package/src/scripts/get-course.js +384 -11
- package/src/scripts/get-dependencies.js +290 -9
- package/src/scripts/get-folder.js +783 -10
- package/src/scripts/get-tunes.js +411 -10
- package/src/scripts/get-video.js +352 -9
- package/src/scripts/git-backup.js +561 -9
- package/src/scripts/git-clone.js +477 -9
- package/src/scripts/git-pup.js +303 -7
- package/src/scripts/git-push.js +380 -8
- package/src/scripts/h.js +607 -9
- package/src/scripts/hide-desktop-icons.js +483 -7
- package/src/scripts/hide-hidden-files.js +522 -7
- package/src/scripts/install-dependencies-from.js +440 -9
- package/src/scripts/ips.js +647 -10
- package/src/scripts/iso.js +354 -8
- package/src/scripts/killni.js +561 -7
- package/src/scripts/ll.js +451 -8
- package/src/scripts/local-ip.js +310 -8
- package/src/scripts/m.js +508 -8
- package/src/scripts/map.js +293 -8
- package/src/scripts/mkd.js +287 -7
- package/src/scripts/ncu-update-all.js +441 -8
- package/src/scripts/nginx-init.js +702 -12
- package/src/scripts/npmi.js +366 -7
- package/src/scripts/o.js +495 -8
- package/src/scripts/org-by-date.js +321 -7
- package/src/scripts/p.js +208 -7
- package/src/scripts/packages.js +313 -8
- package/src/scripts/path.js +209 -7
- package/src/scripts/ports.js +582 -8
- package/src/scripts/q.js +290 -8
- package/src/scripts/refresh-files.js +378 -10
- package/src/scripts/remove-smaller-files.js +500 -8
- package/src/scripts/rename-files-with-date.js +517 -9
- package/src/scripts/resize-image.js +523 -9
- package/src/scripts/rm-safe.js +653 -8
- package/src/scripts/s.js +525 -9
- package/src/scripts/set-git-public.js +349 -7
- package/src/scripts/show-desktop-icons.js +459 -7
- package/src/scripts/show-hidden-files.js +456 -7
- package/src/scripts/tpa.js +265 -8
- package/src/scripts/tpo.js +264 -7
- package/src/scripts/u.js +489 -7
- package/src/scripts/vpush.js +422 -8
- package/src/scripts/y.js +267 -7
- package/src/utils/common/os.js +94 -2
- package/src/utils/ubuntu/apt.js +13 -7
- package/src/utils/windows/choco.js +82 -26
- package/src/utils/windows/winget.js +89 -27
|
@@ -1,23 +1,499 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
|
|
3
3
|
/**
|
|
4
|
-
*
|
|
4
|
+
* hide-desktop-icons - Hide all icons on the desktop
|
|
5
|
+
*
|
|
6
|
+
* Migrated from legacy dotfiles alias.
|
|
7
|
+
* Original aliases:
|
|
8
|
+
* macOS: alias hide-desktop-icons="defaults write com.apple.finder CreateDesktop -bool false && killall Finder"
|
|
9
|
+
* Ubuntu: alias hide-desktop-icons="gsettings set org.gnome.desktop.background show-desktop-icons false" (commented)
|
|
10
|
+
*
|
|
11
|
+
* This script hides all icons on the desktop. The method varies by platform:
|
|
12
|
+
* - macOS: Modifies Finder preferences to disable the desktop and restarts Finder
|
|
13
|
+
* - Linux (GNOME): Uses gsettings to hide desktop icons
|
|
14
|
+
* - Linux (Other DEs): Uses appropriate desktop environment settings
|
|
15
|
+
* - Windows: Toggles desktop icons visibility through registry or COM objects
|
|
16
|
+
*
|
|
17
|
+
* Note: This is a desktop-specific operation that requires a graphical environment.
|
|
18
|
+
* On headless servers, this command will display an informative message.
|
|
19
|
+
*
|
|
5
20
|
* @module scripts/hide-desktop-icons
|
|
6
21
|
*/
|
|
7
22
|
|
|
23
|
+
const os = require('../utils/common/os');
|
|
24
|
+
const { execSync } = require('child_process');
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Helper function to check if a command exists on the system.
|
|
28
|
+
* Used to detect which desktop tools are available.
|
|
29
|
+
*
|
|
30
|
+
* @param {string} cmd - The command name to check
|
|
31
|
+
* @returns {boolean} True if the command exists, false otherwise
|
|
32
|
+
*/
|
|
33
|
+
function isCommandAvailable(cmd) {
|
|
34
|
+
try {
|
|
35
|
+
// Use 'which' on Unix-like systems, 'where' on Windows
|
|
36
|
+
const checkCmd = process.platform === 'win32' ? `where ${cmd}` : `which ${cmd}`;
|
|
37
|
+
execSync(checkCmd, { stdio: 'ignore' });
|
|
38
|
+
return true;
|
|
39
|
+
} catch {
|
|
40
|
+
return false;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
/**
|
|
45
|
+
* Pure Node.js implementation - NOT APPLICABLE for this script.
|
|
46
|
+
*
|
|
47
|
+
* Hiding desktop icons requires OS-level integration that cannot be done in pure Node.js.
|
|
48
|
+
* Each platform has its own mechanism for controlling desktop icon visibility:
|
|
49
|
+
* - macOS uses the defaults command to modify Finder preferences
|
|
50
|
+
* - Linux uses gsettings, dconf, or desktop environment-specific tools
|
|
51
|
+
* - Windows uses registry edits or shell COM objects
|
|
52
|
+
*
|
|
53
|
+
* @param {string[]} args - Command line arguments (unused)
|
|
54
|
+
* @returns {Promise<void>}
|
|
55
|
+
* @throws {Error} Always throws - this function should not be called directly
|
|
56
|
+
*/
|
|
57
|
+
async function do_hide_desktop_icons_nodejs(args) {
|
|
58
|
+
// Desktop icon visibility is inherently platform-specific and cannot be
|
|
59
|
+
// implemented in pure Node.js. Each platform function contains the
|
|
60
|
+
// appropriate system calls.
|
|
61
|
+
throw new Error(
|
|
62
|
+
'do_hide_desktop_icons_nodejs should not be called directly. ' +
|
|
63
|
+
'Desktop icon control requires OS-specific commands.'
|
|
64
|
+
);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Hide desktop icons on macOS by modifying Finder preferences.
|
|
69
|
+
*
|
|
70
|
+
* Uses the original dotfiles approach:
|
|
71
|
+
* 1. Write 'CreateDesktop' preference to false in com.apple.finder
|
|
72
|
+
* 2. Restart Finder to apply the change
|
|
73
|
+
*
|
|
74
|
+
* The CreateDesktop preference controls whether Finder draws icons on the desktop.
|
|
75
|
+
* When set to false, the desktop appears clean with no icons, though the files
|
|
76
|
+
* still exist in ~/Desktop.
|
|
77
|
+
*
|
|
78
|
+
* @param {string[]} args - Command line arguments (unused)
|
|
79
|
+
* @returns {Promise<void>}
|
|
80
|
+
*/
|
|
81
|
+
async function do_hide_desktop_icons_macos(args) {
|
|
82
|
+
try {
|
|
83
|
+
// Step 1: Write the preference to disable desktop icons
|
|
84
|
+
// This tells Finder not to render any icons on the desktop surface
|
|
85
|
+
execSync('defaults write com.apple.finder CreateDesktop -bool false', {
|
|
86
|
+
stdio: 'inherit'
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
// Step 2: Restart Finder to apply the changes
|
|
90
|
+
// Finder must be restarted for the preference change to take effect
|
|
91
|
+
execSync('killall Finder', { stdio: 'inherit' });
|
|
92
|
+
|
|
93
|
+
console.log('Desktop icons are now hidden.');
|
|
94
|
+
console.log('To show them again, run: show-desktop-icons');
|
|
95
|
+
} catch (error) {
|
|
96
|
+
console.error('Error: Could not hide desktop icons.');
|
|
97
|
+
console.error('Make sure you have the necessary permissions.');
|
|
98
|
+
process.exit(1);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
/**
|
|
103
|
+
* Hide desktop icons on Ubuntu using gsettings or dconf.
|
|
104
|
+
*
|
|
105
|
+
* Ubuntu with GNOME has changed how desktop icons work over the versions:
|
|
106
|
+
* - Ubuntu 18.04 and earlier: org.gnome.desktop.background show-desktop-icons
|
|
107
|
+
* - Ubuntu 20.04+: Desktop icons handled by GNOME Shell extension
|
|
108
|
+
* - Modern GNOME: org.gnome.shell.extensions.desktop-icons or ding extension
|
|
109
|
+
*
|
|
110
|
+
* This function tries multiple approaches in order of preference.
|
|
111
|
+
*
|
|
112
|
+
* @param {string[]} args - Command line arguments (unused)
|
|
113
|
+
* @returns {Promise<void>}
|
|
114
|
+
*/
|
|
115
|
+
async function do_hide_desktop_icons_ubuntu(args) {
|
|
116
|
+
// Check if we have a desktop environment available
|
|
117
|
+
const hasDesktop = os.isDesktopAvailable();
|
|
118
|
+
|
|
119
|
+
if (!hasDesktop) {
|
|
120
|
+
console.log('No desktop environment detected.');
|
|
121
|
+
console.log('This command is designed for graphical environments.');
|
|
122
|
+
console.log('');
|
|
123
|
+
console.log('Desktop icons can only be hidden on systems with a GUI.');
|
|
124
|
+
return;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
// Check if gsettings is available
|
|
128
|
+
if (!isCommandAvailable('gsettings')) {
|
|
129
|
+
console.error('Error: gsettings command not found.');
|
|
130
|
+
console.error('This command requires GNOME desktop environment tools.');
|
|
131
|
+
console.error('');
|
|
132
|
+
console.error('Install with: sudo apt install libglib2.0-bin');
|
|
133
|
+
process.exit(1);
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
// Try different approaches for different GNOME versions
|
|
137
|
+
const hideCommands = [
|
|
138
|
+
// Modern GNOME with desktop-icons-ng (ding) extension (Ubuntu 20.04+)
|
|
139
|
+
{
|
|
140
|
+
cmd: 'gsettings set org.gnome.shell.extensions.ding show-home false && gsettings set org.gnome.shell.extensions.ding show-trash false && gsettings set org.gnome.shell.extensions.ding show-volumes false',
|
|
141
|
+
description: 'GNOME desktop-icons-ng extension'
|
|
142
|
+
},
|
|
143
|
+
// Older GNOME with desktop-icons extension
|
|
144
|
+
{
|
|
145
|
+
cmd: 'gsettings set org.gnome.shell.extensions.desktop-icons show-home false && gsettings set org.gnome.shell.extensions.desktop-icons show-trash false',
|
|
146
|
+
description: 'GNOME desktop-icons extension'
|
|
147
|
+
},
|
|
148
|
+
// Legacy GNOME (Ubuntu 18.04 and earlier)
|
|
149
|
+
{
|
|
150
|
+
cmd: 'gsettings set org.gnome.desktop.background show-desktop-icons false',
|
|
151
|
+
description: 'Legacy GNOME desktop icons'
|
|
152
|
+
},
|
|
153
|
+
// Nautilus desktop (some configurations)
|
|
154
|
+
{
|
|
155
|
+
cmd: 'gsettings set org.gnome.nautilus.desktop volumes-visible false && gsettings set org.gnome.nautilus.desktop home-icon-visible false && gsettings set org.gnome.nautilus.desktop trash-icon-visible false',
|
|
156
|
+
description: 'Nautilus desktop'
|
|
157
|
+
}
|
|
158
|
+
];
|
|
159
|
+
|
|
160
|
+
let success = false;
|
|
161
|
+
|
|
162
|
+
for (const approach of hideCommands) {
|
|
163
|
+
try {
|
|
164
|
+
execSync(approach.cmd, { stdio: 'pipe', encoding: 'utf8' });
|
|
165
|
+
console.log(`Desktop icons hidden using ${approach.description}.`);
|
|
166
|
+
console.log('To show them again, run: show-desktop-icons');
|
|
167
|
+
success = true;
|
|
168
|
+
break;
|
|
169
|
+
} catch {
|
|
170
|
+
// This approach didn't work, try the next one
|
|
171
|
+
continue;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
if (!success) {
|
|
176
|
+
console.error('Error: Could not hide desktop icons.');
|
|
177
|
+
console.error('');
|
|
178
|
+
console.error('Your desktop environment may not support this operation,');
|
|
179
|
+
console.error('or you may be using a non-standard configuration.');
|
|
180
|
+
console.error('');
|
|
181
|
+
console.error('Tried approaches:');
|
|
182
|
+
for (const approach of hideCommands) {
|
|
183
|
+
console.error(` - ${approach.description}`);
|
|
184
|
+
}
|
|
185
|
+
process.exit(1);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
/**
|
|
190
|
+
* Hide desktop icons on Raspberry Pi OS.
|
|
191
|
+
*
|
|
192
|
+
* Raspberry Pi OS typically uses LXDE/LXQT (Raspberry Pi OS Lite) or PIXEL desktop.
|
|
193
|
+
* Desktop icon settings are managed through pcmanfm configuration.
|
|
194
|
+
*
|
|
195
|
+
* @param {string[]} args - Command line arguments (unused)
|
|
196
|
+
* @returns {Promise<void>}
|
|
197
|
+
*/
|
|
198
|
+
async function do_hide_desktop_icons_raspbian(args) {
|
|
199
|
+
// Check if we have a desktop environment available
|
|
200
|
+
const hasDesktop = os.isDesktopAvailable();
|
|
201
|
+
|
|
202
|
+
if (!hasDesktop) {
|
|
203
|
+
console.log('No desktop environment detected.');
|
|
204
|
+
console.log('This command is designed for graphical environments.');
|
|
205
|
+
console.log('');
|
|
206
|
+
console.log('Desktop icons can only be hidden on Raspberry Pi OS with desktop.');
|
|
207
|
+
return;
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
// Try different approaches for Raspberry Pi OS
|
|
211
|
+
const hideCommands = [
|
|
212
|
+
// PIXEL desktop uses pcmanfm
|
|
213
|
+
{
|
|
214
|
+
cmd: 'pcmanfm --desktop-pref && echo "Please uncheck show desktop icons in the preferences dialog"',
|
|
215
|
+
description: 'PCManFM desktop preferences',
|
|
216
|
+
interactive: true
|
|
217
|
+
},
|
|
218
|
+
// LXDE desktop
|
|
219
|
+
{
|
|
220
|
+
cmd: 'gsettings set org.gnome.desktop.background show-desktop-icons false',
|
|
221
|
+
description: 'GNOME-compatible settings'
|
|
222
|
+
}
|
|
223
|
+
];
|
|
224
|
+
|
|
225
|
+
// For Raspberry Pi OS with PIXEL/LXDE, the desktop is managed by PCManFM
|
|
226
|
+
// PCManFM stores settings in ~/.config/pcmanfm/LXDE-pi/desktop-items-0.conf
|
|
227
|
+
const fs = require('fs');
|
|
228
|
+
const path = require('path');
|
|
229
|
+
const homeDir = os.getHomeDir();
|
|
230
|
+
|
|
231
|
+
// Common pcmanfm config locations
|
|
232
|
+
const configPaths = [
|
|
233
|
+
path.join(homeDir, '.config/pcmanfm/LXDE-pi/desktop-items-0.conf'),
|
|
234
|
+
path.join(homeDir, '.config/pcmanfm/default/desktop-items-0.conf'),
|
|
235
|
+
path.join(homeDir, '.config/pcmanfm/LXDE/desktop-items-0.conf')
|
|
236
|
+
];
|
|
237
|
+
|
|
238
|
+
for (const configPath of configPaths) {
|
|
239
|
+
if (fs.existsSync(configPath)) {
|
|
240
|
+
try {
|
|
241
|
+
let config = fs.readFileSync(configPath, 'utf8');
|
|
242
|
+
|
|
243
|
+
// Modify the show_documents, show_trash, and show_mounts settings
|
|
244
|
+
config = config.replace(/show_documents=1/g, 'show_documents=0');
|
|
245
|
+
config = config.replace(/show_trash=1/g, 'show_trash=0');
|
|
246
|
+
config = config.replace(/show_mounts=1/g, 'show_mounts=0');
|
|
247
|
+
|
|
248
|
+
fs.writeFileSync(configPath, config);
|
|
249
|
+
console.log('Desktop icons hidden via PCManFM configuration.');
|
|
250
|
+
console.log('You may need to restart the desktop or log out and back in.');
|
|
251
|
+
console.log('To show them again, run: show-desktop-icons');
|
|
252
|
+
return;
|
|
253
|
+
} catch (err) {
|
|
254
|
+
// Continue to try other methods
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
|
|
259
|
+
// Fallback: try gsettings if available
|
|
260
|
+
if (isCommandAvailable('gsettings')) {
|
|
261
|
+
try {
|
|
262
|
+
execSync('gsettings set org.gnome.desktop.background show-desktop-icons false', {
|
|
263
|
+
stdio: 'pipe'
|
|
264
|
+
});
|
|
265
|
+
console.log('Desktop icons hidden.');
|
|
266
|
+
console.log('To show them again, run: show-desktop-icons');
|
|
267
|
+
return;
|
|
268
|
+
} catch {
|
|
269
|
+
// gsettings approach didn't work
|
|
270
|
+
}
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
console.error('Error: Could not hide desktop icons.');
|
|
274
|
+
console.error('');
|
|
275
|
+
console.error('On Raspberry Pi OS, desktop icons are managed by PCManFM.');
|
|
276
|
+
console.error('You can manually hide them by right-clicking the desktop,');
|
|
277
|
+
console.error('selecting "Desktop Preferences", and unchecking the icon options.');
|
|
278
|
+
process.exit(1);
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
/**
|
|
282
|
+
* Hide desktop icons on Amazon Linux.
|
|
283
|
+
*
|
|
284
|
+
* Amazon Linux is typically used in server environments without a desktop.
|
|
285
|
+
* If a desktop is present (rare), it attempts to use GNOME settings.
|
|
286
|
+
*
|
|
287
|
+
* @param {string[]} args - Command line arguments (unused)
|
|
288
|
+
* @returns {Promise<void>}
|
|
289
|
+
*/
|
|
290
|
+
async function do_hide_desktop_icons_amazon_linux(args) {
|
|
291
|
+
// Check if we have a desktop environment available
|
|
292
|
+
const hasDesktop = os.isDesktopAvailable();
|
|
293
|
+
|
|
294
|
+
if (!hasDesktop) {
|
|
295
|
+
console.log('No desktop environment detected.');
|
|
296
|
+
console.log('Amazon Linux is typically used in server environments.');
|
|
297
|
+
console.log('');
|
|
298
|
+
console.log('Desktop icons can only be hidden on systems with a GUI.');
|
|
299
|
+
return;
|
|
300
|
+
}
|
|
301
|
+
|
|
302
|
+
// Try gsettings if available
|
|
303
|
+
if (isCommandAvailable('gsettings')) {
|
|
304
|
+
try {
|
|
305
|
+
execSync('gsettings set org.gnome.desktop.background show-desktop-icons false', {
|
|
306
|
+
stdio: 'inherit'
|
|
307
|
+
});
|
|
308
|
+
console.log('Desktop icons hidden.');
|
|
309
|
+
console.log('To show them again, run: show-desktop-icons');
|
|
310
|
+
return;
|
|
311
|
+
} catch {
|
|
312
|
+
// gsettings approach didn't work
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
|
|
316
|
+
console.error('Error: Could not hide desktop icons.');
|
|
317
|
+
console.error('This feature requires a desktop environment with GNOME settings.');
|
|
318
|
+
process.exit(1);
|
|
319
|
+
}
|
|
320
|
+
|
|
8
321
|
/**
|
|
9
|
-
*
|
|
10
|
-
*
|
|
322
|
+
* Hide desktop icons on Windows using Command Prompt.
|
|
323
|
+
*
|
|
324
|
+
* Windows desktop icons can be hidden through:
|
|
325
|
+
* 1. Right-click desktop > View > Show desktop icons (manual)
|
|
326
|
+
* 2. Registry modification
|
|
327
|
+
* 3. Shell COM object manipulation
|
|
328
|
+
*
|
|
329
|
+
* This implementation uses a PowerShell command that toggles the desktop icons
|
|
330
|
+
* visibility through the Shell.Application COM object.
|
|
11
331
|
*
|
|
12
332
|
* @param {string[]} args - Command line arguments (unused)
|
|
13
333
|
* @returns {Promise<void>}
|
|
14
334
|
*/
|
|
15
|
-
async function
|
|
16
|
-
|
|
335
|
+
async function do_hide_desktop_icons_cmd(args) {
|
|
336
|
+
try {
|
|
337
|
+
// Use PowerShell to toggle desktop icons through COM object
|
|
338
|
+
// This simulates the "Show desktop icons" toggle in the right-click menu
|
|
339
|
+
const psCommand = `
|
|
340
|
+
$shell = New-Object -ComObject Shell.Application
|
|
341
|
+
$shell.ToggleDesktop()
|
|
342
|
+
Start-Sleep -Milliseconds 100
|
|
343
|
+
$shell.ToggleDesktop()
|
|
344
|
+
`;
|
|
345
|
+
|
|
346
|
+
// Alternative approach: modify registry to hide icons
|
|
347
|
+
// This is more reliable but requires a restart of Explorer
|
|
348
|
+
const registryCommand = `
|
|
349
|
+
reg add "HKCU\\Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Advanced" /v HideIcons /t REG_DWORD /d 1 /f
|
|
350
|
+
`;
|
|
351
|
+
|
|
352
|
+
execSync(`cmd /c ${registryCommand.trim().replace(/\n/g, ' ')}`, { stdio: 'inherit' });
|
|
353
|
+
|
|
354
|
+
// Restart Explorer to apply the changes
|
|
355
|
+
execSync('taskkill /f /im explorer.exe && start explorer.exe', {
|
|
356
|
+
stdio: 'inherit',
|
|
357
|
+
shell: true
|
|
358
|
+
});
|
|
359
|
+
|
|
360
|
+
console.log('Desktop icons are now hidden.');
|
|
361
|
+
console.log('To show them again, run: show-desktop-icons');
|
|
362
|
+
} catch (error) {
|
|
363
|
+
console.error('Error: Could not hide desktop icons.');
|
|
364
|
+
console.error('');
|
|
365
|
+
console.error('You can manually hide desktop icons by:');
|
|
366
|
+
console.error('1. Right-click on the desktop');
|
|
367
|
+
console.error('2. Select "View"');
|
|
368
|
+
console.error('3. Uncheck "Show desktop icons"');
|
|
369
|
+
process.exit(1);
|
|
370
|
+
}
|
|
371
|
+
}
|
|
372
|
+
|
|
373
|
+
/**
|
|
374
|
+
* Hide desktop icons on Windows using PowerShell.
|
|
375
|
+
*
|
|
376
|
+
* Uses the same registry approach as CMD but with native PowerShell commands.
|
|
377
|
+
*
|
|
378
|
+
* @param {string[]} args - Command line arguments (unused)
|
|
379
|
+
* @returns {Promise<void>}
|
|
380
|
+
*/
|
|
381
|
+
async function do_hide_desktop_icons_powershell(args) {
|
|
382
|
+
try {
|
|
383
|
+
// Modify registry to hide icons
|
|
384
|
+
const commands = [
|
|
385
|
+
'Set-ItemProperty -Path "HKCU:\\Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Advanced" -Name "HideIcons" -Value 1 -Type DWord',
|
|
386
|
+
'Stop-Process -Name explorer -Force; Start-Process explorer'
|
|
387
|
+
];
|
|
388
|
+
|
|
389
|
+
for (const cmd of commands) {
|
|
390
|
+
execSync(`powershell -Command "${cmd}"`, { stdio: 'inherit' });
|
|
391
|
+
}
|
|
392
|
+
|
|
393
|
+
console.log('Desktop icons are now hidden.');
|
|
394
|
+
console.log('To show them again, run: show-desktop-icons');
|
|
395
|
+
} catch (error) {
|
|
396
|
+
console.error('Error: Could not hide desktop icons.');
|
|
397
|
+
console.error('');
|
|
398
|
+
console.error('You can manually hide desktop icons by:');
|
|
399
|
+
console.error('1. Right-click on the desktop');
|
|
400
|
+
console.error('2. Select "View"');
|
|
401
|
+
console.error('3. Uncheck "Show desktop icons"');
|
|
402
|
+
process.exit(1);
|
|
403
|
+
}
|
|
404
|
+
}
|
|
405
|
+
|
|
406
|
+
/**
|
|
407
|
+
* Hide desktop icons from Git Bash on Windows.
|
|
408
|
+
*
|
|
409
|
+
* Git Bash runs in Windows, so we use the Windows approach via PowerShell.
|
|
410
|
+
*
|
|
411
|
+
* @param {string[]} args - Command line arguments (unused)
|
|
412
|
+
* @returns {Promise<void>}
|
|
413
|
+
*/
|
|
414
|
+
async function do_hide_desktop_icons_gitbash(args) {
|
|
415
|
+
try {
|
|
416
|
+
// Use PowerShell from Git Bash to modify registry
|
|
417
|
+
const psCommand = 'Set-ItemProperty -Path "HKCU:\\Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\Advanced" -Name "HideIcons" -Value 1 -Type DWord; Stop-Process -Name explorer -Force; Start-Process explorer';
|
|
418
|
+
|
|
419
|
+
execSync(`powershell.exe -Command "${psCommand}"`, { stdio: 'inherit' });
|
|
420
|
+
|
|
421
|
+
console.log('Desktop icons are now hidden.');
|
|
422
|
+
console.log('To show them again, run: show-desktop-icons');
|
|
423
|
+
} catch (error) {
|
|
424
|
+
console.error('Error: Could not hide desktop icons.');
|
|
425
|
+
console.error('');
|
|
426
|
+
console.error('You can manually hide desktop icons by:');
|
|
427
|
+
console.error('1. Right-click on the desktop');
|
|
428
|
+
console.error('2. Select "View"');
|
|
429
|
+
console.error('3. Uncheck "Show desktop icons"');
|
|
430
|
+
process.exit(1);
|
|
431
|
+
}
|
|
432
|
+
}
|
|
433
|
+
|
|
434
|
+
/**
|
|
435
|
+
* Main entry point - detects environment and executes appropriate implementation.
|
|
436
|
+
*
|
|
437
|
+
* The "hide-desktop-icons" command hides all icons on the desktop surface.
|
|
438
|
+
* This is useful for:
|
|
439
|
+
* - Creating a clean desktop for screenshots or presentations
|
|
440
|
+
* - Reducing visual clutter while keeping files accessible in ~/Desktop
|
|
441
|
+
* - Personal preference for a minimalist workspace
|
|
442
|
+
*
|
|
443
|
+
* The desktop files themselves are NOT deleted - they remain in the Desktop
|
|
444
|
+
* folder and can be accessed through the file manager. Only the visual
|
|
445
|
+
* representation on the desktop surface is hidden.
|
|
446
|
+
*
|
|
447
|
+
* @param {string[]} args - Command line arguments (unused)
|
|
448
|
+
* @returns {Promise<void>}
|
|
449
|
+
*/
|
|
450
|
+
async function do_hide_desktop_icons(args) {
|
|
451
|
+
const platform = os.detect();
|
|
452
|
+
|
|
453
|
+
const handlers = {
|
|
454
|
+
'macos': do_hide_desktop_icons_macos,
|
|
455
|
+
'ubuntu': do_hide_desktop_icons_ubuntu,
|
|
456
|
+
'debian': do_hide_desktop_icons_ubuntu,
|
|
457
|
+
'raspbian': do_hide_desktop_icons_raspbian,
|
|
458
|
+
'amazon_linux': do_hide_desktop_icons_amazon_linux,
|
|
459
|
+
'rhel': do_hide_desktop_icons_amazon_linux,
|
|
460
|
+
'fedora': do_hide_desktop_icons_ubuntu,
|
|
461
|
+
'linux': do_hide_desktop_icons_ubuntu,
|
|
462
|
+
'wsl': do_hide_desktop_icons_ubuntu,
|
|
463
|
+
'cmd': do_hide_desktop_icons_cmd,
|
|
464
|
+
'windows': do_hide_desktop_icons_cmd,
|
|
465
|
+
'powershell': do_hide_desktop_icons_powershell,
|
|
466
|
+
'gitbash': do_hide_desktop_icons_gitbash
|
|
467
|
+
};
|
|
468
|
+
|
|
469
|
+
const handler = handlers[platform.type];
|
|
470
|
+
if (!handler) {
|
|
471
|
+
console.error(`Platform '${platform.type}' is not supported for this command.`);
|
|
472
|
+
console.error('');
|
|
473
|
+
console.error('Supported platforms:');
|
|
474
|
+
console.error(' - macOS');
|
|
475
|
+
console.error(' - Ubuntu, Debian, and other Linux distributions with GNOME');
|
|
476
|
+
console.error(' - Raspberry Pi OS');
|
|
477
|
+
console.error(' - Windows (CMD, PowerShell, Git Bash)');
|
|
478
|
+
process.exit(1);
|
|
479
|
+
}
|
|
480
|
+
|
|
481
|
+
await handler(args);
|
|
17
482
|
}
|
|
18
483
|
|
|
19
|
-
module.exports = {
|
|
484
|
+
module.exports = {
|
|
485
|
+
main: do_hide_desktop_icons,
|
|
486
|
+
do_hide_desktop_icons,
|
|
487
|
+
do_hide_desktop_icons_nodejs,
|
|
488
|
+
do_hide_desktop_icons_macos,
|
|
489
|
+
do_hide_desktop_icons_ubuntu,
|
|
490
|
+
do_hide_desktop_icons_raspbian,
|
|
491
|
+
do_hide_desktop_icons_amazon_linux,
|
|
492
|
+
do_hide_desktop_icons_cmd,
|
|
493
|
+
do_hide_desktop_icons_powershell,
|
|
494
|
+
do_hide_desktop_icons_gitbash
|
|
495
|
+
};
|
|
20
496
|
|
|
21
497
|
if (require.main === module) {
|
|
22
|
-
|
|
498
|
+
do_hide_desktop_icons(process.argv.slice(2));
|
|
23
499
|
}
|