Skip to content

Commit

Permalink
Styling margin directive from sphinx-book-theme (#238)
Browse files Browse the repository at this point in the history
* version 0.6.2

* margin directive

* hiding back to top

* comments

* sidebar title no display

* margin, sidenote classes

* responsive design
  • Loading branch information
AakashGfude authored Dec 11, 2023
1 parent 13def3f commit 41e8d43
Show file tree
Hide file tree
Showing 4 changed files with 246 additions and 4 deletions.
2 changes: 1 addition & 1 deletion docs/layout.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ right TOC should hide itself automatically.
### Margins

You can specify content that should exist in the right margin. This will behave
like a regular sidebar until the screen hits a certain width, at which point this
like a regular sidebar until the screen hits a certain width (1200px to be exact), at which point this
content will "pop out" to the right white space. To add margin content, use this syntax:

````
Expand Down
31 changes: 31 additions & 0 deletions src/quantecon_book_theme/assets/scripts/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -376,6 +376,37 @@ document.addEventListener("DOMContentLoaded", function () {
);
})();

// Intersection Observer for hiding 'Back To Top' when overlapping margins
const Margin = document.getElementsByClassName("margin");
const figCaption = document.querySelectorAll(
"figure.margin-caption figcaption",
);
const BackToTop = document.getElementsByClassName("qe-page__toc-footer")[0];

const targetElements = Array.from(Margin).concat(Array.from(figCaption));
// Function to be called when the intersection changes
const handleIntersection = (entries, observer) => {
entries.forEach((entry) => {
// If the target element is intersecting with the certain div
if (entry.isIntersecting) {
// Hide the element
BackToTop.style.display = "none";
} else {
// Show the element
BackToTop.style.display = "";
}
});
};

// Create the Intersection Observer
const observer = new IntersectionObserver(handleIntersection, {
root: null, // observing intersections relative to the viewport
rootMargin: "0px 0px -80% 0px", // when the targetElement is 80% above the viewport
});

// Start observing the target elements
Array.from(targetElements).forEach((el) => observer.observe(el));

// Tooltips
tippy("[data-tippy-content]", {
touch: false,
Expand Down
213 changes: 213 additions & 0 deletions src/quantecon_book_theme/assets/styles/_margin.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,213 @@
/**
* Margin content
* This is the area to the right of the main content
* normally covered by the in-page table of contents
* but if `.margin` classes are present, it shows up to the right in the margin
* and the in-page TOC is hidden.
* On narrow screens, margin content behaves like a sidebar
*/

/**
* Variables for calculating margin widths
*/
// We want our margin content to be 1/3 the width of the main page content
// after factoring in a small margin
$margin-width-relative-to-content: 36%;
$margin-gutter: 3%;
$margin-width-width-gutter: $margin-width-relative-to-content - $margin-gutter;

// re-subtract the gutter width because we want it to leave a white-space
// This is how much to offset the margin content.
$margin-offset: -$margin-width-relative-to-content;

/**
* This mixin will cause something to "pop out" to the margin on wide screens
*/
@mixin margin-content() {
// On narrow screens this is the width of margin content
width: 40%;
float: right;
background-color: unset;
font-size: 0.9em;
margin-left: 0.5rem;

// Wide screens and printing should force margin behavior
@media (min-width: $breakpoint-xl), print {
width: $margin-width-width-gutter;
margin: 0 $margin-offset 0 0;

// Prevent sequential margin content from overlapping
clear: right;

p.sidebar-title {
margin-bottom: -1rem;
border-bottom: none;
padding-left: 0px;

// Content of admonitions has fewer horizontal white space to save space
~ * {
padding-left: 0px;
padding-right: 0px;
}
}
}

.sidebar-title:empty {
display: none;
}
}

/**
* Sidenotes and marginnotes
* over-rides the "footnote" behavior to pop out to the margin instead.
*/
label.margin-toggle {
margin-bottom: 0em;
&.marginnote-label {
display: none;
}
sup {
user-select: none;
}
@media (max-width: $breakpoint-xl) {
cursor: pointer;
color: rgb(0, 113, 188);
&.marginnote-label {
display: inline;
&:after {
content: "\2295";
}
}
}
}

input.margin-toggle {
display: none;
@media (max-width: $breakpoint-xl) {
&:checked + .sidenote,
&:checked + .marginnote {
display: block;
float: left;
left: 1rem;
clear: both;
width: 95%;
margin: 1rem 2.5%;
position: relative;
}
}
}

.qe-page__content {
span.sidenote,
span.marginnote {
z-index: 2;
position: relative;
sup {
user-select: none;
}
@include margin-content();
border-left: none;
@media (max-width: $breakpoint-xl) {
display: none;
}
}

aside.sidebar {
.note {
// styling for notes inside sidebars
margin: 1rem;
padding: 0rem 0rem 1rem 0rem;
}
// The titles sticking
.admonition-title {
margin: 0rem -1rem 0rem 0rem;
}
}

/**
* Sidebar content in the margin.
* This will be added by the `margin` directive or the `sidebar` directive
*/
aside.sidebar.margin {
// Margin content can have an empty title so this prevents an empty title block
// from showing up on mobile
.sidebar-title:empty {
display: none;
}

// On narrow screens padding is added to all sidebar content
// This replaces padding w/ margin for admonitions because padding is used
// for the title background color
.admonition {
margin: 0.5rem;
padding-left: 0;
padding-right: 0;

// Remove the title margin so it
.admonition-title {
margin-left: 0;
margin-right: 0;
}
}

@media (min-width: $breakpoint-xl) {
// No border for margin sidebars on wide screen
border: none;

// Admonitions don't need the extra whitespace in the margin
.admonition {
margin: 1rem 0rem;
padding: 0rem 0rem 1rem 0rem;
}
}
}

div.margin,
figure.margin,
aside.margin,
.margin.docutils.container,
.cell.tag_popout,
.cell.tag_margin {
z-index: 2;
position: relative;
@include margin-content();

// Make cell outputs take up more space if they're in the margin
div.cell.tag_margin .cell_output {
padding-left: 0;
}
}

// A few permutations because docutils 0.18 switched to semantic tags
div.figure.margin-caption p.caption,
div.figure.margin-caption figcaption,
figure.margin-caption figcaption {
z-index: 2;
position: relative;
@include margin-content();
}

// Margin captions
.margin-caption figcaption {
text-align: left;
}

/**
* Full width content
*/

// Grow 100% by the ratio of the margin to the content width.
$content-fullwidth-width: 100% + $margin-width-relative-to-content;

div.cell.tag_full-width,
div.cell.tag_full_width,
div.full_width,
div.full-width {
z-index: 2;
position: relative;
@media (min-width: $breakpoint-xl) {
max-width: $content-fullwidth-width;
width: $content-fullwidth-width;
}
}
}
4 changes: 1 addition & 3 deletions src/quantecon_book_theme/assets/styles/index.scss
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,7 @@ $color-body: #444444;
@import "quantecon-defaults";
@import "syntax";
@import "tippy-themes";
@import "margin";

* {
-webkit-font-smoothing: antialiased;
Expand Down Expand Up @@ -376,9 +377,6 @@ a {
overflow-wrap: break-word;
}

a:link {
}

a:hover {
color: #004979;
text-decoration: underline;
Expand Down

1 comment on commit 41e8d43

@github-actions
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Please sign in to comment.