Skip to main content

Tutor plugin that simplifies branding an Open edX instance

Project description

Tutor Branding Plugin

This plugin customizes Open edX branding for Tutor, with a focus on Ulmo-era MFE theming.

Installation

pip install tutor-contrib-branding

This release targets Open edX Ulmo with Tutor 21.x.

Quick Start

  • Register for free at branding.aulasneo.com. Follow the instructions to create and publish your theme. Copy the provided tutor command.
  • Enable the tutor-contrib-branding plugin.
  • Paste the tutor command
  • Restart services

Now you can tweak the theme parameters in https://branding.aulasneo.com and see the results in real time in your Open edX site (you might need to hard refresh or clear cache in your browser to see the changes).

Refer to the Branding documentation for more information.

Current approach

Branding is now centered on externally published Paragon theme assets. The Branding applications is an online editor that manages your Paragon assets and publishes it to be used in your Open edX site with no effort. It provides the tutor commands you need to link your site with the theme.

The supported path is:

  • publish Paragon core.css and variant CSS files from your design-token theme
  • point MFEs at those assets with BRANDING_PARAGON_THEME_URLS
  • configure logos and favicon explicitly with BRANDING_MFE_LOGO_URL, BRANDING_MFE_LOGO_WHITE_URL, BRANDING_MFE_LOGO_TRADEMARK_URL, and BRANDING_MFE_FAVICON_URL
  • use BRANDING_THEME_REPOS only for comprehensive theme content that still belongs to legacy pages, mainly certificates and static pages

Official references:

Configuring BRANDING_PARAGON_THEME_URLS

Set BRANDING_PARAGON_THEME_URLS to the PARAGON_THEME_URLS object expected by frontend-platform.

Example:

BRANDING_PARAGON_THEME_URLS:
  core:
    url: "https://cdn.example.com/theme/core.css"
  defaults:
    light: light
    dark: dark
  variants:
    light:
      url: "https://cdn.example.com/theme/light.css"
    dark:
      url: "https://cdn.example.com/theme/dark.css"
    high-contrast-dark:
      url: "https://cdn.example.com/theme/high-contrast-dark.css"

When multiple variants are declared, this plugin adds a footer theme selector to MFEs. It supports:

  • Auto
  • the configured default light variant
  • the configured default dark variant, if present
  • any additional variants declared under BRANDING_PARAGON_THEME_URLS.variants

MFE logos and favicon

MFEs still expect explicit asset URLs for brand images.

Available settings:

  • BRANDING_MFE_LOGO_URL
  • BRANDING_MFE_LOGO_WHITE_URL
  • BRANDING_MFE_LOGO_TRADEMARK_URL
  • BRANDING_MFE_FAVICON_URL

These values must be public URLs.

Catalog home page overlay

BRANDING_OVERLAY_HTML replaces the catalog home page overlay HTML when it is defined.

This value is passed through the org.openedx.frontend.catalog.home_page.overlay_html plugin slot and is only applied when the setting is set.

Catalog MFE and marketing site

By default, this plugin enables the catalog MFE, which replaces the home and the courses pages. If you have set marketing site, set BRANDING_ENABLE_CATALOG_MICROFRONTEND to False in order to redirect the home and courses pages to your marketing site URL instead.

Theme repositories and comprehensive theming

BRANDING_THEME_REPOS is still supported, but only for the remaining legacy/comprehensive theme surface.

That means:

  • certificates
  • legacy static pages
  • other legacy Django-rendered theming needs that are still served from the comprehensive theme

Example:

BRANDING_THEME_REPOS:
  - name: my-theme
    url: https://github.com/myorg/my-theme.git
    version: main

After updating the configuration:

tutor config save
tutor images build openedx
tutor local do init --limit branding

Notes:

  • only one theme can be active at a time
  • do not use theme as a custom theme name; that name is reserved for the base theme directory
  • assign the theme in Django admin if you need to switch the active comprehensive theme for a site

Deprecated and removed settings

The following legacy build-time branding settings are no longer supported and have been removed in favor of externally published Paragon theme assets and runtime MFE configuration:

  • BRANDING_WELCOME_MESSAGE
  • BRANDING_FOOTER_NAV_LINKS
  • BRANDING_FOOTER_LEGAL_LINKS
  • BRANDING_BACKGROUND
  • BRANDING_BG_PRIMARY
  • BRANDING_BODY
  • BRANDING_PRIMARY
  • BRANDING_SECONDARY
  • BRANDING_FONT_FAMILY
  • BRANDING_BRAND
  • BRANDING_SUCCESS
  • BRANDING_INFO
  • BRANDING_DANGER
  • BRANDING_WARNING
  • BRANDING_LIGHT
  • BRANDING_DARK
  • BRANDING_ACCENT_A
  • BRANDING_ACCENT_B
  • BRANDING_HOMEPAGE_BG_IMAGE
  • BRANDING_EXTRAS
  • BRANDING_OVERRIDES
  • BRANDING_FONTS
  • BRANDING_FONTS_URLS
  • BRANDING_LMS_IMAGES
  • BRANDING_CMS_IMAGES
  • BRANDING_HIDE_DASHBOARD_SIDEBAR
  • BRANDING_HIDE_LOOKING_FOR_CHALLENGE_WIDGET
  • BRANDING_FIT_COURSE_IMAGE
  • BRANDING_INDEX_ADDITIONAL_HTML
  • BRANDING_FRONTEND_COMPONENT_HEADER_REPO
  • BRANDING_FRONTEND_COMPONENT_FOOTER_REPO
  • BRANDING_MFE_PLATFORM_REPO
  • BRANDING_CERTIFICATE_HTML
  • BRANDING_STATIC_TEMPLATE_404
  • BRANDING_STATIC_TEMPLATE_429
  • BRANDING_STATIC_TEMPLATE_ABOUT
  • BRANDING_STATIC_TEMPLATE_BLOG
  • BRANDING_STATIC_TEMPLATE_CONTACT
  • BRANDING_STATIC_TEMPLATE_DONATE
  • BRANDING_STATIC_TEMPLATE_EMBARGO
  • BRANDING_STATIC_TEMPLATE_FAQ
  • BRANDING_STATIC_TEMPLATE_HELP
  • BRANDING_STATIC_TEMPLATE_HONOR
  • BRANDING_STATIC_TEMPLATE_JOBS
  • BRANDING_STATIC_TEMPLATE_MEDIA_KIT
  • BRANDING_STATIC_TEMPLATE_NEWS
  • BRANDING_STATIC_TEMPLATE_PRESS
  • BRANDING_STATIC_TEMPLATE_PRIVACY
  • BRANDING_STATIC_TEMPLATE_SERVER_DOWN
  • BRANDING_STATIC_TEMPLATE_SERVER_ERROR
  • BRANDING_STATIC_TEMPLATE_SERVER_OVERLOADED
  • BRANDING_STATIC_TEMPLATE_SITEMAP
  • BRANDING_STATIC_TEMPLATE_TOS

Custom MFEs

You can still override or add MFEs with BRANDING_MFE.

Example:

BRANDING_MFE:
  authn:
    port: 2001
    repository: https://github.com/myorg/myfork.git
    version: mybranch

Repositories must end in .git, and custom MFEs must remain compatible with Tutor MFE build expectations.

Usage

tutor plugins enable branding
tutor images build openedx
tutor images build mfe
tutor local do init --limit branding

Notes:

  • tutor local do init --limit branding is needed only if you are using BRANDING_THEME_REPOS. This command associates the comprehensive theme directory to the site for legacy HTML pages.
  • tutor images build openedx is needed only if you are using BRANDING_THEME_REPOS.
  • tutor images build mfe is needed only if you want the theme variant (light/dark/auto/...) switch.

For Kubernetes deployments, also push rebuilt images and restart the affected services.

License

This software is licensed under the terms of the AGPLv3.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tutor_contrib_branding-21.1.0.tar.gz (22.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tutor_contrib_branding-21.1.0-py3-none-any.whl (11.7 kB view details)

Uploaded Python 3

File details

Details for the file tutor_contrib_branding-21.1.0.tar.gz.

File metadata

  • Download URL: tutor_contrib_branding-21.1.0.tar.gz
  • Upload date:
  • Size: 22.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tutor_contrib_branding-21.1.0.tar.gz
Algorithm Hash digest
SHA256 c61a289e365fc3a014a20d3d8abfb9c64313a801dad795423dc147ca7dcc6924
MD5 3f911e2d7f06d73a1f63590f29ee4329
BLAKE2b-256 4077c4d916575349e460d8991ed49be4b479b90ebf9aa503f82862901f1ca929

See more details on using hashes here.

Provenance

The following attestation bundles were made for tutor_contrib_branding-21.1.0.tar.gz:

Publisher: publish.yml on aulasneo/tutor-contrib-branding

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tutor_contrib_branding-21.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for tutor_contrib_branding-21.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2bb5123030db9659efac31370c12ff023e32c267a6f90d84763233ed8ffed878
MD5 ad24b0778ae74b447e9e7f302ceba45b
BLAKE2b-256 fae1550615cfb0441053cd52ffb12d6ca8815220dc9bbffb149a4089ecb759b7

See more details on using hashes here.

Provenance

The following attestation bundles were made for tutor_contrib_branding-21.1.0-py3-none-any.whl:

Publisher: publish.yml on aulasneo/tutor-contrib-branding

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page