The Reference Set CSS will work with:
- The default Obsidian theme.
- Themes with Style Settings that have implemented a Style Settings toggle for their Alternative Checkboxes implementation (Progress on that documented here: [[09 Style Settings Toggle Review]]).
- Themes without Style Settings which have implemented the
@container style()
query surrounding their Alternative Checkboxes implementation; effectively working like a toggle which can be overwritten from the CSS snippet. (Progress on that documented here: [[10 @container Style Queries Toggle Review]]). - Potentially, any theme that doesn't have it's own Alternative Checkboxes implementation (this will depend on how much the theme alters the checkboxes).
Implementing an option to toggle your theme's implementation of Alternative Checkboxes allows users to use their own implementation with ease and promotes. Here is how you can make this possible regardless if your theme uses the Style Settings plugin or not.
You can prefix your existing selectors related to the Alternative Checkboxes with the following or nest all of them within the brackets.
body.enable-alternative-checkboxes {
/* Encapsulate all code relevant to Altenative Checkboxes here */
}
Add a toggle in the Style Settings code:
-
id: enable-alternative-checkboxes
title: Enable Alternative Checkboxes
description: Disable this if you are using your own implementation via a CSS Snippet.
default: true
type: class-toggle
-
The Style Settings toggle will allow users to disable your implementation (effectively resetting the styling to match the default checked checkbox) and use their own CSS snippet. By default, it's set to enabled to assure the functionality remains unchanged for existing users of your theme.
This option allows the Reference Set CSS to disable your Alternative Checkboxes implementation with a simple change to the --theme-alternative-checkboxes
variable.
body {
--theme-alternative-checkboxes: enable;
}
@container style(--theme-alternative-checkboxes: enable) {
/* all the code for the checkboxes */
}
For the @container style()
query to function, you and your users need to be using an updated Obsidian Installer version (within last 12 months should be fine). Installer version means downloading the Obsidian app again and running the installer which will update the Installer version (effectively updating the Electron version used among other things). Note that the in app updates and Installer updates are not the same.
For Apple users, you will need iOS 18 / iPadOS 18 or newer, since this feature is available since Safari 18 (Safari versions typically match the OS versions on Apple devices).
Here is how one Alternative Checkbox from the Reference Set CSS is defined:
/* - [/] Incomplete */
div.HyperMD-task-line[data-task="/"],
ul >li[data-task="/"] {
--icon-method: mask;
--icon-mask-position: center;
--icon-mask-size: contain;
/* Icon used: https://lucide.dev/icons/square-dashed */
--icon-mask-image: url("...");
--icon-content: "/";
--icon-content-weight: var(--font-bold);
--icon-content-font: var(--font-monospace);
--icon-content-alignment: center;
--icon-color: var(--text-normal);
--icon-background-color: transparent;
--icon-background-color-hover: transparent;
--icon-border: unset;
--icon-border-radius: unset;
--line-text-color: inherit;
--line-background-color: unset;
--line-border: unset;
--line-border-radius: unset;
}
This example includes all available variables. You don't need to include all of them per checkbox since there are defaults set in the Reference Set CSS. Only include the ones you want to overwrite e.g. change the icon with the --icon-mask-image
variable.
Each line has a specific function:
div.HyperMD-task-line[data-task="/"]
Used to inject the variables for the specific checkbox in Live Preview. Change the character in between the quotes to the character you want to use for your checkbox. Certain symbols need to be escaped to work correctly e.g. [data-task="\""]
for a - ["] Quote
checkbox.
ul > li[data-task="/"]
Used to inject the variables for the specific checkbox in Reading Mode. Change the character in between the quotes to the character you want to use for your checkbox. Certain symbols need to be escaped to work correctly e.g. [data-task="\""]
for a - ["] Quote
checkbox.
--icon-method: mask;
Used to set which icon setup is used. There are 2 options:
mask
allows you to use a Base64 embedded icon.content
allows you to use text, symbols and / or emoji instead of the icon.
--icon-mask-position: center;
Only used when --icon-method: mask;
is set; it's the default option. Used to align the icon (horizontally and vertically) within the checkbox container.
CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/mask-position
--icon-mask-size: contain;
Only used when --icon-method: mask;
is set; it's the default option. Used to change the size of icon within the checkbox container.
CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/mask-size
--icon-mask-image: url("...");
Only used when --icon-method: mask;
is set; it's the default option. Used to input the Base64 embedded icon.
CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/mask-image
--icon-content: "/";
Only used when --icon-method: content;
is set. Used to define content displayed instead of the Base64 embedded icon. In this case, it can be text, symbol and/or Emoji.
CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/content
--icon-content-weight: var(--font-bold);
Only used when --icon-method: content;
is set. Used to set the font weight for the content. You can change this to any valid CSS weight type, a weight variable within your theme or the default Obsidian theme.
CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/@font-face/font-weight
--icon-content-font: var(--font-monospace);
Only used when --icon-method: content;
is set. Used to set the font family for the content. You can change this to any valid CSS font family, a font family variable within your theme or the default Obsidian theme.
CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/font-family
--icon-content-alignment: center;
Only used when --icon-method: content;
is set. Used to change the horizontal alignment of the content.
CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/text-align
--icon-color: var(--text-normal);
Used to change the icon color. In this case, it's utilising a color variable from the default Obsidian theme to match the text color. You can change this to any valid CSS color type, a color variable within your theme or the default Obsidian theme. CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/color
--icon-background-color: transparent;
Used to change the background color behind the icon. CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/color
--icon-background-color-hover: transparent;
Used to change the background color behind the icon when hovering over it. CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/color
--icon-border: unset;
Used to change the border properties (width, style and color) of the icon container. CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/border
--icon-border-radius: unset;
Used to change the border radius of the icon container. CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/border-radius
--line-text-color: inherit;
Used to change the color of the text after the checkbox icon / content. CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/color
--line-background-color: unset;
Used to change the color of the background for the line that the checkbox is on. CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/color
--line-border: unset;
Used to change the border properties (width, style and color) of the line that the checkbox is on. CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/border
--line-border-radius: unset;
Used to change the border radius of the line that the checkbox is on. CSS Reference: https://developer.mozilla.org/en-US/docs/Web/CSS/border-radius