diff --git a/.stylelintrc.js b/.stylelintrc.js index fef3f5d2..0692a8a7 100644 --- a/.stylelintrc.js +++ b/.stylelintrc.js @@ -12,8 +12,6 @@ module.exports = { 'color-hex-length': 'long', // Disallow ids 'selector-max-id': 0, - // Enforce alphabetical ordering of properties - 'order/properties-alphabetical-order': true, // Require that color, background-color, etc use variables for colors, instead of direct values 'scale-unlimited/declaration-strict-value': [ ['/color/'] // We can enforce variables for font-size, margin, etc as well by adding here diff --git a/addon/styles/addon.css b/addon/styles/addon.css index eb1a76df..0febda9d 100644 --- a/addon/styles/addon.css +++ b/addon/styles/addon.css @@ -14,6 +14,7 @@ @import 'icon.css'; @import 'sidebar-container.css'; @import 'well.css'; +@import 'table-of-contents.css'; /* Helpers */ @import 'helpers/index.css'; diff --git a/addon/styles/table-of-contents.css b/addon/styles/table-of-contents.css new file mode 100644 index 00000000..9b284112 --- /dev/null +++ b/addon/styles/table-of-contents.css @@ -0,0 +1,62 @@ +.table-of-contents { + list-style-type: none; + padding-left: 0; + font-size: var(--font-size-base); + font-weight: var(--font-weight-3); +} + +.sub-table-of-contents { + padding-left: var(--spacing-1); + font-size: var(--font-size-base); + font-weight: var(--font-weight-2); +} + +.sub-table-of-contents .sub-table-of-contents { + padding-left: var(--spacing-3); + margin-bottom: 0; +} + +li.toc-heading { + margin-top: var(--spacing-4); + color: var(--color-gray-600); +} + +li.toc-heading:first-child { + margin-top: 0; +} + +.table-of-contents li { + margin: 3px 0; + list-style-type: none; +} + +.table-of-contents a:link { + background: none; +} + +.sub-table-of-contents .toc-item a { + display: block; + padding: var(--spacing-1); + border-radius: var(--radius); + line-height: var(--line-height-xs); + color: var(--color-gray-700); + border-left: 0 solid transparent; + transition: border-width 0.3s; +} + +.sub-table-of-contents .toc-item a:hover { + border-left: 4px solid var(--color-gray-400); + border-radius: 0; +} + +.sub-table-of-contents .toc-item.selected > a, +.sub-table-of-contents .toc-item > a.active { + border-left: 4px solid var(--color-brand-hc-dark); + border-radius: 0; +} + +@media (max-width: 844px) { + .table-of-contents { + font-size: var(--font-size-lg); + } +} diff --git a/docs/concepts/table-of-contents.md b/docs/concepts/table-of-contents.md new file mode 100644 index 00000000..24373380 --- /dev/null +++ b/docs/concepts/table-of-contents.md @@ -0,0 +1,43 @@ +# Table of Contents + +Instead of providing a component we provide this concept for our table of contents. You can see the concept below. +Every item in the list is either a `toc-heading`, giving it heading styling, or an `toc-item`. The `anchor`-tags wrapped in a `toc-item` will get specific styling. On the main level, not wrapped in a `sub-table-of contents`, they will be the brand-color. When they are wrapped in a `sub-table-of-contents`, they will have an "active" indicator and a hover state, this will also indent them from the main level. + +```html + +```