@fredlackey/devutils 0.0.18 → 0.0.19

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 (331) hide show
  1. package/README.md +32 -150
  2. package/package.json +5 -82
  3. package/bin/dev.js +0 -16
  4. package/files/README.md +0 -0
  5. package/files/claude/.claude/commands/setup-context.md +0 -3
  6. package/files/monorepos/_archive/README.md +0 -36
  7. package/files/monorepos/_legacy/README.md +0 -36
  8. package/files/monorepos/ai-docs/README.md +0 -33
  9. package/files/monorepos/apps/README.md +0 -24
  10. package/files/monorepos/docs/README.md +0 -40
  11. package/files/monorepos/packages/README.md +0 -25
  12. package/files/monorepos/research/README.md +0 -29
  13. package/files/monorepos/scripts/README.md +0 -24
  14. package/src/cli.js +0 -72
  15. package/src/commands/README.md +0 -41
  16. package/src/commands/configure.js +0 -199
  17. package/src/commands/identity.js +0 -1630
  18. package/src/commands/ignore.js +0 -247
  19. package/src/commands/install.js +0 -526
  20. package/src/commands/setup.js +0 -246
  21. package/src/commands/status.js +0 -223
  22. package/src/commands/update.js +0 -142
  23. package/src/commands/version.js +0 -100
  24. package/src/completion.js +0 -284
  25. package/src/constants.js +0 -45
  26. package/src/ignore/claude-code.txt +0 -10
  27. package/src/ignore/docker.txt +0 -18
  28. package/src/ignore/linux.txt +0 -23
  29. package/src/ignore/macos.txt +0 -36
  30. package/src/ignore/node.txt +0 -55
  31. package/src/ignore/terraform.txt +0 -37
  32. package/src/ignore/vscode.txt +0 -18
  33. package/src/ignore/windows.txt +0 -35
  34. package/src/index.js +0 -0
  35. package/src/installs/README.md +0 -399
  36. package/src/installs/adobe-creative-cloud.js +0 -546
  37. package/src/installs/adobe-creative-cloud.md +0 -605
  38. package/src/installs/appcleaner.js +0 -321
  39. package/src/installs/appcleaner.md +0 -699
  40. package/src/installs/apt-transport-https.js +0 -390
  41. package/src/installs/apt-transport-https.md +0 -678
  42. package/src/installs/atomicparsley.js +0 -642
  43. package/src/installs/atomicparsley.md +0 -795
  44. package/src/installs/aws-cli.js +0 -797
  45. package/src/installs/aws-cli.md +0 -727
  46. package/src/installs/balena-etcher.js +0 -710
  47. package/src/installs/balena-etcher.md +0 -761
  48. package/src/installs/bambu-studio.js +0 -1143
  49. package/src/installs/bambu-studio.md +0 -780
  50. package/src/installs/bash-completion.js +0 -575
  51. package/src/installs/bash-completion.md +0 -833
  52. package/src/installs/bash.js +0 -417
  53. package/src/installs/bash.md +0 -993
  54. package/src/installs/beyond-compare.js +0 -603
  55. package/src/installs/beyond-compare.md +0 -813
  56. package/src/installs/brave-browser.js +0 -968
  57. package/src/installs/brave-browser.md +0 -650
  58. package/src/installs/build-essential.js +0 -529
  59. package/src/installs/build-essential.md +0 -977
  60. package/src/installs/ca-certificates.js +0 -618
  61. package/src/installs/ca-certificates.md +0 -937
  62. package/src/installs/caffeine.js +0 -508
  63. package/src/installs/caffeine.md +0 -839
  64. package/src/installs/camtasia.js +0 -596
  65. package/src/installs/camtasia.md +0 -762
  66. package/src/installs/chatgpt.js +0 -476
  67. package/src/installs/chatgpt.md +0 -814
  68. package/src/installs/chocolatey.js +0 -456
  69. package/src/installs/chocolatey.md +0 -661
  70. package/src/installs/chrome-canary.js +0 -419
  71. package/src/installs/chrome-canary.md +0 -641
  72. package/src/installs/chromium.js +0 -667
  73. package/src/installs/chromium.md +0 -838
  74. package/src/installs/claude-code.js +0 -576
  75. package/src/installs/claude-code.md +0 -1173
  76. package/src/installs/cloudflare-warp.js +0 -900
  77. package/src/installs/cloudflare-warp.md +0 -1047
  78. package/src/installs/comet-browser.js +0 -588
  79. package/src/installs/comet-browser.md +0 -731
  80. package/src/installs/curl.js +0 -379
  81. package/src/installs/curl.md +0 -714
  82. package/src/installs/cursor.js +0 -579
  83. package/src/installs/cursor.md +0 -970
  84. package/src/installs/dbeaver.js +0 -924
  85. package/src/installs/dbeaver.md +0 -939
  86. package/src/installs/dbschema.js +0 -692
  87. package/src/installs/dbschema.md +0 -925
  88. package/src/installs/dependencies.md +0 -453
  89. package/src/installs/development-tools.js +0 -600
  90. package/src/installs/development-tools.md +0 -977
  91. package/src/installs/docker.js +0 -1029
  92. package/src/installs/docker.md +0 -1109
  93. package/src/installs/drawio.js +0 -1019
  94. package/src/installs/drawio.md +0 -795
  95. package/src/installs/elmedia-player.js +0 -347
  96. package/src/installs/elmedia-player.md +0 -556
  97. package/src/installs/ffmpeg.js +0 -889
  98. package/src/installs/ffmpeg.md +0 -852
  99. package/src/installs/file.js +0 -464
  100. package/src/installs/file.md +0 -987
  101. package/src/installs/gemini-cli.js +0 -811
  102. package/src/installs/gemini-cli.md +0 -1153
  103. package/src/installs/git.js +0 -400
  104. package/src/installs/git.md +0 -907
  105. package/src/installs/gitego.js +0 -949
  106. package/src/installs/gitego.md +0 -1172
  107. package/src/installs/go.js +0 -931
  108. package/src/installs/go.md +0 -958
  109. package/src/installs/google-antigravity.js +0 -913
  110. package/src/installs/google-antigravity.md +0 -1075
  111. package/src/installs/google-chrome.js +0 -833
  112. package/src/installs/google-chrome.md +0 -862
  113. package/src/installs/gpg.js +0 -480
  114. package/src/installs/gpg.md +0 -1056
  115. package/src/installs/homebrew.js +0 -1028
  116. package/src/installs/homebrew.md +0 -988
  117. package/src/installs/imageoptim.js +0 -968
  118. package/src/installs/imageoptim.md +0 -1119
  119. package/src/installs/installers.json +0 -4032
  120. package/src/installs/installers.json.tmp +0 -3953
  121. package/src/installs/jq.js +0 -400
  122. package/src/installs/jq.md +0 -809
  123. package/src/installs/keyboard-maestro.js +0 -719
  124. package/src/installs/keyboard-maestro.md +0 -825
  125. package/src/installs/kiro.js +0 -864
  126. package/src/installs/kiro.md +0 -1015
  127. package/src/installs/latex.js +0 -789
  128. package/src/installs/latex.md +0 -1095
  129. package/src/installs/lftp.js +0 -356
  130. package/src/installs/lftp.md +0 -907
  131. package/src/installs/lsb-release.js +0 -346
  132. package/src/installs/lsb-release.md +0 -814
  133. package/src/installs/messenger.js +0 -847
  134. package/src/installs/messenger.md +0 -900
  135. package/src/installs/microsoft-office.js +0 -568
  136. package/src/installs/microsoft-office.md +0 -760
  137. package/src/installs/microsoft-teams.js +0 -801
  138. package/src/installs/microsoft-teams.md +0 -886
  139. package/src/installs/moom.js +0 -326
  140. package/src/installs/moom.md +0 -570
  141. package/src/installs/node.js +0 -904
  142. package/src/installs/node.md +0 -1153
  143. package/src/installs/nordpass.js +0 -716
  144. package/src/installs/nordpass.md +0 -921
  145. package/src/installs/nordvpn.js +0 -892
  146. package/src/installs/nordvpn.md +0 -1052
  147. package/src/installs/nvm.js +0 -995
  148. package/src/installs/nvm.md +0 -1057
  149. package/src/installs/ohmyzsh.js +0 -529
  150. package/src/installs/ohmyzsh.md +0 -1094
  151. package/src/installs/openssh.js +0 -804
  152. package/src/installs/openssh.md +0 -1056
  153. package/src/installs/pandoc.js +0 -662
  154. package/src/installs/pandoc.md +0 -1036
  155. package/src/installs/parallels-desktop.js +0 -431
  156. package/src/installs/parallels-desktop.md +0 -446
  157. package/src/installs/pinentry.js +0 -510
  158. package/src/installs/pinentry.md +0 -1142
  159. package/src/installs/pngyu.js +0 -869
  160. package/src/installs/pngyu.md +0 -896
  161. package/src/installs/postman.js +0 -799
  162. package/src/installs/postman.md +0 -940
  163. package/src/installs/procps.js +0 -425
  164. package/src/installs/procps.md +0 -851
  165. package/src/installs/safari-tech-preview.js +0 -374
  166. package/src/installs/safari-tech-preview.md +0 -533
  167. package/src/installs/sfnt2woff.js +0 -658
  168. package/src/installs/sfnt2woff.md +0 -795
  169. package/src/installs/shellcheck.js +0 -481
  170. package/src/installs/shellcheck.md +0 -1005
  171. package/src/installs/slack.js +0 -741
  172. package/src/installs/slack.md +0 -865
  173. package/src/installs/snagit.js +0 -585
  174. package/src/installs/snagit.md +0 -844
  175. package/src/installs/software-properties-common.js +0 -372
  176. package/src/installs/software-properties-common.md +0 -805
  177. package/src/installs/spotify.js +0 -877
  178. package/src/installs/spotify.md +0 -901
  179. package/src/installs/studio-3t.js +0 -823
  180. package/src/installs/studio-3t.md +0 -918
  181. package/src/installs/sublime-text.js +0 -804
  182. package/src/installs/sublime-text.md +0 -914
  183. package/src/installs/superwhisper.js +0 -706
  184. package/src/installs/superwhisper.md +0 -630
  185. package/src/installs/tailscale.js +0 -745
  186. package/src/installs/tailscale.md +0 -1100
  187. package/src/installs/tar.js +0 -389
  188. package/src/installs/tar.md +0 -946
  189. package/src/installs/termius.js +0 -798
  190. package/src/installs/termius.md +0 -844
  191. package/src/installs/terraform.js +0 -779
  192. package/src/installs/terraform.md +0 -899
  193. package/src/installs/tfenv.js +0 -778
  194. package/src/installs/tfenv.md +0 -1091
  195. package/src/installs/tidal.js +0 -771
  196. package/src/installs/tidal.md +0 -864
  197. package/src/installs/tmux.js +0 -346
  198. package/src/installs/tmux.md +0 -1030
  199. package/src/installs/tree.js +0 -411
  200. package/src/installs/tree.md +0 -833
  201. package/src/installs/unzip.js +0 -460
  202. package/src/installs/unzip.md +0 -879
  203. package/src/installs/vim.js +0 -421
  204. package/src/installs/vim.md +0 -1040
  205. package/src/installs/vlc.js +0 -821
  206. package/src/installs/vlc.md +0 -927
  207. package/src/installs/vscode.js +0 -843
  208. package/src/installs/vscode.md +0 -1002
  209. package/src/installs/wget.js +0 -420
  210. package/src/installs/wget.md +0 -791
  211. package/src/installs/whatsapp.js +0 -729
  212. package/src/installs/whatsapp.md +0 -854
  213. package/src/installs/winpty.js +0 -352
  214. package/src/installs/winpty.md +0 -620
  215. package/src/installs/woff2.js +0 -553
  216. package/src/installs/woff2.md +0 -977
  217. package/src/installs/wsl.js +0 -572
  218. package/src/installs/wsl.md +0 -699
  219. package/src/installs/xcode-clt.js +0 -520
  220. package/src/installs/xcode-clt.md +0 -351
  221. package/src/installs/xcode.js +0 -560
  222. package/src/installs/xcode.md +0 -573
  223. package/src/installs/yarn.js +0 -824
  224. package/src/installs/yarn.md +0 -1074
  225. package/src/installs/yq.js +0 -654
  226. package/src/installs/yq.md +0 -944
  227. package/src/installs/yt-dlp.js +0 -701
  228. package/src/installs/yt-dlp.md +0 -946
  229. package/src/installs/yum-utils.js +0 -297
  230. package/src/installs/yum-utils.md +0 -648
  231. package/src/installs/zoom.js +0 -759
  232. package/src/installs/zoom.md +0 -884
  233. package/src/installs/zsh.js +0 -455
  234. package/src/installs/zsh.md +0 -1008
  235. package/src/scripts/README.md +0 -617
  236. package/src/scripts/STATUS.md +0 -208
  237. package/src/scripts/afk.js +0 -411
  238. package/src/scripts/backup-all.js +0 -746
  239. package/src/scripts/backup-source.js +0 -727
  240. package/src/scripts/brewd.js +0 -389
  241. package/src/scripts/brewi.js +0 -520
  242. package/src/scripts/brewr.js +0 -527
  243. package/src/scripts/brews.js +0 -477
  244. package/src/scripts/brewu.js +0 -504
  245. package/src/scripts/c.js +0 -201
  246. package/src/scripts/ccurl.js +0 -341
  247. package/src/scripts/certbot-crontab-init.js +0 -504
  248. package/src/scripts/certbot-init.js +0 -657
  249. package/src/scripts/ch.js +0 -355
  250. package/src/scripts/claude-danger.js +0 -268
  251. package/src/scripts/clean-dev.js +0 -435
  252. package/src/scripts/clear-dns-cache.js +0 -541
  253. package/src/scripts/clone.js +0 -435
  254. package/src/scripts/code-all.js +0 -437
  255. package/src/scripts/count-files.js +0 -211
  256. package/src/scripts/count-folders.js +0 -211
  257. package/src/scripts/count.js +0 -264
  258. package/src/scripts/d.js +0 -219
  259. package/src/scripts/datauri.js +0 -389
  260. package/src/scripts/delete-files.js +0 -380
  261. package/src/scripts/docker-clean.js +0 -426
  262. package/src/scripts/dp.js +0 -442
  263. package/src/scripts/e.js +0 -390
  264. package/src/scripts/empty-trash.js +0 -513
  265. package/src/scripts/evm.js +0 -444
  266. package/src/scripts/fetch-github-repos.js +0 -456
  267. package/src/scripts/get-channel.js +0 -345
  268. package/src/scripts/get-course.js +0 -399
  269. package/src/scripts/get-dependencies.js +0 -306
  270. package/src/scripts/get-folder.js +0 -799
  271. package/src/scripts/get-tunes.js +0 -426
  272. package/src/scripts/get-video.js +0 -367
  273. package/src/scripts/git-backup.js +0 -577
  274. package/src/scripts/git-clone.js +0 -493
  275. package/src/scripts/git-pup.js +0 -319
  276. package/src/scripts/git-push.js +0 -396
  277. package/src/scripts/h.js +0 -622
  278. package/src/scripts/hide-desktop-icons.js +0 -499
  279. package/src/scripts/hide-hidden-files.js +0 -538
  280. package/src/scripts/install-dependencies-from.js +0 -456
  281. package/src/scripts/ips.js +0 -663
  282. package/src/scripts/iso.js +0 -370
  283. package/src/scripts/killni.js +0 -577
  284. package/src/scripts/ll.js +0 -467
  285. package/src/scripts/local-ip.js +0 -325
  286. package/src/scripts/m.js +0 -524
  287. package/src/scripts/map.js +0 -309
  288. package/src/scripts/mkd.js +0 -351
  289. package/src/scripts/ncu-update-all.js +0 -457
  290. package/src/scripts/nginx-init.js +0 -718
  291. package/src/scripts/npmi.js +0 -382
  292. package/src/scripts/o.js +0 -511
  293. package/src/scripts/org-by-date.js +0 -338
  294. package/src/scripts/p.js +0 -224
  295. package/src/scripts/packages.js +0 -330
  296. package/src/scripts/path.js +0 -225
  297. package/src/scripts/ports.js +0 -597
  298. package/src/scripts/q.js +0 -305
  299. package/src/scripts/refresh-files.js +0 -394
  300. package/src/scripts/remove-smaller-files.js +0 -516
  301. package/src/scripts/rename-files-with-date.js +0 -533
  302. package/src/scripts/resize-image.js +0 -539
  303. package/src/scripts/rm-safe.js +0 -669
  304. package/src/scripts/s.js +0 -540
  305. package/src/scripts/set-git-public.js +0 -365
  306. package/src/scripts/show-desktop-icons.js +0 -475
  307. package/src/scripts/show-hidden-files.js +0 -472
  308. package/src/scripts/tpa.js +0 -280
  309. package/src/scripts/tpo.js +0 -280
  310. package/src/scripts/u.js +0 -505
  311. package/src/scripts/vpush.js +0 -437
  312. package/src/scripts/y.js +0 -283
  313. package/src/utils/README.md +0 -95
  314. package/src/utils/common/apps.js +0 -143
  315. package/src/utils/common/display.js +0 -157
  316. package/src/utils/common/network.js +0 -185
  317. package/src/utils/common/os.js +0 -294
  318. package/src/utils/common/package-manager.js +0 -301
  319. package/src/utils/common/privileges.js +0 -138
  320. package/src/utils/common/shell.js +0 -261
  321. package/src/utils/macos/apps.js +0 -228
  322. package/src/utils/macos/brew.js +0 -315
  323. package/src/utils/ubuntu/apt.js +0 -307
  324. package/src/utils/ubuntu/desktop.js +0 -292
  325. package/src/utils/ubuntu/snap.js +0 -344
  326. package/src/utils/ubuntu/systemd.js +0 -286
  327. package/src/utils/windows/choco.js +0 -465
  328. package/src/utils/windows/env.js +0 -246
  329. package/src/utils/windows/registry.js +0 -269
  330. package/src/utils/windows/shell.js +0 -240
  331. package/src/utils/windows/winget.js +0 -489
@@ -1,795 +0,0 @@
1
- # Installing Draw.io
2
-
3
- ## Overview
4
-
5
- Draw.io (also known as diagrams.net) is a free, open-source diagramming application for creating flowcharts, process diagrams, org charts, UML diagrams, ER diagrams, network diagrams, and more. The desktop application is built on Electron and provides a security-first approach where all diagram data remains local - no data is ever sent externally.
6
-
7
- Key features:
8
- - **Offline-first**: Works completely offline after installation
9
- - **Privacy-focused**: No analytics or external data transmission
10
- - **Cross-platform**: Available for macOS, Windows, and Linux
11
- - **Free and open-source**: Licensed under Apache 2.0
12
-
13
- This guide documents Draw.io Desktop installation across all supported platforms.
14
-
15
- ## Dependencies
16
-
17
- ### macOS (Homebrew)
18
- - **Required:**
19
- - Homebrew - Install via `/bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"` or run `dev install homebrew`
20
- - **Optional:** None
21
- - **Auto-installed:** All application dependencies are automatically handled by the Homebrew cask installation process
22
-
23
- ### Ubuntu (APT/Snap)
24
- - **Required:**
25
- - snapd - Install via `sudo apt-get update && sudo apt-get install -y snapd` (automatically installed by the installer if missing)
26
- - **Optional:** None
27
- - **Auto-installed:** snapd package manager will be installed automatically if not present via `sudo apt-get install -y snapd`
28
-
29
- ### Raspberry Pi OS (APT/Snap)
30
- - **Required:**
31
- - curl - Install via `sudo apt-get install -y curl` (usually pre-installed)
32
- - **Optional:**
33
- - snapd - Install via `sudo apt-get install -y snapd` (preferred installation method, but installer falls back to .deb package if unavailable)
34
- - **Auto-installed:** When using .deb package fallback, apt will automatically install any missing package dependencies
35
-
36
- ### Amazon Linux (DNF/YUM)
37
- - **Required:**
38
- - wget - Install via `sudo dnf install -y wget` (AL2023) or `sudo yum install -y wget` (AL2)
39
- - curl - Install via `sudo dnf install -y curl` (AL2023) or `sudo yum install -y curl` (AL2)
40
- - libxkbfile - Install via `sudo dnf install -y libxkbfile` (AL2023) or `sudo yum install -y libxkbfile` (AL2)
41
- - libsecret - Install via `sudo dnf install -y libsecret` (AL2023) or `sudo yum install -y libsecret` (AL2)
42
- - nss - Install via `sudo dnf install -y nss` (AL2023) or `sudo yum install -y nss` (AL2)
43
- - gtk3 - Install via `sudo dnf install -y gtk3` (AL2023) or `sudo yum install -y gtk3` (AL2)
44
- - libdrm - Install via `sudo dnf install -y libdrm` (AL2023) or `sudo yum install -y libdrm` (AL2)
45
- - mesa-libgbm - Install via `sudo dnf install -y mesa-libgbm` (AL2023) or `sudo yum install -y mesa-libgbm` (AL2)
46
- - alsa-lib - Install via `sudo dnf install -y alsa-lib` (AL2023) or `sudo yum install -y alsa-lib` (AL2)
47
- - **Optional:** None
48
- - **Auto-installed:** None (all dependencies must be manually installed before running Draw.io)
49
-
50
- ### Windows (Chocolatey/winget)
51
- - **Required:**
52
- - Chocolatey - Install via PowerShell (Administrator): `Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://community.chocolatey.org/install.ps1'))`
53
- - **Optional:** None
54
- - **Auto-installed:** All application dependencies are automatically handled by the Chocolatey package installation process
55
-
56
- ### Git Bash (Manual/Portable)
57
- - **Required:**
58
- - curl - Usually pre-installed with Git for Windows
59
- - **Optional:**
60
- - unzip - Install via Git for Windows package manager or use PowerShell's Expand-Archive as fallback
61
- - **Auto-installed:** None
62
-
63
- ## Prerequisites
64
-
65
- Before installing Draw.io on any platform, ensure:
66
-
67
- 1. **Internet connectivity** - Required to download installation packages
68
- 2. **Administrative privileges** - Required for system-wide installation
69
- 3. **Sufficient disk space** - Approximately 500 MB free space recommended
70
-
71
- ## Platform-Specific Installation
72
-
73
- ### macOS (Homebrew)
74
-
75
- #### Prerequisites
76
-
77
- - macOS 12 (Monterey) or later
78
- - Homebrew package manager installed
79
- - Apple Silicon (M1/M2/M3/M4) or Intel processor
80
-
81
- If Homebrew is not installed, install it first:
82
-
83
- ```bash
84
- /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
85
- ```
86
-
87
- #### Installation Steps
88
-
89
- Run the following command to install Draw.io Desktop:
90
-
91
- ```bash
92
- brew install --quiet --cask drawio
93
- ```
94
-
95
- The `--quiet` flag suppresses non-essential output, and `--cask` specifies the graphical application version. Homebrew automatically detects your processor architecture (Intel or Apple Silicon) and installs the appropriate version.
96
-
97
- #### Verification
98
-
99
- Confirm the installation succeeded by launching the application:
100
-
101
- ```bash
102
- open -a "draw.io"
103
- ```
104
-
105
- Alternatively, verify the application exists:
106
-
107
- ```bash
108
- ls /Applications | grep -i draw
109
- ```
110
-
111
- Expected output:
112
-
113
- ```
114
- draw.io.app
115
- ```
116
-
117
- #### Troubleshooting
118
-
119
- **Problem**: `Error: Cask 'drawio' is not installed`
120
-
121
- **Solution**: The cask name may have changed. Search for the current name:
122
-
123
- ```bash
124
- brew search drawio
125
- ```
126
-
127
- **Problem**: Application fails to open with "damaged" warning
128
-
129
- **Solution**: Remove the quarantine attribute:
130
-
131
- ```bash
132
- xattr -cr /Applications/draw.io.app
133
- ```
134
-
135
- **Problem**: Homebrew is not in PATH after installation
136
-
137
- **Solution**: Add Homebrew to your PATH. For Apple Silicon Macs:
138
-
139
- ```bash
140
- echo 'eval "$(/opt/homebrew/bin/brew shellenv)"' >> ~/.zprofile
141
- eval "$(/opt/homebrew/bin/brew shellenv)"
142
- ```
143
-
144
- ---
145
-
146
- ### Ubuntu/Debian (Snap)
147
-
148
- #### Prerequisites
149
-
150
- - Ubuntu 16.04 LTS or later, or Debian 9 or later
151
- - snapd package manager (pre-installed on Ubuntu 16.04+)
152
- - sudo privileges
153
-
154
- Snap is the recommended installation method for Ubuntu/Debian as it provides automatic updates and consistent behavior across distributions.
155
-
156
- First, ensure snapd is installed and up to date:
157
-
158
- ```bash
159
- sudo DEBIAN_FRONTEND=noninteractive apt-get update -y
160
- sudo DEBIAN_FRONTEND=noninteractive apt-get install -y snapd
161
- ```
162
-
163
- #### Installation Steps
164
-
165
- Run the following command to install Draw.io:
166
-
167
- ```bash
168
- sudo snap install drawio
169
- ```
170
-
171
- Snap handles all dependencies automatically and will keep Draw.io updated in the background.
172
-
173
- #### Verification
174
-
175
- Confirm the installation succeeded:
176
-
177
- ```bash
178
- snap list drawio
179
- ```
180
-
181
- Expected output (version numbers may vary):
182
-
183
- ```
184
- Name Version Rev Tracking Publisher Notes
185
- drawio 28.2.5 123 latest/stable jgraph -
186
- ```
187
-
188
- Launch Draw.io to verify it works:
189
-
190
- ```bash
191
- drawio &
192
- ```
193
-
194
- Or from the application menu, search for "draw.io" or "diagrams.net".
195
-
196
- #### Troubleshooting
197
-
198
- **Problem**: `error: snap "drawio" is not available on stable for this architecture`
199
-
200
- **Solution**: The Snap package may not support your CPU architecture. Use the alternative .deb installation method:
201
-
202
- ```bash
203
- # Download the latest .deb package
204
- curl -s https://api.github.com/repos/jgraph/drawio-desktop/releases/latest | grep "browser_download_url.*amd64.*\.deb" | cut -d '"' -f 4 | xargs -I {} curl -L -o /tmp/drawio.deb {}
205
- # Install the package
206
- sudo DEBIAN_FRONTEND=noninteractive apt-get install -y /tmp/drawio.deb
207
- ```
208
-
209
- **Problem**: Draw.io cannot access files in certain directories
210
-
211
- **Solution**: Snap applications have limited file system access by default. Grant additional permissions:
212
-
213
- ```bash
214
- sudo snap connect drawio:removable-media
215
- ```
216
-
217
- **Problem**: `snap: command not found`
218
-
219
- **Solution**: Install snapd:
220
-
221
- ```bash
222
- sudo DEBIAN_FRONTEND=noninteractive apt-get update -y
223
- sudo DEBIAN_FRONTEND=noninteractive apt-get install -y snapd
224
- sudo systemctl enable --now snapd.socket
225
- sudo ln -s /var/lib/snapd/snap /snap
226
- ```
227
-
228
- Log out and log back in for PATH changes to take effect.
229
-
230
- ---
231
-
232
- ### Raspberry Pi OS (Snap or Manual)
233
-
234
- #### Prerequisites
235
-
236
- - Raspberry Pi OS (64-bit recommended) - Bookworm or Bullseye
237
- - Raspberry Pi 3B+ or later (64-bit capable hardware)
238
- - At least 2 GB RAM
239
- - sudo privileges
240
-
241
- First, verify your architecture:
242
-
243
- ```bash
244
- uname -m
245
- ```
246
-
247
- - `aarch64` = 64-bit (recommended, more packages available)
248
- - `armv7l` = 32-bit (limited package availability)
249
-
250
- **Important**: Draw.io Desktop ARM64 packages are available from GitHub releases. Snap packages may have limited ARM support.
251
-
252
- #### Installation Steps
253
-
254
- **For 64-bit Raspberry Pi OS (aarch64):**
255
-
256
- Install via Snap (if available for your architecture):
257
-
258
- ```bash
259
- # Install and configure snapd
260
- sudo DEBIAN_FRONTEND=noninteractive apt-get update -y
261
- sudo DEBIAN_FRONTEND=noninteractive apt-get install -y snapd
262
- sudo reboot
263
- ```
264
-
265
- After reboot:
266
-
267
- ```bash
268
- sudo snap install core
269
- sudo snap install drawio
270
- ```
271
-
272
- **Alternative: Install from .deb package (Recommended for ARM64):**
273
-
274
- If Snap does not work on your architecture, download and install the ARM64 .deb package directly:
275
-
276
- ```bash
277
- # Download the latest ARM64 .deb package
278
- curl -s https://api.github.com/repos/jgraph/drawio-desktop/releases/latest | grep "browser_download_url.*arm64.*\.deb" | cut -d '"' -f 4 | xargs -I {} curl -L -o /tmp/drawio-arm64.deb {}
279
-
280
- # Install the package and resolve dependencies
281
- sudo DEBIAN_FRONTEND=noninteractive apt-get update -y
282
- sudo DEBIAN_FRONTEND=noninteractive apt-get install -y /tmp/drawio-arm64.deb
283
- ```
284
-
285
- **For 32-bit Raspberry Pi OS (armv7l):**
286
-
287
- Draw.io Desktop does not officially provide 32-bit ARM packages. Use the web version instead:
288
-
289
- 1. Open Chromium browser on your Raspberry Pi
290
- 2. Navigate to https://app.diagrams.net
291
- 3. The web application provides the same functionality as the desktop app
292
-
293
- #### Verification
294
-
295
- For Snap installation:
296
-
297
- ```bash
298
- snap list drawio
299
- ```
300
-
301
- For .deb installation:
302
-
303
- ```bash
304
- dpkg -l | grep drawio
305
- ```
306
-
307
- Launch Draw.io:
308
-
309
- ```bash
310
- drawio &
311
- ```
312
-
313
- #### Troubleshooting
314
-
315
- **Problem**: Snap installation fails with architecture error
316
-
317
- **Solution**: Use the .deb package installation method described above for ARM64, or use the web version for 32-bit systems.
318
-
319
- **Problem**: Application is slow or unresponsive
320
-
321
- **Solution**: Draw.io is an Electron application which can be resource-intensive. Ensure you have adequate RAM (2 GB minimum, 4 GB recommended) and consider closing other applications.
322
-
323
- **Problem**: Dependency errors when installing .deb package
324
-
325
- **Solution**: Fix broken dependencies:
326
-
327
- ```bash
328
- sudo DEBIAN_FRONTEND=noninteractive apt-get install -y -f
329
- ```
330
-
331
- ---
332
-
333
- ### Amazon Linux (RPM Manual Installation)
334
-
335
- #### Prerequisites
336
-
337
- - Amazon Linux 2023 (AL2023) or Amazon Linux 2 (AL2)
338
- - sudo privileges
339
- - curl and wget installed
340
-
341
- **Note**: Draw.io is not available in Amazon Linux's default repositories. Install the RPM package directly from GitHub releases.
342
-
343
- #### Installation Steps
344
-
345
- **For Amazon Linux 2023 (DNF):**
346
-
347
- ```bash
348
- # Install required dependencies
349
- sudo dnf install -y wget curl libxkbfile libsecret nss
350
-
351
- # Download the latest x86_64 RPM package
352
- curl -s https://api.github.com/repos/jgraph/drawio-desktop/releases/latest | grep "browser_download_url.*x86_64.*\.rpm" | cut -d '"' -f 4 | xargs -I {} curl -L -o /tmp/drawio.rpm {}
353
-
354
- # Install the package
355
- sudo dnf install -y /tmp/drawio.rpm
356
- ```
357
-
358
- **For Amazon Linux 2 (YUM):**
359
-
360
- ```bash
361
- # Install required dependencies
362
- sudo yum install -y wget curl libxkbfile libsecret nss
363
-
364
- # Download the latest x86_64 RPM package
365
- curl -s https://api.github.com/repos/jgraph/drawio-desktop/releases/latest | grep "browser_download_url.*x86_64.*\.rpm" | cut -d '"' -f 4 | xargs -I {} curl -L -o /tmp/drawio.rpm {}
366
-
367
- # Install the package
368
- sudo yum install -y /tmp/drawio.rpm
369
- ```
370
-
371
- #### Verification
372
-
373
- Confirm the installation succeeded:
374
-
375
- ```bash
376
- rpm -qa | grep drawio
377
- ```
378
-
379
- Expected output (version numbers may vary):
380
-
381
- ```
382
- drawio-29.2.9-1.x86_64
383
- ```
384
-
385
- Launch Draw.io (requires X11 display):
386
-
387
- ```bash
388
- drawio &
389
- ```
390
-
391
- #### Troubleshooting
392
-
393
- **Problem**: Missing library dependencies
394
-
395
- **Solution**: Install common Electron dependencies:
396
-
397
- ```bash
398
- # For AL2023
399
- sudo dnf install -y gtk3 libdrm mesa-libgbm alsa-lib
400
-
401
- # For AL2
402
- sudo yum install -y gtk3 libdrm mesa-libgbm alsa-lib
403
- ```
404
-
405
- **Problem**: "cannot open display" error
406
-
407
- **Solution**: Draw.io is a GUI application requiring a graphical environment. On headless servers, use X11 forwarding:
408
-
409
- ```bash
410
- ssh -X user@amazon-linux-host
411
- drawio &
412
- ```
413
-
414
- Or use the web version at https://app.diagrams.net for server environments.
415
-
416
- **Problem**: RPM verification fails
417
-
418
- **Solution**: Import the GPG key or skip verification (less secure):
419
-
420
- ```bash
421
- sudo rpm --import https://github.com/jgraph.gpg
422
- # Or skip verification
423
- sudo rpm -ivh --nosignature /tmp/drawio.rpm
424
- ```
425
-
426
- ---
427
-
428
- ### Windows (Chocolatey)
429
-
430
- #### Prerequisites
431
-
432
- - Windows 10 version 1809 or later (64-bit), or Windows 11
433
- - Administrator PowerShell or Command Prompt
434
- - Chocolatey package manager installed
435
-
436
- If Chocolatey is not installed, install it first by running this command in an Administrator PowerShell:
437
-
438
- ```powershell
439
- Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://community.chocolatey.org/install.ps1'))
440
- ```
441
-
442
- #### Installation Steps
443
-
444
- Run the following command in an Administrator PowerShell or Command Prompt:
445
-
446
- ```powershell
447
- choco install drawio -y
448
- ```
449
-
450
- The `-y` flag automatically confirms all prompts, enabling fully non-interactive installation. The Chocolatey package uses the `/S` (silent) flag internally for the installer.
451
-
452
- #### Verification
453
-
454
- Confirm the installation succeeded:
455
-
456
- ```powershell
457
- choco list drawio
458
- ```
459
-
460
- Expected output (version numbers may vary):
461
-
462
- ```
463
- drawio 29.2.9
464
- 1 packages installed.
465
- ```
466
-
467
- Launch Draw.io from the Start Menu or via command line:
468
-
469
- ```powershell
470
- start "" "C:\Program Files\draw.io\draw.io.exe"
471
- ```
472
-
473
- #### Troubleshooting
474
-
475
- **Problem**: Installation fails with access denied error
476
-
477
- **Solution**: Ensure you are running PowerShell or Command Prompt as Administrator. Right-click the terminal icon and select "Run as administrator".
478
-
479
- **Problem**: `choco: command not found`
480
-
481
- **Solution**: Chocolatey was not installed correctly or PATH was not updated. Close and reopen PowerShell, or reinstall Chocolatey.
482
-
483
- **Problem**: Application does not appear after installation
484
-
485
- **Solution**: The installer may require a system restart. If that does not help, verify the installation:
486
-
487
- ```powershell
488
- Get-ChildItem "C:\Program Files\draw.io"
489
- ```
490
-
491
- ---
492
-
493
- ### WSL (Ubuntu)
494
-
495
- #### Prerequisites
496
-
497
- - Windows 10 version 2004 or higher, or Windows 11
498
- - WSL 2 enabled with Ubuntu distribution installed
499
- - sudo privileges within WSL
500
- - X11 server running on Windows (for GUI applications)
501
-
502
- **Important**: Draw.io is a GUI application. Running it in WSL requires an X11 server on Windows to display the window.
503
-
504
- #### Installation Steps
505
-
506
- **Step 1: Install an X11 server on Windows**
507
-
508
- Install VcXsrv or similar X11 server on Windows:
509
-
510
- ```powershell
511
- # Run in Windows PowerShell as Administrator
512
- choco install vcxsrv -y
513
- ```
514
-
515
- Launch XLaunch from the Start Menu with default settings (Multiple windows, Start no client, Disable access control).
516
-
517
- **Step 2: Configure WSL for X11 display**
518
-
519
- In WSL Ubuntu, configure the DISPLAY variable:
520
-
521
- ```bash
522
- # For WSL 2
523
- echo 'export DISPLAY=$(grep -m 1 nameserver /etc/resolv.conf | awk "{print \$2}"):0' >> ~/.bashrc
524
- source ~/.bashrc
525
- ```
526
-
527
- **Step 3: Install Draw.io via Snap**
528
-
529
- ```bash
530
- # Install snapd if not present
531
- sudo DEBIAN_FRONTEND=noninteractive apt-get update -y
532
- sudo DEBIAN_FRONTEND=noninteractive apt-get install -y snapd
533
-
534
- # Install Draw.io
535
- sudo snap install drawio
536
- ```
537
-
538
- #### Verification
539
-
540
- Confirm the installation succeeded:
541
-
542
- ```bash
543
- snap list drawio
544
- ```
545
-
546
- Launch Draw.io (ensure X11 server is running on Windows):
547
-
548
- ```bash
549
- drawio &
550
- ```
551
-
552
- A Draw.io window should appear on your Windows desktop.
553
-
554
- #### Troubleshooting
555
-
556
- **Problem**: `Error: cannot open display`
557
-
558
- **Solution**: Ensure the X11 server is running on Windows and DISPLAY is set correctly:
559
-
560
- ```bash
561
- echo $DISPLAY
562
- ```
563
-
564
- If empty or incorrect, set it manually:
565
-
566
- ```bash
567
- export DISPLAY=$(grep -m 1 nameserver /etc/resolv.conf | awk '{print $2}'):0
568
- ```
569
-
570
- **Problem**: Snap does not work in WSL
571
-
572
- **Solution**: Snap requires systemd which is not enabled by default in WSL. Enable systemd:
573
-
574
- ```bash
575
- echo -e "[boot]\nsystemd=true" | sudo tee /etc/wsl.conf
576
- ```
577
-
578
- Then restart WSL from Windows PowerShell:
579
-
580
- ```powershell
581
- wsl --shutdown
582
- ```
583
-
584
- Re-open WSL and retry the Snap installation.
585
-
586
- **Problem**: Window appears but is blank or crashes
587
-
588
- **Solution**: Try running with software rendering:
589
-
590
- ```bash
591
- drawio --disable-gpu &
592
- ```
593
-
594
- ---
595
-
596
- ### Git Bash (Windows Portable Installation)
597
-
598
- #### Prerequisites
599
-
600
- - Windows 10 or Windows 11 (64-bit)
601
- - Git Bash installed (comes with Git for Windows)
602
- - Internet connection to download the portable package
603
-
604
- **Note**: Git Bash runs on Windows, so the primary installation method is the Windows Chocolatey installation (see Windows section). However, if you cannot use Chocolatey or need a portable installation, follow these steps.
605
-
606
- #### Installation Steps
607
-
608
- Download and extract the portable Windows ZIP package:
609
-
610
- ```bash
611
- # Create a directory for portable applications
612
- mkdir -p ~/portable-apps
613
-
614
- # Download the latest Windows ZIP (portable version)
615
- curl -L -o /tmp/drawio.zip "$(curl -s https://api.github.com/repos/jgraph/drawio-desktop/releases/latest | grep 'browser_download_url.*windows\.zip' | head -1 | cut -d '"' -f 4)"
616
-
617
- # Extract to portable apps directory
618
- unzip -q /tmp/drawio.zip -d ~/portable-apps/drawio
619
-
620
- # Clean up
621
- rm /tmp/drawio.zip
622
- ```
623
-
624
- Add an alias for easy access from Git Bash:
625
-
626
- ```bash
627
- echo 'alias drawio="~/portable-apps/drawio/draw.io.exe"' >> ~/.bashrc
628
- source ~/.bashrc
629
- ```
630
-
631
- #### Verification
632
-
633
- Confirm the installation succeeded:
634
-
635
- ```bash
636
- ls ~/portable-apps/drawio/
637
- ```
638
-
639
- Expected output should include `draw.io.exe` and supporting files.
640
-
641
- Launch Draw.io:
642
-
643
- ```bash
644
- drawio &
645
- ```
646
-
647
- Or directly:
648
-
649
- ```bash
650
- ~/portable-apps/drawio/draw.io.exe &
651
- ```
652
-
653
- #### Troubleshooting
654
-
655
- **Problem**: `unzip: command not found`
656
-
657
- **Solution**: Install unzip via Git Bash's package manager or use Windows built-in extraction:
658
-
659
- ```bash
660
- # Alternative using PowerShell from Git Bash
661
- powershell -command "Expand-Archive -Path '/tmp/drawio.zip' -DestinationPath '$HOME/portable-apps/drawio'"
662
- ```
663
-
664
- **Problem**: Permission denied when running the executable
665
-
666
- **Solution**: Windows may have blocked the downloaded file. Unblock it:
667
-
668
- ```bash
669
- powershell -command "Unblock-File -Path '$HOME/portable-apps/drawio/draw.io.exe'"
670
- ```
671
-
672
- **Problem**: PATH issues with spaces in directory names
673
-
674
- **Solution**: Ensure the path is quoted correctly in aliases and commands. Use Windows-style paths if needed:
675
-
676
- ```bash
677
- alias drawio='"/c/Users/YourName/portable-apps/drawio/draw.io.exe"'
678
- ```
679
-
680
- ---
681
-
682
- ## Post-Installation Configuration
683
-
684
- After installing Draw.io on any platform, consider these optional configurations.
685
-
686
- ### Setting Default File Format
687
-
688
- Draw.io supports multiple file formats. To set a default:
689
-
690
- 1. Open Draw.io
691
- 2. Go to File > Properties
692
- 3. Set your preferred default format (`.drawio`, `.drawio.xml`, `.drawio.svg`, `.drawio.png`)
693
-
694
- ### Configuring Automatic Updates
695
-
696
- **macOS (Homebrew)**: Updates are manual. Run periodically:
697
-
698
- ```bash
699
- brew upgrade --cask drawio
700
- ```
701
-
702
- **Linux (Snap)**: Updates are automatic via snapd.
703
-
704
- **Windows (Chocolatey)**: Run periodically:
705
-
706
- ```powershell
707
- choco upgrade drawio -y
708
- ```
709
-
710
- ### Disabling Update Checks
711
-
712
- If you prefer to control updates manually, you can disable automatic update checks:
713
-
714
- 1. Open Draw.io
715
- 2. Go to Help > Check for Updates
716
- 3. Disable automatic checking
717
-
718
- ### Integrating with Version Control
719
-
720
- Draw.io files (`.drawio`) are XML-based and can be version-controlled with Git. For better diff support:
721
-
722
- 1. Save diagrams as `.drawio.svg` or `.drawio.png` for visual diffs
723
- 2. Or use `.drawio.xml` for text-based diffs
724
-
725
- ---
726
-
727
- ## Common Issues
728
-
729
- ### Issue: Application Takes Long Time to Start
730
-
731
- **Symptoms**: Draw.io shows a blank window or loading indicator for an extended period.
732
-
733
- **Solutions**:
734
-
735
- - Disable hardware acceleration: Launch with `--disable-gpu` flag
736
- - Clear application cache (location varies by platform)
737
- - Ensure sufficient system resources are available
738
-
739
- ### Issue: Cannot Open Files from Network Drives
740
-
741
- **Symptoms**: Error when trying to open diagrams stored on network shares.
742
-
743
- **Solutions**:
744
-
745
- - Copy the file locally first, then open it
746
- - On Linux Snap installations, connect the removable-media interface:
747
-
748
- ```bash
749
- sudo snap connect drawio:removable-media
750
- ```
751
-
752
- ### Issue: Export to PDF Fails
753
-
754
- **Symptoms**: PDF export produces blank or corrupted files.
755
-
756
- **Solutions**:
757
-
758
- - Ensure the diagram is not empty
759
- - Try exporting to PNG first, then convert to PDF
760
- - Update to the latest version of Draw.io
761
-
762
- ### Issue: Fonts Appear Incorrect
763
-
764
- **Symptoms**: Diagram text uses incorrect or fallback fonts.
765
-
766
- **Solutions**:
767
-
768
- - Install the required fonts on your system
769
- - Use web-safe fonts for maximum compatibility
770
- - Embed fonts when exporting (File > Export As > Advanced Options)
771
-
772
- ### Issue: Slow Performance with Large Diagrams
773
-
774
- **Symptoms**: Application becomes sluggish with complex diagrams.
775
-
776
- **Solutions**:
777
-
778
- - Split large diagrams into multiple pages
779
- - Reduce the use of complex shapes and gradients
780
- - Increase available system memory
781
- - Disable "Connection Arrows" for complex diagrams
782
-
783
- ---
784
-
785
- ## References
786
-
787
- - [Draw.io Official Website](https://www.drawio.com/)
788
- - [Draw.io Desktop GitHub Repository](https://github.com/jgraph/drawio-desktop)
789
- - [Draw.io Desktop Releases](https://github.com/jgraph/drawio-desktop/releases)
790
- - [Homebrew Cask - drawio](https://formulae.brew.sh/cask/drawio)
791
- - [Snap Store - drawio](https://snapcraft.io/drawio)
792
- - [Chocolatey Package - drawio](https://community.chocolatey.org/packages/drawio)
793
- - [Draw.io Desktop Documentation](https://www.drawio.com/blog/diagrams-offline)
794
- - [Installing Snap on Raspberry Pi OS](https://snapcraft.io/docs/installing-snap-on-raspbian)
795
- - [Draw.io Silent Installation Guide](https://silentinstallhq.com/draw-io-silent-install-how-to-guide/)