Theme Slots Tool For Sharepoint

  

  1. Free Sharepoint Tools
  2. Free Sharepoint Themes
-->

The SharePoint (classic) Color Palette Tool exposes 90 color slot settings. The UI Fabric Theme Designer has trimmed that number down to 21 color slot settings. (There are actually 22 slots that appear in an exported theme files, but only 21 of them are available in the UI application.) For reference, here are the mapped values between.

Composed looks are out-of-the-box themes that are included in SharePoint and SharePoint Online. Apply composed looks, including colors, fonts, and a background image, to your SharePoint and SharePoint Online sites by using the SharePoint theming engine.

Important

This extensibility option is only available for classic SharePoint experiences. You cannot use this option with modern experiences in SharePoint Online, like with communication sites.

To apply a composed look to a SharePoint site, select Site Settings > Look and Feel > Change the look. You can then use the Change the Look Wizard to customize the colors, fonts, master page, and background image of a composed look. The Change the Look Wizard copies, transforms, and stores CSS in SharePoint's content database. It also recolors images and stores them in the content database.

SharePoint theming engine

You can use the SharePoint theming engine to apply colors, fonts, and a background image to a site by associating those elements with a master page.

In SharePoint and SharePoint Online, a theme is a connected set of XML definition files, an image file, and an associated master page that you can use to apply custom CSS to a site.

The following XML files define color slots and font slots that define the details of specific colors and fonts as they're applied to styles:

  • .spcolor
  • .spfont

You can create your own color and font files in your favorite text editor.

Free Sharepoint Tools

The following table lists the elements of a composed look.

Table 1. Elements of a composed look

ElementFile or filesWhere it's storedRequired?
Color palette.spcolorTheme Gallery15 folderYes
Font scheme.spfontTheme Gallery15 folderNo
Site layout

.master

.preview

Master Page GalleryYes
Background image

.jpg

.bmp

.png

.gif

Site assetsNo

Users can select composed looks by using the Change the Look Wizard (Site Settings > Look and Feel > Change the Look), the Getting Started UI, or directly in the site actions menu. When a user selects a composed look, the theming engine applies colors, fonts, background images, the associated .master page, and the .preview file associated with the .master page to the site.

Color palettes

The theming engine stores colors in color palettes defined by the .spcolor file, as shown in the following figure.

Color palettes are stored in the Theme Gallery of the root site. A color palette is an editable XML file made up of color palette definitions and color slots.

Color palette metadata (<s:colorPalette>) defines the following:

  • Three preview slots that define what color slots to use in composed look previews.
  • An isInverted property that lets the palette designer specify whether the theme is inverted (dark background with light text).
  • The XML namespace associated with the theme.

Color slots are defined by two attributes—color name and value&mdaash;that define a name for the color and its RGB value. Color slots have semantic names, such as BodyText or SiteTitle, which help you identify which slots correspond to a region of a SharePoint page.

Line 2 of the .spcolor file defines the XML namespace, preview slots, and whether colors are inverted (they have a light foreground on a dark background instead of a dark foreground on a light background).

The .spcolor file contains 89 color slots. You can use color slots to define richer aspects of color, including opacity, by using 8-digit hexadecimal values. For example, if green is RRGGBB 00FF00, a 70 percent opaque green is AARRGGBB 7F00FF00. If SharePoint uses a slot that you don't define, any CSS that references it won't change color. If a slot is defined that is never referenced in CSS, the color is never shown in the UI.

You can edit the .spcolor file in Notepad. You cannot edit it in PowerPoint.

Color palette tool

You can use the color palette tool to visualize theme colors and how they work together on the page. Use it to identify color information that you can use in the color slots of the .spcolor file, and apply colors to a SharePoint site without changing any CSS as part of the process.

The tool displays the colors in hexadecimal format so that you can easily copy and paste the color value into the appropriate element in your .spcolor file. You can also use the color palette tool to fit a background image into a mockup and toggle between the seattle.master and oslo.master master pages.

Color palette tool

The .spcolor file is the only file that is required for a new theme, but you might need to add some custom font declarations, depending on the depth of your design. To do that, you need to access the .spfont file.

Font schemes

In the same way that color palettes define how colors are used in composed looks, font schemes define the fonts in composed looks.

Font schemes are defined in the .spfont file stored in the Theme Gallery. The .spfont file includes the following font slots that define the name, typeface, and script values of a composed look:

  • Title
  • Navigation
  • Small-heading
  • Heading
  • Large-heading
  • Body
  • Large-body

Free Sharepoint Themes

Fonts are further scoped by script type (for example, Latin, Arabic, Cyrillic). Web fonts support is included in four file types:

  • Embedded open type (EOT)
  • Web open font format file (WOFF)
  • TrueType font (TTF)
  • Scalable vector graphics (SVG)

The font scheme defines a large preview image and a small preview image. They are required only for web fonts.

Note

You can edit the .spfont file in Notepad. You cannot edit it in PowerPoint.

The following is an example of an .spfont file.

Site layout: master pages and corresponding preview files

The theming engine defines the site layout of a composed look based on the .master master page and its corresponding .preview file. For example, if the master page defined for the composed look is seattle.master, that master page defines the layout of the site.

The site layout is pulled from the Master Page Gallery of any master pages that have accompanying .preview files. A .preview file is required for a master page to appear as an option in the Change the look UI (Site Settings > Look and Feel > Change the look).

To make a master page available from the Site Layout menu, create a .preview file that corresponds to the .master page. The .preview file displays thumbnail images for the composed look and the preview section to the right of the Change the look options on the designbuilder.aspx page.

Background image

You can change the background image of a composed look by choosing Change. This opens an upload dialog box that you can use to upload an image file. You can also drag your own image onto the background preview.

Create custom themes

To create a custom theme:

  1. Go to Site settings, and under the Web Designer Galleries heading, select Themes > 15. A list of .spcolor and .spfont files appears, as shown here.

  2. Download a copy of one of the .spcolor files (for example, Palette001.spcolor) and open it in a text editor.

  3. Edit the copied .spcolor file to reflect your design guidelines. For example, if you have a black font for main body text, edit the file to change the line <s:color name='BodyText' value='444444' /> to <s:color name='BodyText' value='000000' />.

  4. For each HTML element, add your color.

  5. When you are done, upload the .spcolor file to the Site settings > Theme > 15 folder.

    Note

    Save the file with a new file name (for example, custom_palette1.spcolor).

    The following table maps colors and page elements to their code in the .spcolor file. It is a subset of the mappings that are available in the .spcolor file.

    Table 2. Mapping of colors and page elements to .spcolor file

    ElementColorCode
    Body textBlack<s:color name='BodyText' value='000000' />
    Global navigation backgroundBlue<s:color name='HeaderBackground' value='018dff' />
    Global navigation textWhite<s:color name='HeaderNavigationText' value='ffffff' />
    Current navigation backgroundRed<s:color name='NavigationHoverBackground' value='e51400' />
    Current navigation textWhite<s:color name='Navigation' value='ffffff' />
    TitleWhite<s:color name='SiteTitle' value='FFFFFF' />
    Footer backgroundBlack<s:color name='FooterBackground' value='000000' />
  6. To customize .spfont, download a copy of an .spfont file and open it in a text editor. Notice that the .spfont file is laid out a bit differently than .spcolor, but that both files share a similar structure.

  7. Edit each <s:fontSlot /> section to customize the font that SharePoint applies to the specified font slot on the page. For example, notice the first entry, <s:fontSlot name='title'>. This entry describes which font SharePoint uses to style the title of the page. This section also specifies which font is used for different languages.

    Note

    You can upload custom fonts to SharePoint and point each entry to a custom .eot, .woff, .ttf, and .svg file.

  8. Upload the file to the Site settings > Theme > 15 folder.

    Note

    Save the file with a new file name (for example, custom_font.spfont).

    The following table maps page elements to fonts as they're defined in the .spfont file.

    Table 3. Mapping of page elements to fonts

    ElementFontCode
    TitleOpen Sans<s:cs typeface='Open Sans' />
    NavigationRoboto<s:cs typeface='Roboto' />
    HeadingsTrajan Pro<s:cs typeface='Trajan Pro' />
    BodyOpen Sans<s:cs typeface='Open Sans' />

    You might have to ensure that some custom fonts are available to users' browsers. For example, if the headings refer to a Trajan Pro font, which is uncommon on most users' computers, add the following font declarations at the top of the <s:fontSlot> declaration. This will ensure that the correct font is displayed.

Add a custom theme to SharePoint

After you make your customizations to the master page, .spcolor, and .spfont files, add them to the Composed Looks directory so that SharePoint can access them.

  1. Go to Site settings, and under Web Designer Galleries, select Composed Looks.

  2. Choose the new item link at the top left. The following window opens.

  3. Add a title and a name for your composed look.

  4. Complete the remaining fields:

    • In the Master Page URL field, add the URL of the master page that you would like the theme to use.

    • In Theme URL, add the URL of the .spcolor file.

    • In Image URL, include the URL of an image that you want to use as a background. This is not required if your design doesn't call for a background image.

    • In Font Scheme URL, include the URL of the .spfont file.

    • In Display Order, indicate the order in which the composed look should be displayed.

  5. Choose Save. Your theme entry appears in the Composed Looks list.

After you add your custom theme as a composed look, users can access the theme and apply it to a site by going to Site settings > Look and Feel > Change the look.

Theme Slots Tool For Sharepoint

The following figure shows an example of a Change the look section in Site Settings.

What the theming engine does when a user applies a composed look

Free sharepoint tools

When a user applies a composed look, SharePoint copies, transforms, and stores CSS in the content database. It also recolors and stores images in the content database. As part of the process of applying a theme to a site, the theming engine pulls color and font values from the specified color palette and font scheme found in the Theme Gallery of the root site. To apply .master page and the master page .preview file (the site layout), the theming engine pulls master pages in the Master Page Gallery that have a corresponding .preview file.

When it applies a composed look, the engine maps the settings specified by specific CSS comments that the theming engine defines. Under the hood, the theming engine saves the background image to Site Assets, scales and compresses JPG and BMP images, and limits the size of GIF and PNG images.

When a composed look is applied to a SharePoint site, SharePoint finds and replaces CSS comment tokens by embedding a value derived from the composed look in the next line in the CSS file after the token. This new value is applied to the SharePoint site.

The following table lists the CSS comment tokens.

Table 4. CSS comment tokens

TokenDescriptionCorresponding ApplyTheme parameter
/* ReplaceBGImage */Swaps current background image with the image in the assigned composed look image URL.backgroundImageUrl
/* ReplaceFont */Swaps the current font with one of the fonts found in the font scheme URL of the assigned composed look.fontSchemeUrl
/* ReplaceColor */Swaps the current color with one of the colors specified in a color slot in the color palette URL of the assigned composed look.colorPaletteUrl
/* RecolorImage */Recolors images using tinting or filling.

See also

Do you need to create a Modern theme based on an existing Classic theme? Or have you found that you need to leverage both Modern and Classic themes in your O365 SharePoint environment to ensure a consistent experience? Me, too!
So I created this app. :-)

NOTE: This application only works with valid SPColor file and UI Fabric Theme Designer JSON file inputs.

  1. Open the Program.cs file and add input and output local path values for the relevant conversion method(s) you need: ClassicToModern() or ModernToClassic().
  2. Uncomment the relevant conversion method(s) you need.
  3. Run the program.

The SharePoint (classic) Color Palette Tool exposes ~90 color slot settings. The UI Fabric Theme Designer has trimmed that number down to 21 color slot settings. (There are actually 22 slots that appear in an exported theme files, but only 21 of them are available in the UI application.)

For reference, here are the mapped values between SharePoint Modern and Classic theme palette slots:

Modern Palette SlotsClassic Palette Slots
themePrimaryAccentText
Hyperlink
Hyperlinkfollowed
CommandLinksHoverRowAccent
NavigationAccent
NavigationHover
EmphasisBackground
HeaderNavigationHoverText
HeaderNavigationSelectedText
SuiteBarBackground
ContentAccent1
ContentAccent2
ContentAccent3
ContentAccent4
ContentAccent5
ContentAccent6
neutralPrimaryBodyText
WebPartHeading
SearchURL
HeaderText
ButtonText
ButtonGlyphActive
whiteBackgroundOverlay
PageBackground
HeaderBackground
FooterBackground
EmphasisText
SuiteBarText
TileText
themeLighterAltButtonHoverBackground
themeLighterSelectionBackground
HoverBackground
NavigationHoverBackground
themeLightStrongLines
HeaderStrongLines
ButtonPressedBackground
ButtonHoverBorder
themeTertiarySuiteBarHoverBackground
themeSecondaryAccentLines
HeaderAccentLines
ButtonPressedBorder
themeDarkAltEmphasisHoverBackground
EmphasisBorder
themeDarkHyperlinkActive
themeDarkerCommandLinksPressed
NavigationPressed
EmphasisHoverBorder
HeaderNavigationPressedText
TileBackgroundOverlay
neutralLighterAltDisabledBackground
HeaderDisabledBackground
ButtonBackground
ButtonDisabledBackground
neutralLighterNavigationSelectedBackground
SubtleEmphasisBackground
TopBarBackground
neutralLightDisabledLines
DialogBorder
HeaderDisabledLines
ButtonDisabledBorder
neutralQuaternaryAltHeaderFlyoutBorder
neutralQuaternaryNo Modern Designer setting available
neutralTertiaryAltSubtleLines
HeaderSubtleLines
SuiteBarDisabledText
ButtonGlyphDisabled
neutralTertiaryDisabledText
CommandLinksDisabled
HeaderDisableText
ButtonDisabledText
neutralSecondaryLines
HeaderLines
ButtonBorder
neutralPrimaryAltSubtleBodyText
HeaderSubtleText
neutralDarkCommandLinks
Navigation
SubtleEmphasisText
TopBarText
HeaderNavigationText
ButtonGlyph
blackStrongBodyText
SiteTitle
CommandLinksSecondary
SubtleEmphasisCommandLinks
TopBarHoverText
TopBarPressedText
HeaderSiteTitle

Converted Classic Theme (Preview)

Converted Modern Theme (Team Site Home Page)