Skip to content

Commit d34ea05

Browse files
Shrink and move ferris when possible
1 parent d20900e commit d34ea05

File tree

2 files changed

+40
-11
lines changed

2 files changed

+40
-11
lines changed

ferris.css

Lines changed: 14 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -19,13 +19,24 @@ body.ayu .not_desired_behavior {
1919
background: #501f21;
2020
}
2121

22-
.ferris {
22+
.ferris-container {
2323
position: absolute;
2424
z-index: 99;
2525
right: 5px;
2626
top: 30px;
27-
width: 10%;
28-
height: auto;
27+
}
28+
29+
.ferris {
30+
vertical-align: top;
31+
margin-left: 0.5em;
32+
}
33+
34+
.ferris-large {
35+
width: 4.5em;
36+
}
37+
38+
.ferris-small {
39+
width: 3em;
2940
}
3041

3142
.ferris-explain {

ferris.js

Lines changed: 26 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -19,29 +19,47 @@ document.addEventListener('DOMContentLoaded', () => {
1919
}
2020
})
2121

22-
function attachFerrises (type) {
22+
function attachFerrises(type) {
2323
var elements = document.getElementsByClassName(type.attr)
2424

2525
for (var codeBlock of elements) {
26-
var lines = codeBlock.textContent.split(/\r|\r\n|\n/).length - 1;
27-
28-
if (lines >= 4) {
29-
attachFerris(codeBlock, type)
26+
var lines = codeBlock.innerText.replace(/\n$/, '').split(/\n/).length
27+
var size = 'large'
28+
if (lines < 4) {
29+
size = 'small'
3030
}
31+
32+
var container = prepareFerrisContainer(codeBlock, size == 'small')
33+
container.appendChild(createFerris(type, size))
34+
}
35+
}
36+
37+
function prepareFerrisContainer(element, useButtons) {
38+
var foundButtons = element.parentElement.querySelector('.buttons')
39+
if (useButtons && foundButtons) {
40+
return foundButtons
3141
}
42+
43+
var div = document.createElement('div')
44+
div.classList.add('ferris-container')
45+
46+
element.parentElement.insertBefore(div, element)
47+
48+
return div
3249
}
3350

34-
function attachFerris (element, type) {
51+
function createFerris(type, size) {
3552
var a = document.createElement('a')
3653
a.setAttribute('href', 'ch00-00-introduction.html#ferris')
3754
a.setAttribute('target', '_blank')
3855

3956
var img = document.createElement('img')
4057
img.setAttribute('src', 'img/ferris/' + type.attr + '.svg')
4158
img.setAttribute('title', type.title)
42-
img.className = 'ferris'
59+
img.classList.add('ferris')
60+
img.classList.add('ferris-' + size)
4361

4462
a.appendChild(img)
4563

46-
element.parentElement.insertBefore(a, element)
64+
return a
4765
}

0 commit comments

Comments
 (0)