Pop_Icons are the standard icons for Pop!_OS. It uses a semi-flat design with raised 3D motifs to help give depth to icons. Included in the theme are flat symbolic (single-color) icons as well as full-color stylized icons.
Pop_Icons take inspiration from the Adwaita GNOME Icons.
This project has mixed licencing. You are free to copy, redistribute and/or modify aspects of this work under the terms of each licence accordingly (unless otherwise specified).
The icon assets (any and all source .svg
files or rendered .png
files) are licenced under the terms of the Creative Commons Attribution-ShareAlike 4.0 License.
Included scripts are free software licenced under the terms of the GNU General Public License, version 3.
When reusing this work please include a proper attribution:
It is recommended to install Pop_Icons through your system package manager, e.g.:
sudo apt update
sudo apt install pop-icon-theme
If your OS does not package Pop_Icons, you can install them from git:
git clone https://github.com/pop-os/icon-theme pop-icon-theme
cd pop-icon-theme
meson build
sudo ninja -C "build" install
By default the theme installs to /usr/
, but you can specify a different directory with a prefix like /usr/local
or $HOME/.local
, for example:
meson -Dprefix=$HOME/.local build
ninja -C "build" install
After which you should be able to pick Pop as your icon or cursor theme in GNOME Tweaks, or you can set either from a terminal with:
# set the icon theme
gsettings set org.gnome.desktop.interface icon-theme "Pop"
# or the cursor theme
gsettings set org.gnome.desktop.interface cursor-theme "Pop"
To uninstall Pop, simply run the following. (If you installed it without superuser priveleges just omit the sudo
.)
sudo ninja -C "build" uninstall
Once uninstalled you can reset your icon and cursor theme to the default setting by running the following.
# reset icon theme to default
gsettings reset org.gnome.desktop.interface icon-theme
# reset cursor theme to default
gsettings reset org.gnome.desktop.interface cursor-theme
Pop uses the meson build system, and can be built using:
meson build
ninja -C build install
Icons and cursors are shipped pre-rendered in order to save time in the event of modifications to the theme as well as reducing build-load on the Pop_OS build servers. Most modifications are rendered using ./master-render.py
. For making/rendering modifications:
The ./master-render.py
script takes care of rendering each different type of file in the theme. Running it by default will render any missing icon files and any updated full-color icons. You can render specific parts of the theme by using the following flags:
-a, --all Render all items (Default)
-f, --fullcolor Render fullcolor icons
-s, --symbolics Render Symbolic Icons
-x, --cursors Render Cursors
-l, --links Generate Theme Symlinks
-m, --metadata Generate Metadata
Using the -c, --clean
option will erase the currently rendered/generated files in the specified, rendering context, which is helpful in the event a source-file is not rendering when it should be. Using it will re-render all files in the specified context, which can take a long time, so use with care. Using the -c
flag with -a, --all
or without another context will erase all files in the theme and require re-rendering all of them, so be extra careful.
Multiple contexts can be combined to render/clean multiple context in one pass, except that any contexts other than -a, --all
will disable --all
so keep that in mind.
The following packages are required to render all of the files within the theme:
python # Running main, full-color, and cursor render scripts
ruby # Running symbolic icons render script
bash # Running symlink script
inkscape # Renders source files to output
python3-pil # Renders cursors
x11-apps # Rendering cursors
Additionally, the following are optional, but will improve the output of the rendering:
scour # Cleaning up unused definitions from full-color/symbolic SVGs
svgo # Optimizing full-color and symbolic SVGs
symlinks # Remove empty symlinks
The full-color icons are stored within the src/fullcolor
folder, and are organized into subdirectories for each category of icon. After making a modification to a source icon, the changes will automatically be rendered into the required icon files by ./master-render.py
; if the script is not rendering your icon, double-check that the file timestamp has been updated and that the source file follows the related formatting requirements in src/fullcolor/README.md
.
The symbolic/single-color icons are stored within the src/scalable/source-symbolic.svg
file. The file has separate layer for each different category of icon within the theme. Ensure when you modify the file, that your icon is located within the correct layer for it to end up in the correct output directory.
Symbolic icons require that you remove the corresponding output icon from the Pop/scalable
folder in order for the master-render.py
script to re-render. The reason for this is that because there is only a single symbolic source-file, we can't re-render a single icon automatically. If you prefer to let the icons re-render automatically and don't mind waiting for all of the symbolics to render, you can do so using ./master-render.py -cls
Additional information about the symbolic icons can be found in src/scalable/README.md
Cursors are stored in the src/cursors
directory. Because cursors are somewhat complicated/difficult to render as they are often animated, and because they use a single source file, they need to be re-rendered each time using ./master-render.py -cx
. You can also manually delete the Pop/cursors
directory. Additional information about rendering the cursors is found in src/cursors/README.md
Pop_Icons uses symbolic links to save on disk space and match a larger number of icon names without needing as many unique icons.
Symbolic link definitions are separated out into fullcolor
for the full-color icons, and scalable
for the symbolic icons. Each directory contains a .list
file for each icon category. Each line in a .list
file defines exactly one output symlink. The format for each line is link-target link-name
similar to the ln
command. For more information regarding symlinks, see the src/symlinks/README.md
file.
Currently theme metadata is stored in the main folder within index.theme.in
and cursor.theme.in
. When the output files of these is generated, these are copied directly into the output folder without modification; automatic generation is a planned feature for a later release. In the meantime, modify these files directly and use ./master-render.py
to copy them to the correct locations.
We happily consider all pull requests sent our way. When submitting a PR, be sure to abide by our Code of Conduct, as submissions in violation will be rejected.
To improve the quality of your submission and increase the chances of acceptance, please consider the following guidelines:
-
Ensure that your contribution is of a generally finished quality. PRs and contributions requiring further development by the Pop_OS team may not be accepted.
-
Follow existing code and design style where possible. Submissions which don't follow our code or design style may require changes to be accepted. Ensure that icons follow our design language and generally "fit in" with the other Pop Icons. When in doubt, mark your PR as a draft and request assistance from a Pop Icons maintainer.
-
Ensure that your changes to icons/cursors follow our in-place development practices. Submissions which add/remove/rename icons within the
Pop
folder without corresponding changes in thesrc
folder will not be accepted. -
Ensure that your icons are rendered out before submitting. Un-render changes will not be visible in the installed theme.
-
Consider doing a full-render of the theme before you submit a PR (
./master-render.py -c
). This will erase any existing output files and ensure the theme is in a good, maintainable state and that your changes have been applied in a way which ensures that they will be carried over in the future. Contributions where running./master-render.py -c
creates a diff verses the gitHEAD
commit will not be accepted! Performing this step prior to submitting your PR will catch many of the above problems before they appear.
You can file an icon request as a GitHub issue. Filing an icon request or reporting a missing icon, please take care in providing the following useful information:
- A screenshot of your issue or an image of the original icon you are requesting to be themed
- The file name for the missing icon or the requested icon, for example
image-adjust.svg
orsystem-shutdown.svg
Note: Pop does not supply icons for third-party applications, only those which come with Pop!_OS.
Pop_Icons use Sam Hewitt's Paper icons as an architectural base, although the icon artwork is new. If you would like to support development by making a donation you can do so here or by becoming a supporter on Patreon or Liberapay.