forked from mvdbent/setDock
-
Notifications
You must be signed in to change notification settings - Fork 0
/
setDock-defaultDockOutset.sh
executable file
·244 lines (220 loc) · 9.45 KB
/
setDock-defaultDockOutset.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
#!/bin/bash
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
#
# version 2.0
# Written by: Mischa van der Bent
#
# Permission is granted to use this code in any way you want.
# Credit would be nice, but not obligatory.
# Provided "as is", without warranty of any kind, express or implied.
#
# Original source:
# https://github.com/mvdbent/setDock/blob/main/setDock-defaultDock.sh
#
# DESCRIPTION
# This script configures users docks using docktutil
# source dockutil https://github.com/kcrawford/dockutil/
#
# REQUIREMENTS
# dockutil Version 3.0.0 or higher installed to /usr/local/bin/
# Compatible with macOS 11.x and higher
#
# THIS FORK/VERSION
# This is a modification of Mischa's original by Anthony Reimer to allow more flexibility:
# • Dock items are split into three lists: alwaysApps, alwaysOthers, and optionalItems
# (you no longer have to hardcode "Others" for the right side/bottom end of the Dock).
# • "always" items (Apps and Others) are added even if not present.
# • "optionalItems" (which can be Apps or Others) are only added if present.
# • You are allowed to specify dockutil options for alwaysOthers (in the optionsOthers
# list) and optionalItems (in the optionsOptional list).
# • You must run the script while a user is logged in (e.g., using Outset
# https://github.com/macadmins/outset). Root privileges are not required.
#
# Use setDock-defaultDock.sh instead if you need to run this script as root
# (e.g., executed as part of a Jamf Pro policy).
#
# Source for this fork/version:
# https://github.com/jazzace/setDock/blob/main/setDock-defaultDockOutset.sh
#
# Code last edited 2024-12-11 (added user-specific dock additions)
# (values of the 5 arrays may change without notice here, as this is my production version)
#
# # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # # #
export PATH=/usr/bin:/bin:/usr/sbin:/sbin
# Full path to Applications to add to the Dock every time, even if they are not present on the system yet.
# Items will be added in order. None of the additional options of dockutil are used on these items.
alwaysApps=(
"/System/Applications/Launchpad.app"
"/System/Applications/Mission Control.app"
"/System/Cryptexes/App/System/Applications/Safari.app"
"/Applications/Firefox.app"
"/Applications/Microsoft Edge.app"
"/Applications/Pages.app"
"/Applications/Microsoft Word.app"
"/Applications/Adobe Photoshop 2025/Adobe Photoshop 2025.app"
"/Applications/Adobe Lightroom Classic/Adobe Lightroom Classic.app"
"/Applications/Adobe Bridge 2025/Adobe Bridge 2025.app"
"/Applications/Adobe Illustrator 2025/Adobe Illustrator.app"
"/Applications/DiffusionBee.app"
"/Applications/Vectorworks 2024/Vectorworks 2024.app"
"/Applications/Adobe Premiere Pro 2025/Adobe Premiere Pro 2025.app"
"/Applications/iMovie.app"
"/Applications/ClipGrab.app"
"/Applications/IINA.app"
"/System/Applications/System Settings.app"
"/Applications/Keynote.app"
"/Applications/Microsoft PowerPoint.app"
"/Applications/Max.app"
"/Applications/GarageBand.app"
"/Applications/Amadeus Pro.app"
"/Applications/Audacity.app"
)
# Path to folders and files for the right side of the Dock ("others"); ~/ syntax may be used.
# This list pairs with optionsOthers to specify how you would like these items to be displayed
# (i.e., the first folder listed in alwaysOthers will be run with the options specified on the
# first line of optionsOthers).
alwaysOthers=(
"/Applications"
"/Applications/Utilities/IAML Utilities"
"~/Downloads"
)
# Display options for items in alwaysOthers in order.
# You should have one entry for each entry in alwaysOthers.
# For files, use a pair of quotes (null string) since there are no display options.
optionsOthers=(
"--view grid --display folder --sort name"
"--view grid --display folder --sort name"
"--view list --display folder --sort dateadded"
)
# Path to items to add to the Dock (apps, folders, files) only if they are present.
# This list pairs with optionsOptional to specify how you would like these items to be displayed.
optionalItems=(
"/Applications/Maxon ZBrush 2025/ZBrush.app"
"/Applications/Epson Software/Epson Scan 2.app"
"/Applications/SilverFast Application/SilverFast 9/SilverFast 9.app"
"/Applications/SilverFast Application/SilverFast 8/SilverFast 8.app"
"/Applications/VueScan.app"
"/Applications/Lightwright 6.app"
"/Applications/Final Cut Pro.app"
"/Applications/Logic Pro.app"
"/Applications/Ableton Live 12 Suite.app"
"/Applications/KeyShot11.app"
"/Applications/Vectorworks 2025/Vectorworks 2025.app"
"/Users/Shared/ST-DBLauncher.fmp12"
"/Applications/ON1 Resize AI 2023/ON1 Resize AI 2023.app"
"/Applications/BBEdit.app"
"/System/Applications/Utilities/Activity Monitor.app"
"/System/Applications/Utilities/Console.app"
"/System/Applications/Utilities/Terminal.app"
)
# Display options for items in optionalItems in order.
# You should have one entry for each entry in optionalItems.
# If you do not want to specify options for an item, use a pair of quotes (null string).
#
# Instead of specifying an option, you may specify a username. If it matches the
# currently logged-in user, the item (assuming it exists) will be added at the end of the
# user’s Dock. This is useful for adding technical tools to the Dock of an Admin account.
#
# You must escape or quote (with a different type of quote mark) any argument that has a
# space in it (e.g., "--after 'Microsoft Word'" or "--after Microsoft\ Word").
# Using the app identifier instead of the app name is not supported by this script.
#
# Any relative options (e.g., --before, --after) will be applied to the Dock in the State
# it was in after the "always" apps and others are applied
optionsOptional=(
"--after 'Adobe Illustrator'"
""
""
""
""
"--after 'Adobe Illustrator'"
"--replacing iMovie"
"--replacing GarageBand"
"--before 'Amadeus Pro'"
"--before 'Vectorworks 2024'"
"--replacing 'Vectorworks 2024'"
""
"--after 'Adobe Photoshop 2025'"
"tech"
"tech"
"tech"
"tech"
)
###############################################################
# You should not have to edit any of the code after this line #
###############################################################
# COLLECT IMPORTANT USER INFORMATION
# Get the currently logged in user
currentUser=$( echo "show State:/Users/ConsoleUser" | scutil | awk '/Name :/ { print $3 }' )
# Get uid logged in user
uid=$(id -u "${currentUser}")
# Current User home folder - do it this way in case the folder isn't in /Users
userHome=$(dscl . -read /users/"${currentUser}" NFSHomeDirectory | cut -d " " -f 2)
# Path to plist
plist="${userHome}/Library/Preferences/com.apple.dock.plist"
# Check if dockutil is installed
if [[ -x "/usr/local/bin/dockutil" ]]; then
dockutil="/usr/local/bin/dockutil"
else
echo "dockutil not installed in /usr/local/bin, exiting"
exit 1
fi
# Version dockutil
dockutilVersion=$(${dockutil} --version)
echo "Dockutil version = ${dockutilVersion}"
# Create a clean Dock
"${dockutil}" --remove all --no-restart ${plist}
echo "All items removed from user’s Dock"
# Loop through alwaysApps and add item to the Dock. Log (only) if app is missing.
for app in "${alwaysApps[@]}";
do
"${dockutil}" --add "${app}" --no-restart ${plist};
if [[ ! -e "${app}" ]]; then
echo "${app} not installed but Dock item added"
fi
done
# Need to restart the Dock to allow any relative options to be applied in further commands.
killall -KILL Dock
# Loop through alwaysOthers and add folder/file to the right part of the Dock, even if item is missing.
# Check first to see if there are matching options for each item and log any errors (but do not stop)
itemCount=${#alwaysOthers[@]}
optionsCount=${#optionsOthers[@]}
if [ $itemCount -gt $optionsCount ] ; then
echo "There are more items for the right side of the Dock than there are matching options; some items will receve default options"
elif [ $itemCount -lt $optionsCount ] ; then
echo "There are more options than there are items for the right side of the Dock; results may not be as anticipated"
fi
for (( i=0 ; i<itemCount ; i++));
do
eval "${dockutil}" --add \"${alwaysOthers[i]}\" ${optionsOthers[i]} --no-restart ${plist};
if [[ ! -e "${alwaysOthers[i]}" ]] && [[ "${alwaysOthers[i]:0:1}" != '~' ]] ; then
echo "${alwaysOthers[i]} not present but Dock item added"
fi
done
# Loop through optionalItems and check if item is installed. If installed, add to the Dock
# using the options (or username) specified in optionsOptional
itemCount=${#optionalItems[@]}
optionsCount=${#optionsOptional[@]}
if [ $itemCount -gt $optionsCount ] ; then
echo "There are more optional Dock items than there are matching options; some items will receve default options"
elif [ $itemCount -lt $optionsCount ] ; then
echo "There are more options than there are optional items for the Dock; results may not be as anticipated"
fi
for (( i=0 ; i<itemCount ; i++));
do
if [[ -e "${optionalItems[i]}" ]]; then
optOrUser=${optionsOptional[i]:0:2}
if [ "${optOrUser}" == '--' ] || [ "${optOrUser}" == '' ] ; then # Process option as normal
eval "${dockutil}" --add \"${optionalItems[i]}\" ${optionsOptional[i]} --no-restart ${plist}
elif [ "${optionsOptional[i]}" == "${currentUser}" ] ; then # Process option as a username and only add to Dock if the current username matches
eval "${dockutil}" --add \"${optionalItems[i]}\" --no-restart ${plist}
fi
else
echo "${optionalItems[i]} not present and no Dock item added"
fi
done
# Kill the Dock (again) to use all new settings
killall -KILL Dock
echo "Restarted the Dock"
echo "Finished creating default Dock"
exit 0