-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwireframe.js
63 lines (55 loc) · 1.61 KB
/
wireframe.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
// Note to self: `::after` pseudo-elements don't work on img elements
const wireframeables = [
'.introduction',
'.name',
'.socials a',
'.details > span',
'.link-header > span',
'.linkout a',
'.book-header > span',
'.book span',
'.book-links a',
'.blog-link',
'.writing-header > span',
'.writing-name',
'.writing-publisher',
'.writing-description',
'.project-header > span',
'.project-name',
'.project-role',
'.project-description',
'.project-tech',
'.tech-header > span',
'.tech span'
];
(function enableWireframe() {
if (window.innerWidth <= 800) {
return;
}
const elementsToWireframe = document.querySelectorAll(wireframeables.join(', '));
for (const el of elementsToWireframe) {
const wrapper = document.createElement('span');
wrapper.classList.add('wf-wrapper');
const hFrame = document.createElement('span');
hFrame.classList.add('wf-h-frame');
const vFrame = document.createElement('span');
vFrame.classList.add('wf-v-frame');
el.parentNode.insertBefore(wrapper, el);
wrapper.appendChild(hFrame);
wrapper.appendChild(vFrame);
wrapper.appendChild(el);
el.classList.add('wf-hoverable');
el.addEventListener('mouseover', function(_) {
el.setAttribute('data-dim', `${wrapper.clientWidth} x ${wrapper.clientHeight}`);
});
if (el.classList.contains('wf-observe')) {
const observer = new MutationObserver(function() {
el.setAttribute('data-dim', `${wrapper.clientWidth} x ${wrapper.clientHeight}`);
});
observer.observe(el, {
childList: true,
subtree: true
});
}
}
})();