/* Alternative Checkboxes Reference Set (Version: 1.0.0) Initiative created by Damian Korcz . Initiative Repository: https://github.com/damiankorcz/Alternative-Checkboxes-Reference-Set Usage Guide: https://github.com/damiankorcz/Alternative-Checkboxes-Reference-Set/blob/main/Usage%20Guide.md Research Vault: https://github.com/damiankorcz/Alternative-Checkboxes-Reference-Set/tree/main/Research%20Vault The following CSS Snippet is designed to serve as a Reference for how to implement the commonly used Alternative Checkboxes feature in themes and CSS Snippets. The Checkbox syntax in conjunction with the meaning are based on the same set as the Minimal theme, since that is the most common set among all themes which implement the feature. More on that here: https://github.com/damiankorcz/Alternative-Checkboxes-Reference-Set/blob/main/Research%20Vault/06%20Syntax%20and%20Meaning%20Review.md The icon set used for this Reference Set is Lucide (same icon set as used in the Obsidian UI). Lucide icons are distributed under the ISC License: https://lucide.dev/license Each icon uses the `Copy Data URL` option on the website which provides a Base64 embeded SVG for the icon. Properties for the Lucide icons used: - Stroke width = 1.75px - Size = 16px - Absolute Stroke width = on This snippet's code is distributed under the Unlicense License. See https://github.com/damiankorcz/Alternative-Checkboxes-Reference-Set/blob/main/LICENSE for more information. */ /* -------------------------------------------------------------------------------------------- Section 1 Definining each Alternative Checkbox with a simple selectors and a set of CSS Variables. */ /* - [/] Incomplete */ div.HyperMD-task-line[data-task="/"], ul > li[data-task="/"] { /* Icon used: https://lucide.dev/icons/square-dashed */ --icon-mask-image: url(""); } /* - [-] Cancelled */ div.HyperMD-task-line[data-task="-"], ul > li[data-task="-"] { /* Icon used: https://lucide.dev/icons/ban */ --icon-mask-image: url(""); } /* - [>] Forwarded */ div.HyperMD-task-line[data-task=">"], ul > li[data-task=">"] { /* Icon used: https://lucide.dev/icons/send-horizontal */ --icon-mask-image: url(""); } /* - [<] Scheduling */ div.HyperMD-task-line[data-task="<"], ul > li[data-task="<"] { /* Icon used: https://lucide.dev/icons/calendar */ --icon-mask-image: url(""); } /* - [?] Question */ div.HyperMD-task-line[data-task="?"], ul > li[data-task="?"] { /* Icon used: https://lucide.dev/icons/circle-help */ --icon-mask-image: url(""); } /* - [!] Important */ div.HyperMD-task-line[data-task="!"], ul > li[data-task="!"] { /* Icon used: https://lucide.dev/icons/triangle-alert */ --icon-mask-image: url(""); } /* - [*] Star */ div.HyperMD-task-line[data-task="*"], ul > li[data-task="*"] { /* Icon used: https://lucide.dev/icons/star */ --icon-mask-image: url(""); } /* - ["] Quote */ div.HyperMD-task-line[data-task="\""], ul > li[data-task="\""] { /* Icon used: https://lucide.dev/icons/quote */ --icon-mask-image: url(""); } /* - [l] Location */ div.HyperMD-task-line[data-task="l"], ul > li[data-task="l"] { /* Icon used: https://lucide.dev/icons/map-pin */ --icon-mask-image: url(""); } /* - [b] Bookmark */ div.HyperMD-task-line[data-task="b"], ul > li[data-task="b"] { /* Icon used: https://lucide.dev/icons/bookmark */ --icon-mask-image: url(""); } /* - [i] Information */ div.HyperMD-task-line[data-task="i"], ul > li[data-task="i"] { /* Icon used: https://lucide.dev/icons/info */ --icon-mask-image: url(""); } /* - [S] Savings */ div.HyperMD-task-line[data-task="S"], ul > li[data-task="S"] { /* Icon used: https://lucide.dev/icons/dollar-sign */ --icon-mask-image: url(""); } /* - [I] Idea */ div.HyperMD-task-line[data-task="I"], ul > li[data-task="I"] { /* Icon used: https://lucide.dev/icons/lightbulb */ --icon-mask-image: url(""); } /* - [p] Pros */ div.HyperMD-task-line[data-task="p"], ul > li[data-task="p"] { /* Icon used: https://lucide.dev/icons/thumbs-up */ --icon-mask-image: url(""); } /* - [c] Cons */ div.HyperMD-task-line[data-task="c"], ul > li[data-task="c"] { /* Icon used: https://lucide.dev/icons/thumbs-down */ --icon-mask-image: url(""); } /* - [f] Fire */ div.HyperMD-task-line[data-task="f"], ul > li[data-task="f"] { /* Icon used: https://lucide.dev/icons/flame */ --icon-mask-image: url(""); } /* - [k] Key */ div.HyperMD-task-line[data-task="k"], ul > li[data-task="k"] { /* Icon used: https://lucide.dev/icons/key-round */ --icon-mask-image: url(""); } /* - [w] Win */ div.HyperMD-task-line[data-task="w"], ul > li[data-task="w"] { /* Icon used: https://lucide.dev/icons/trophy */ --icon-mask-image: url(""); } /* - [u] Up */ div.HyperMD-task-line[data-task="u"], ul > li[data-task="u"] { /* Icon used: https://lucide.dev/icons/trending-up */ --icon-mask-image: url(""); } /* - [d] Down */ div.HyperMD-task-line[data-task="d"], ul > li[data-task="d"] { /* Icon used: https://lucide.dev/icons/trending-down */ --icon-mask-image: url(""); } /* -------------------------------------------------------------------------------------------- Section 2 The following code should remain untouched. It serves as a template for checkbox definitions above. It leaves the default unchecked and checked checkboxes untouched; those are styled according to the theme used. */ /* Disables Theme's Alternative Checkboxes that don't use Style Settings and implemented the `@container style()` query. */ body { --theme-alternative-checkboxes: disable; } /* Custom Default Variables - Reduces repetition and simplifies the implementation above. If you want different defaults for all Alternative Checkboxes you can change them here. */ .HyperMD-task-line:not([data-task="x"], [data-task="X"], [data-task=" "]), li:not([data-task="x"], [data-task="X"], [data-task=" "]) { --icon-mask-image: unset; --icon-mask-color: var(--text-normal); --icon-content: ""; --icon-content-font: var(--font-monospace); --icon-content-weight: var(--font-bold); --icon-content-color: var(--text-normal); --icon-background: transparent; --icon-background-hover: transparent; --icon-border: unset; --icon-border-radius: unset; --line-text-color: inherit; --line-background: unset; --line-border: unset; --line-border-radius: unset; } .HyperMD-task-line:not([data-task="x"], [data-task="X"], [data-task=" "]), li:not([data-task="x"], [data-task="X"], [data-task=" "]).is-checked { color: var(--line-text-color); background: var(--line-background); border: var(--line-border); border-radius: var(--line-border-radius); } /* Swapping margin for padding to allow background color to apply in Reading view the same as in Live Preview */ .task-list-item.is-checked { margin-inline-start: unset; padding-inline-start: 3ch; } div.is-live-preview label > input[type="checkbox"]:not([data-task="x"], [data-task="X"], [data-task=" "]), li:not([data-task="x"], [data-task="X"], [data-task=" "]) > input[type="checkbox"], li:not([data-task="x"], [data-task="X"], [data-task=" "]) > p > input[type="checkbox"] { &:checked { --checkbox-marker-color: transparent; border: var(--icon-border); border-radius: var(--icon-border-radius); background: var(--icon-background); &:hover { background: var(--icon-background-hover); } } &:checked::after { background-color: var(--icon-mask-color); -webkit-mask-image: var(--icon-mask-image); -webkit-mask-size: contain; -webkit-mask-position: center; color: var(--icon-content-color); background-image: var(--icon-image); background-repeat: no-repeat; background-position: center; content: var(--icon-content); text-align: center; font-weight: var(--icon-content-weight); font-family: var(--icon-content-font); font-size: 1rem; display: flex; align-items: center; justify-content: center; /* Allows icons to remain scaled correctly within the checkbox when using a border */ width: -webkit-fill-available; width: fill-available; /* Fallback for Safari */ height: -webkit-fill-available; height: fill-available; /* Fallback for Safari */ } }