aboutsummaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/Layout.mjs43
-rw-r--r--src/css/dumbymap.css99
-rw-r--r--src/dumbymap.mjs9
3 files changed, 119 insertions, 32 deletions
diff --git a/src/Layout.mjs b/src/Layout.mjs
index 861f56b..5673722 100644
--- a/src/Layout.mjs
+++ b/src/Layout.mjs
@@ -11,7 +11,48 @@ export class Layout {
11 valueOf = () => this.name 11 valueOf = () => this.name
12} 12}
13 13
14export class OverlayLayout extends Layout { 14export class SideBySide extends Layout {
15 name = "side-by-side"
16
17 enterHandler = ({ container, htmlHolder, showcase }) => {
18 const bar = document.createElement('div')
19 bar.className = 'bar'
20 bar.innerHTML = '<div class="bar-handle"></div>'
21 const handle = bar.querySelector('.bar-handle')
22 container.appendChild(bar)
23
24 const resizeByLeft = (left) => {
25 htmlHolder.style.width = (left) + "px"
26 showcase.style.width = (parseFloat(getComputedStyle(container).width) - left) + "px"
27 }
28
29 const draggable = new PlainDraggable(bar, {
30 handle: handle,
31 containment: { left: '25%', top: 0, right: '75%', height: 0 },
32 })
33 draggable.draggableCursor = "grab"
34 draggable.onDrag = (pos) => {
35 handle.style.transform = 'unset'
36 resizeByLeft(pos.left)
37 }
38 draggable.onDragEnd = (_) => {
39 handle.removeAttribute('style')
40 }
41
42 new ResizeObserver(() => {
43 if (draggable) resizeByLeft(draggable.left)
44 }).observe(container);
45 }
46
47 leaveHandler = ({ container, htmlHolder, showcase }) => {
48 container.removeAttribute('style')
49 htmlHolder.removeAttribute('style')
50 showcase.removeAttribute('style')
51 container.querySelector('.bar')?.remove()
52 }
53}
54
55export class Overlay extends Layout {
15 name = "overlay" 56 name = "overlay"
16 57
17 enterHandler = (dumbymap) => { 58 enterHandler = (dumbymap) => {
diff --git a/src/css/dumbymap.css b/src/css/dumbymap.css
index 68a73c0..f58cf22 100644
--- a/src/css/dumbymap.css
+++ b/src/css/dumbymap.css
@@ -80,7 +80,6 @@
80} 80}
81 81
82.DumbyMap { 82.DumbyMap {
83 display: flex;
84 width: 100%; 83 width: 100%;
85 height: 100%; 84 height: 100%;
86 margin: 0 auto; 85 margin: 0 auto;
@@ -89,32 +88,10 @@
89 position: relative; 88 position: relative;
90 overflow-x: auto; 89 overflow-x: auto;
91 90
92 .Showcase {
93 display: none;
94 overflow: visible;
95
96 position: relative;
97 order: 2;
98
99 > * {
100 width: 100%;
101 height: 100%;
102
103 position: absolute;
104 top: 0;
105 left: 0;
106 }
107
108 [data-focus="true"] {
109 z-index: 1;
110 }
111 }
112
113 .SemanticHtml { 91 .SemanticHtml {
114 width: 100%; 92 height: 100%;
115 padding: 1.5rem; 93 padding: 1.5rem;
116 overflow-y: auto; 94 overflow-y: auto;
117 order: 1;
118 95
119 pre { 96 pre {
120 width: 100%; 97 width: 100%;
@@ -149,6 +126,28 @@
149 animation: fade-out 1s; 126 animation: fade-out 1s;
150 } 127 }
151 } 128 }
129
130 .Showcase {
131 display: none;
132 overflow: visible;
133 height: 100%;
134
135 position: relative;
136
137 > * {
138 width: 100%;
139 height: 100%;
140
141 position: absolute;
142 top: 0;
143 left: 0;
144 }
145
146 [data-focus="true"] {
147 z-index: 1;
148 }
149 }
150
152} 151}
153 152
154.DumbyMap[data-layout="normal"] { 153.DumbyMap[data-layout="normal"] {
@@ -156,14 +155,60 @@
156} 155}
157 156
158.DumbyMap[data-layout="side-by-side"] { 157.DumbyMap[data-layout="side-by-side"] {
159 display: flex;
160
161 .SemanticHtml, 158 .SemanticHtml,
162 .Showcase { 159 .Showcase {
163 flex: 50%; 160 width: 50%;
164 161
162 position: absolute;
163 top: 0;
164 min-width: 20%;
165 }
166
167 .SemanticHtml {
168 left: 0;
169 }
170
171 .Showcase {
165 display: block; 172 display: block;
173
174 right: 0;
175 }
176
177 .bar {
178 display: flex;
179 overflow: visible;
180 width: 1px;
166 height: 100%; 181 height: 100%;
182
183 position: absolute;
184 left: 50%;
185 z-index: 9999;
186
187 border: 2px black solid;
188
189 .bar-handle {
190 display: inline-block;
191 width: 60px;
192 height: 60px;
193
194 position: absolute;
195 top: calc(50% - 30px);
196 left: -30px;
197
198 border-radius: 50%;
199
200 background-color: #3887be;
201 background-image: url("");
202
203 transition: transform 0.3s ease-in-out;
204 transform: scale(0.5, 0.5);
205 box-shadow: inset 0 0 0 2px white;
206
207 &:hover {
208 transform: unset;
209 }
210 }
211
167 } 212 }
168} 213}
169 214
diff --git a/src/dumbymap.mjs b/src/dumbymap.mjs
index a785d6f..87ea694 100644
--- a/src/dumbymap.mjs
+++ b/src/dumbymap.mjs
@@ -6,15 +6,15 @@ import MarkdownItTocDoneRight from 'markdown-it-toc-done-right'
6import LeaderLine from 'leader-line' 6import LeaderLine from 'leader-line'
7import { renderWith, defaultAliases, parseConfigsFromYaml } from 'mapclay' 7import { renderWith, defaultAliases, parseConfigsFromYaml } from 'mapclay'
8import { onRemove, animateRectTransition, throttle } from './utils' 8import { onRemove, animateRectTransition, throttle } from './utils'
9import { Layout, OverlayLayout } from './Layout' 9import { Layout, SideBySide, Overlay } from './Layout'
10 10
11const docLinkSelector = 'a[href^="#"][title^="=>"]' 11const docLinkSelector = 'a[href^="#"][title^="=>"]'
12const geoLinkSelector = 'a[href^="geo:"]' 12const geoLinkSelector = 'a[href^="geo:"]'
13 13
14const layouts = [ 14const layouts = [
15 new Layout({ name: "normal" }), 15 new Layout({ name: "normal" }),
16 new Layout({ name: "side-by-side" }), 16 new SideBySide({ name: "side-by-side" }),
17 new OverlayLayout({ name: "overlay" }), 17 new Overlay({ name: "overlay" }),
18] 18]
19 19
20// FUNCTION: Get DocLinks from special anchor element {{{ 20// FUNCTION: Get DocLinks from special anchor element {{{
@@ -144,9 +144,10 @@ export const generateMaps = async (container, callback) => {
144 showcase.classList.add('Showcase') 144 showcase.classList.add('Showcase')
145 145
146 const dumbymap = { 146 const dumbymap = {
147 blocks: Array.from(htmlHolder.querySelectorAll('.dumby-block')), 147 container: container,
148 htmlHolder: htmlHolder, 148 htmlHolder: htmlHolder,
149 showcase: showcase, 149 showcase: showcase,
150 blocks: Array.from(htmlHolder.querySelectorAll('.dumby-block')),
150 } 151 }
151 152
152 container.classList.add('DumbyMap') 153 container.classList.add('DumbyMap')