@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.
Files changed (259) hide show
  1. package/README.md +5 -5
  2. package/package.json +1 -1
  3. package/src/commands/install.js +374 -36
  4. package/src/installs/adobe-creative-cloud.js +527 -25
  5. package/src/installs/adobe-creative-cloud.md +605 -0
  6. package/src/installs/appcleaner.js +303 -26
  7. package/src/installs/appcleaner.md +699 -0
  8. package/src/installs/apt-transport-https.js +390 -0
  9. package/src/installs/apt-transport-https.md +678 -0
  10. package/src/installs/atomicparsley.js +624 -26
  11. package/src/installs/atomicparsley.md +795 -0
  12. package/src/installs/aws-cli.js +779 -26
  13. package/src/installs/aws-cli.md +727 -0
  14. package/src/installs/balena-etcher.js +688 -26
  15. package/src/installs/balena-etcher.md +761 -0
  16. package/src/installs/bambu-studio.js +912 -26
  17. package/src/installs/bambu-studio.md +780 -0
  18. package/src/installs/bash-completion.js +554 -23
  19. package/src/installs/bash-completion.md +833 -0
  20. package/src/installs/bash.js +399 -26
  21. package/src/installs/bash.md +993 -0
  22. package/src/installs/beyond-compare.js +585 -26
  23. package/src/installs/beyond-compare.md +813 -0
  24. package/src/installs/build-essential.js +511 -26
  25. package/src/installs/build-essential.md +977 -0
  26. package/src/installs/ca-certificates.js +618 -0
  27. package/src/installs/ca-certificates.md +937 -0
  28. package/src/installs/caffeine.js +490 -26
  29. package/src/installs/caffeine.md +839 -0
  30. package/src/installs/camtasia.js +577 -25
  31. package/src/installs/camtasia.md +762 -0
  32. package/src/installs/chatgpt.js +458 -26
  33. package/src/installs/chatgpt.md +814 -0
  34. package/src/installs/chocolatey.js +447 -0
  35. package/src/installs/chocolatey.md +661 -0
  36. package/src/installs/chrome-canary.js +472 -26
  37. package/src/installs/chrome-canary.md +641 -0
  38. package/src/installs/chromium.js +645 -26
  39. package/src/installs/chromium.md +838 -0
  40. package/src/installs/claude-code.js +558 -26
  41. package/src/installs/claude-code.md +1173 -0
  42. package/src/installs/curl.js +361 -26
  43. package/src/installs/curl.md +714 -0
  44. package/src/installs/cursor.js +561 -26
  45. package/src/installs/cursor.md +970 -0
  46. package/src/installs/dbschema.js +674 -26
  47. package/src/installs/dbschema.md +925 -0
  48. package/src/installs/dependencies.md +435 -0
  49. package/src/installs/development-tools.js +600 -0
  50. package/src/installs/development-tools.md +977 -0
  51. package/src/installs/docker.js +1010 -25
  52. package/src/installs/docker.md +1109 -0
  53. package/src/installs/drawio.js +1001 -26
  54. package/src/installs/drawio.md +795 -0
  55. package/src/installs/elmedia-player.js +328 -25
  56. package/src/installs/elmedia-player.md +556 -0
  57. package/src/installs/ffmpeg.js +870 -25
  58. package/src/installs/ffmpeg.md +852 -0
  59. package/src/installs/file.js +464 -0
  60. package/src/installs/file.md +987 -0
  61. package/src/installs/gemini-cli.js +793 -26
  62. package/src/installs/gemini-cli.md +1153 -0
  63. package/src/installs/git.js +382 -26
  64. package/src/installs/git.md +907 -0
  65. package/src/installs/gitego.js +931 -26
  66. package/src/installs/gitego.md +1172 -0
  67. package/src/installs/go.js +913 -26
  68. package/src/installs/go.md +958 -0
  69. package/src/installs/google-chrome.js +801 -25
  70. package/src/installs/google-chrome.md +862 -0
  71. package/src/installs/gpg.js +412 -73
  72. package/src/installs/gpg.md +1056 -0
  73. package/src/installs/homebrew.js +1015 -26
  74. package/src/installs/homebrew.md +988 -0
  75. package/src/installs/imageoptim.js +950 -26
  76. package/src/installs/imageoptim.md +1119 -0
  77. package/src/installs/installers.json +2297 -0
  78. package/src/installs/jq.js +382 -26
  79. package/src/installs/jq.md +809 -0
  80. package/src/installs/keyboard-maestro.js +701 -26
  81. package/src/installs/keyboard-maestro.md +825 -0
  82. package/src/installs/latex.js +771 -26
  83. package/src/installs/latex.md +1095 -0
  84. package/src/installs/lftp.js +338 -26
  85. package/src/installs/lftp.md +907 -0
  86. package/src/installs/lsb-release.js +346 -0
  87. package/src/installs/lsb-release.md +814 -0
  88. package/src/installs/messenger.js +829 -26
  89. package/src/installs/messenger.md +900 -0
  90. package/src/installs/microsoft-office.js +550 -26
  91. package/src/installs/microsoft-office.md +760 -0
  92. package/src/installs/microsoft-teams.js +782 -25
  93. package/src/installs/microsoft-teams.md +886 -0
  94. package/src/installs/node.js +886 -26
  95. package/src/installs/node.md +1153 -0
  96. package/src/installs/nordpass.js +698 -26
  97. package/src/installs/nordpass.md +921 -0
  98. package/src/installs/nvm.js +977 -26
  99. package/src/installs/nvm.md +1057 -0
  100. package/src/installs/openssh.js +734 -64
  101. package/src/installs/openssh.md +1056 -0
  102. package/src/installs/pandoc.js +644 -26
  103. package/src/installs/pandoc.md +1036 -0
  104. package/src/installs/pinentry.js +492 -26
  105. package/src/installs/pinentry.md +1142 -0
  106. package/src/installs/pngyu.js +851 -26
  107. package/src/installs/pngyu.md +896 -0
  108. package/src/installs/postman.js +781 -26
  109. package/src/installs/postman.md +940 -0
  110. package/src/installs/procps.js +425 -0
  111. package/src/installs/procps.md +851 -0
  112. package/src/installs/safari-tech-preview.js +355 -25
  113. package/src/installs/safari-tech-preview.md +533 -0
  114. package/src/installs/sfnt2woff.js +640 -26
  115. package/src/installs/sfnt2woff.md +795 -0
  116. package/src/installs/shellcheck.js +463 -26
  117. package/src/installs/shellcheck.md +1005 -0
  118. package/src/installs/slack.js +722 -25
  119. package/src/installs/slack.md +865 -0
  120. package/src/installs/snagit.js +566 -25
  121. package/src/installs/snagit.md +844 -0
  122. package/src/installs/software-properties-common.js +372 -0
  123. package/src/installs/software-properties-common.md +805 -0
  124. package/src/installs/spotify.js +858 -25
  125. package/src/installs/spotify.md +901 -0
  126. package/src/installs/studio-3t.js +803 -26
  127. package/src/installs/studio-3t.md +918 -0
  128. package/src/installs/sublime-text.js +780 -25
  129. package/src/installs/sublime-text.md +914 -0
  130. package/src/installs/superwhisper.js +687 -25
  131. package/src/installs/superwhisper.md +630 -0
  132. package/src/installs/tailscale.js +727 -26
  133. package/src/installs/tailscale.md +1100 -0
  134. package/src/installs/tar.js +389 -0
  135. package/src/installs/tar.md +946 -0
  136. package/src/installs/termius.js +780 -26
  137. package/src/installs/termius.md +844 -0
  138. package/src/installs/terraform.js +761 -26
  139. package/src/installs/terraform.md +899 -0
  140. package/src/installs/tidal.js +752 -25
  141. package/src/installs/tidal.md +864 -0
  142. package/src/installs/tmux.js +328 -26
  143. package/src/installs/tmux.md +1030 -0
  144. package/src/installs/tree.js +393 -26
  145. package/src/installs/tree.md +833 -0
  146. package/src/installs/unzip.js +460 -0
  147. package/src/installs/unzip.md +879 -0
  148. package/src/installs/vim.js +403 -26
  149. package/src/installs/vim.md +1040 -0
  150. package/src/installs/vlc.js +803 -26
  151. package/src/installs/vlc.md +927 -0
  152. package/src/installs/vscode.js +825 -26
  153. package/src/installs/vscode.md +1002 -0
  154. package/src/installs/wget.js +415 -0
  155. package/src/installs/wget.md +791 -0
  156. package/src/installs/whatsapp.js +710 -25
  157. package/src/installs/whatsapp.md +854 -0
  158. package/src/installs/winpty.js +352 -0
  159. package/src/installs/winpty.md +620 -0
  160. package/src/installs/woff2.js +535 -26
  161. package/src/installs/woff2.md +977 -0
  162. package/src/installs/wsl.js +572 -0
  163. package/src/installs/wsl.md +699 -0
  164. package/src/installs/xcode-clt.js +520 -0
  165. package/src/installs/xcode-clt.md +351 -0
  166. package/src/installs/xcode.js +542 -26
  167. package/src/installs/xcode.md +573 -0
  168. package/src/installs/yarn.js +806 -26
  169. package/src/installs/yarn.md +1074 -0
  170. package/src/installs/yq.js +636 -26
  171. package/src/installs/yq.md +944 -0
  172. package/src/installs/yt-dlp.js +683 -26
  173. package/src/installs/yt-dlp.md +946 -0
  174. package/src/installs/yum-utils.js +297 -0
  175. package/src/installs/yum-utils.md +648 -0
  176. package/src/installs/zoom.js +740 -25
  177. package/src/installs/zoom.md +884 -0
  178. package/src/scripts/README.md +567 -45
  179. package/src/scripts/STATUS.md +208 -0
  180. package/src/scripts/afk.js +395 -7
  181. package/src/scripts/backup-all.js +731 -9
  182. package/src/scripts/backup-source.js +711 -8
  183. package/src/scripts/brewd.js +373 -7
  184. package/src/scripts/brewi.js +505 -9
  185. package/src/scripts/brewr.js +512 -9
  186. package/src/scripts/brews.js +462 -9
  187. package/src/scripts/brewu.js +488 -7
  188. package/src/scripts/c.js +185 -7
  189. package/src/scripts/ccurl.js +325 -8
  190. package/src/scripts/certbot-crontab-init.js +488 -8
  191. package/src/scripts/certbot-init.js +641 -9
  192. package/src/scripts/ch.js +339 -7
  193. package/src/scripts/claude-danger.js +253 -8
  194. package/src/scripts/clean-dev.js +419 -8
  195. package/src/scripts/clear-dns-cache.js +525 -7
  196. package/src/scripts/clone.js +417 -7
  197. package/src/scripts/code-all.js +420 -7
  198. package/src/scripts/count-files.js +195 -8
  199. package/src/scripts/count-folders.js +195 -8
  200. package/src/scripts/count.js +248 -8
  201. package/src/scripts/d.js +203 -7
  202. package/src/scripts/datauri.js +373 -8
  203. package/src/scripts/delete-files.js +363 -7
  204. package/src/scripts/docker-clean.js +410 -8
  205. package/src/scripts/dp.js +426 -7
  206. package/src/scripts/e.js +375 -9
  207. package/src/scripts/empty-trash.js +497 -7
  208. package/src/scripts/evm.js +428 -9
  209. package/src/scripts/fetch-github-repos.js +441 -10
  210. package/src/scripts/get-channel.js +329 -8
  211. package/src/scripts/get-course.js +384 -11
  212. package/src/scripts/get-dependencies.js +290 -9
  213. package/src/scripts/get-folder.js +783 -10
  214. package/src/scripts/get-tunes.js +411 -10
  215. package/src/scripts/get-video.js +352 -9
  216. package/src/scripts/git-backup.js +561 -9
  217. package/src/scripts/git-clone.js +477 -9
  218. package/src/scripts/git-pup.js +303 -7
  219. package/src/scripts/git-push.js +380 -8
  220. package/src/scripts/h.js +607 -9
  221. package/src/scripts/hide-desktop-icons.js +483 -7
  222. package/src/scripts/hide-hidden-files.js +522 -7
  223. package/src/scripts/install-dependencies-from.js +440 -9
  224. package/src/scripts/ips.js +647 -10
  225. package/src/scripts/iso.js +354 -8
  226. package/src/scripts/killni.js +561 -7
  227. package/src/scripts/ll.js +451 -8
  228. package/src/scripts/local-ip.js +310 -8
  229. package/src/scripts/m.js +508 -8
  230. package/src/scripts/map.js +293 -8
  231. package/src/scripts/mkd.js +287 -7
  232. package/src/scripts/ncu-update-all.js +441 -8
  233. package/src/scripts/nginx-init.js +702 -12
  234. package/src/scripts/npmi.js +366 -7
  235. package/src/scripts/o.js +495 -8
  236. package/src/scripts/org-by-date.js +321 -7
  237. package/src/scripts/p.js +208 -7
  238. package/src/scripts/packages.js +313 -8
  239. package/src/scripts/path.js +209 -7
  240. package/src/scripts/ports.js +582 -8
  241. package/src/scripts/q.js +290 -8
  242. package/src/scripts/refresh-files.js +378 -10
  243. package/src/scripts/remove-smaller-files.js +500 -8
  244. package/src/scripts/rename-files-with-date.js +517 -9
  245. package/src/scripts/resize-image.js +523 -9
  246. package/src/scripts/rm-safe.js +653 -8
  247. package/src/scripts/s.js +525 -9
  248. package/src/scripts/set-git-public.js +349 -7
  249. package/src/scripts/show-desktop-icons.js +459 -7
  250. package/src/scripts/show-hidden-files.js +456 -7
  251. package/src/scripts/tpa.js +265 -8
  252. package/src/scripts/tpo.js +264 -7
  253. package/src/scripts/u.js +489 -7
  254. package/src/scripts/vpush.js +422 -8
  255. package/src/scripts/y.js +267 -7
  256. package/src/utils/common/os.js +94 -2
  257. package/src/utils/ubuntu/apt.js +13 -7
  258. package/src/utils/windows/choco.js +82 -26
  259. package/src/utils/windows/winget.js +89 -27
@@ -1,23 +1,499 @@
1
1
  #!/usr/bin/env node
2
2
 
3
3
  /**
4
- * @fileoverview Hide desktop icons in Finder.
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
- * Hides all icons on the macOS desktop by modifying Finder preferences
10
- * and restarting Finder.
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 main(args) {
16
- // TODO: Implement desktop icon hiding
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 = { main };
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
- main(process.argv.slice(2));
498
+ do_hide_desktop_icons(process.argv.slice(2));
23
499
  }