In rendering some HTML document, I would like to mimic the process of handwritten annotations, in which there is a main text, and some annotation put at the same level of an highlighted text in the right margin.
I use CSS grid mechanism to set up the main area (for the main text) and the side area (for annotations).
Some example code illustrating the problem and the sought result is available on jsfiddle. The code is reproduced below.
HTML code:
.kb-container {
display: grid;
grid-template-columns: 4fr 2em 2fr;
grid-template-rows: auto;
grid-template-areas: "main . side";
}
.kb-main {
grid-area: main;
}
.kb-side {
grid-area: side;
}
<body>
<div class="kb-container">
<div class="kb-main">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.<br />
Curabitur pretium tincidunt lacus. Nulla gravida orci a odio. Nullam varius, turpis et commodo pharetra, est eros bibendum elit, nec luctus magna felis sollicitudin mauris. Integer in mauris eu nibh euismod gravida. Duis ac tellus et risus vulputate vehicula. Donec lobortis risus a elit. Etiam tempor. Ut ullamcorper, ligula eu tempor congue, eros est euismod turpis, id tincidunt sapien risus a quam. Maecenas fermentum consequat mi. <mark>Donec fermentum</mark>. Pellentesque malesuada nulla a mi. Duis sapien sem, aliquet nec, commodo eget, consequat quis, neque. Aliquam faucibus, elit ut dictum aliquet, felis nisl adipiscing sapien, sed malesuada diam lacus eget erat. Cras mollis scelerisque nunc. Nullam arcu. Aliquam consequat. Curabitur augue lorem, dapibus quis, laoreet et, pretium ac, nisi. Aenean magna nisl, mollis quis, molestie eu, feugiat in, orci. In hac habitasse platea dictumst.</p>
</div>
<div class="kb-side">This is a side note (currently not, lined up with "Donec fermentum").</div>
</div>
</body>
Using CSS grid and flex containers, I am able to head in the right direction and line up the annotation to the marked text. However, the solution is not satisfactory, because it introduces new <div>
block elements, thereby breaking the initial text composition (which was using inline elements <mark>
).
<html>
<head>
<style>
.grid-container {
display: grid;
grid-template-columns: 4fr 2em 2fr;
grid-template-areas: "main . side";
}
.grid-main {
grid-area: main;
}
.grid-side {
grid-area: side;
}
.flex-container {
flex-direction: column;
}
</style>
</head>
<body>
<div class="flex-container">
<div class="grid-container">
<div class="grid-main">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure
dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p>
<p>Curabitur pretium tincidunt lacus. Nulla gravida orci a odio. Nullam varius, turpis et commodo pharetra, est eros bibendum elit, nec luctus magna felis sollicitudin mauris. Integer in mauris eu nibh euismod gravida. Duis ac tellus et risus vulputate
vehicula. Donec lobortis risus a elit. Etiam tempor. Ut ullamcorper, ligula eu tempor congue, eros est euismod turpis, id tincidunt sapien risus a quam. Maecenas fermentum consequat mi.</p>
</div>
</div>
<div class="grid-container">
<div class="grid-main">
<mark>Donec fermentum.</mark>
</div>
<div class="grid-side">This is a side note. It is lined up with the marked text. However, the initial text composition has been broken, due to the introduction of new div tags.
</div>
</div>
<div class="grid-container">
<div class="grid-main">
<p>Pellentesque malesuada nulla a mi. Duis sapien sem, aliquet nec, commodo eget, consequat quis, neque. Aliquam faucibus, elit ut dictum aliquet, felis nisl adipiscing sapien, sed malesuada diam lacus eget erat. Cras mollis scelerisque nunc. Nullam
arcu. Aliquam consequat. Curabitur augue lorem, dapibus quis, laoreet et, pretium ac, nisi. Aenean magna nisl, mollis quis, molestie eu, feugiat in, orci. In hac habitasse platea dictumst.
</p>
</div>
</div>
</div>
</body>
</html>