Theme Developer Tutorial: 3. CSS in Themes

Technically, Discourse uses SCSS to author its stylesheets. However, we’re increasingly moving towards native CSS features as they mature, so the vast majority of themes won’t need to use SCSS features or syntaxes. We follow a variant of BEM for our CSS, you should be familiar with this when writing theme CSS.

This chapter will focus on Discourse-specific subjects, so if you don’t already have a passing familiarity with CSS, take some time to learn about it from CSS styling basics - Learn web development | MDN.

Authoring theme CSS

As we touched on in the last chapter, the main entrypoint for theme CSS is the common/common.scss file. For many themes, that’s all you’ll need.

You can also use desktop/desktop.scss and mobile/mobile.scss, although we’re increasingly moving away from these separate files and towards breakpoint-based styling in common.scss.

But for more complex situations, you can put additional scss in files like /stylesheets/my-styles.scss, and import from common.scss like @import "my-styles";

Using variables

Discourse makes extensive use of CSS variables for colors, font sizes, and other things which need to be shared throughout the stylesheets. You can find a full list of the color variables here, font variables here. Or alternatively, open your browser dev tools, select the <html> element, and scroll through all the available variables.

Let’s make use of this knowledge by updating our theme to use the theme colors for the banner! Open up the common.scss file, and update the color properties to use variables:

.custom-welcome-banner {
  background: var(--quaternary);
  color: var(--secondary);
  text-align: center;
  padding: 10px;
}

discourse_theme will sync this change up to your site instantly, and the change should appear in your browser.

Great! Now your banner’s colors will match the site color scheme, and automatically adjust based on light/dark modes.

For more information about the variables available, check out this document

Finding CSS selectors to style

The number of elements and classes in Discourse can feel quite overwhelming from a re-styling standpoint. The key to having a maintainable theme is to keep your changes as small as possible, and match the selectors used in Discourse core’s stylesheets.

For example, let’s assume you want to style all the buttons in Discourse. One approach would be to use DevTools and try to find every variation of every button and style it. But a better approach would be to see how core is styling buttons, and base your approach on that.

To explore re-styling Discourse in more detail, check out the Designer’s guide to Discourse themes

Or if you’re ready to explore more ways to add/change content in Discourse, let’s go to the next chapter


This document is version controlled - suggest changes on github.

إعجابَين (2)

ألا ينبغي أن يكون scss للسمات، أم يمكن استخدام stylesheets أيضًا؟

إعجاب واحد (1)

كلاهما يعمل. أفضل /stylesheets للاتساق مع النواة والمكونات الإضافية… على الرغم من أنني أدرك الآن أن theme-skeleton يستخدم scss/ لذا هذا ما تستخدمه 99٪ من السمات :sweat_smile:

3 إعجابات

أعتقد أنه يمكنني إدخال هذا هنا، والتظاهر بأنني لم أنسَ إجراء هذا التغيير على الهيكل العظمي قبل 6 سنوات :shushing_face:

5 إعجابات

إذًا، هل سيكون من المنطقي إعادة تسمية scss إلى stylesheets في السمات الحالية (والإضافات؟ أنا على هاتفي ولم ألقِ نظرة على إضافاتي)؟

إعجاب واحد (1)

الأمر متروك لك تمامًا. إنهما مترادفان في مترجم السمات الخاص بنا، وليس لدينا أي خطط لإيقاف استخدام scss في الوقت الحالي.

(إذا قررنا الإيقاف، فستحصل على تحذير كافٍ)

ينطبق هذا فقط على السمات. لطالما استخدمت الإضافات /stylesheets كاصطلاح.

3 إعجابات