Compare commits

..

6 Commits

Author SHA1 Message Date
Jürgen Mummert 2d0018bf1b style: remove pinboard outer padding 2026-04-01 13:51:11 +02:00
Jürgen Mummert 14723880d6 style: adjust pinboard positioning and radius 2026-04-01 13:49:31 +02:00
Jürgen Mummert 6a157f1a26 feat: render text entries before image 2026-04-01 13:43:09 +02:00
Jürgen Mummert a44a60ba79 feat: make pinboard text field optional 2026-04-01 13:30:40 +02:00
Jürgen Mummert 478e01c435 style: tweak pin marker layering and image hover 2026-04-01 13:09:13 +02:00
Jürgen Mummert 6269d383e6 feat: render image-only notes without inner padding 2026-04-01 13:03:22 +02:00
3 changed files with 39 additions and 10 deletions
+1 -1
View File
@@ -97,7 +97,7 @@ $GLOBALS['TL_DCA']['tl_pinnwand'] = [
'exclude' => true, 'exclude' => true,
'search' => true, 'search' => true,
'inputType' => 'textarea', 'inputType' => 'textarea',
'eval' => ['mandatory' => true, 'maxlength' => 3000, 'tl_class' => 'clr'], 'eval' => ['mandatory' => false, 'maxlength' => 3000, 'tl_class' => 'clr'],
'sql' => 'text NULL', 'sql' => 'text NULL',
], ],
'link' => [ 'link' => [
+8 -7
View File
@@ -5,20 +5,15 @@
<section class="pinboard" data-pinboard> <section class="pinboard" data-pinboard>
<div class="pinboard__surface" data-pinboard-surface> <div class="pinboard__surface" data-pinboard-surface>
{% for entry in entries %} {% for entry in entries %}
{% set isImageOnly = entry.imageFigure and not entry.headline and not entry.text and not entry.link %}
<article <article
class="pin-note{% if entry.highlighted %} is-highlighted{% endif %}" class="pin-note{% if entry.highlighted %} is-highlighted{% endif %}{% if isImageOnly %} pin-note--image-only{% endif %}"
data-pin-note data-pin-note
data-highlighted="{{ entry.highlighted ? '1' : '0' }}" data-highlighted="{{ entry.highlighted ? '1' : '0' }}"
data-seed="{{ entry.id }}" data-seed="{{ entry.id }}"
aria-label="{{ entry.headline }}" aria-label="{{ entry.headline }}"
> >
<div class="pin-note__inner" data-pin-note-inner> <div class="pin-note__inner" data-pin-note-inner>
{% if entry.imageFigure %}
<figure class="pin-note__image-wrap">
{% with {figure: entry.imageFigure} %}{{ block('figure_component') }}{% endwith %}
</figure>
{% endif %}
{% if entry.headline %} {% if entry.headline %}
<h3 class="pin-note__headline">{{ entry.headline }}</h3> <h3 class="pin-note__headline">{{ entry.headline }}</h3>
{% endif %} {% endif %}
@@ -27,6 +22,12 @@
<div class="pin-note__text">{{ entry.text|e|nl2br }}</div> <div class="pin-note__text">{{ entry.text|e|nl2br }}</div>
{% endif %} {% endif %}
{% if entry.imageFigure %}
<figure class="pin-note__image-wrap">
{% with {figure: entry.imageFigure} %}{{ block('figure_component') }}{% endwith %}
</figure>
{% endif %}
{% if entry.link %} {% if entry.link %}
<p class="pin-note__link-wrap"> <p class="pin-note__link-wrap">
<a href="{{ entry.link }}" class="pin-note__link" target="_blank" rel="noopener">Mehr erfahren</a> <a href="{{ entry.link }}" class="pin-note__link" target="_blank" rel="noopener">Mehr erfahren</a>
+30 -2
View File
@@ -2,12 +2,15 @@
width: 100%; width: 100%;
max-width: 1400px; max-width: 1400px;
margin: 0 auto; margin: 0 auto;
padding: 2em; padding: 0;
box-sizing: border-box; box-sizing: border-box;
} }
.pinboard { .pinboard {
--pin-gap: 1.25rem; --pin-gap: 1.25rem;
margin-top: -80px;
position: relative;
z-index: 1;
} }
.pinboard__surface { .pinboard__surface {
@@ -15,7 +18,7 @@
min-height: 42rem; min-height: 42rem;
padding: 1.2rem; padding: 1.2rem;
border: 30px solid #cba888; border: 30px solid #cba888;
border-radius: 1.2rem; border-radius: 0.7rem;
overflow: hidden; overflow: hidden;
background: background:
radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.18), transparent 42%), radial-gradient(circle at 20% 10%, rgba(255, 255, 255, 0.18), transparent 42%),
@@ -56,6 +59,7 @@
width: 18px; width: 18px;
height: 18px; height: 18px;
transform: translateX(-50%); transform: translateX(-50%);
z-index: 1;
border-radius: 50%; border-radius: 50%;
background: radial-gradient(circle at 35% 35%, #f2f2f2, #979797 68%, #707070 100%); background: radial-gradient(circle at 35% 35%, #f2f2f2, #979797 68%, #707070 100%);
box-shadow: 0 2px 4px rgba(0, 0, 0, 0.35); box-shadow: 0 2px 4px rgba(0, 0, 0, 0.35);
@@ -73,6 +77,26 @@
margin: 0 0 0.7rem; margin: 0 0 0.7rem;
} }
.pin-note--image-only .pin-note__inner {
min-height: 0;
padding: 0;
background: transparent;
box-shadow: none;
}
.pin-note--image-only .pin-note__image-wrap {
margin: 0;
}
.pin-note--image-only .pin-note__image-wrap img,
.pin-note--image-only .pin-note__image {
display: block;
width: 100%;
height: auto;
border-radius: 0.3rem;
box-shadow: 0 10px 22px rgba(20, 10, 5, 0.34);
}
.pin-note__image { .pin-note__image {
display: block; display: block;
width: 100%; width: 100%;
@@ -80,6 +104,10 @@
border-radius: 0.25rem; border-radius: 0.25rem;
} }
figure.pin-note__image-wrap a:hover img {
transform: none;
}
.pin-note__headline { .pin-note__headline {
margin: 0 0 0.5rem; margin: 0 0 0.5rem;
font-size: 1.1rem; font-size: 1.1rem;