Styling des Cookie-Hinweises von iwcc Cookie Gedöns
Einleitung
Achtung: Diese Anleitung bezieht sich auf Version 1 des Addons. In Version 2 gab es Änderungen am Fragment "iwcc_box.php".
Der Cookie Hinweis des iwcc Cookie Gedöns Addons erscheint standardmäßig als Lightbox welche die gesamte Seite überlagert. Zudem werden CSS- und Javascript-Dateien des Addons im Head-Bereich reingeladen. Dies läasst sich über das Fragment iwcc_box.php aus dem Ordner fragments im Ordner eigenen Wünschen anpassen. Dazu wird das Fragment z.B. in den Ordner theme/private/fragments kopiert, sofern das theme-Addon verwendet wird. Anschließend können die Änderungen vorgenommen werden.
Im nachfolgenden Beispiel wird auf pretty-checkbox und fontello verzichtet. Das CSS aus iwcc_frontend.css wird geändert in die Haupt-CSS-Datei der Website eingefügt.
Beispiel
Code
<?php
$iwcc = new iwcc_frontend($this->getVar('forceCache'));
$iwcc->setDomain($_SERVER['HTTP_HOST']);
if ($this->getVar('debug'))
{
dump($iwcc);
}
?>
<?php if ($iwcc->cookiegroups): ?>
<script src="/assets/addons/iwcc/js.cookie-2.2.1.min.js"></script>
<script src="/assets/addons/iwcc/iwcc_frontend.js"></script>
<script id="iwcc-template" type="text/template">
<div class="iwcc-background fr-version-bottom iwcc-hidden <?= $iwcc->boxClass ?>" id="iwcc-background" data-domain-name="<?= $iwcc->domainName ?>">
<div class="iwcc-wrapper" id="iwcc-wrapper">
<div class="iwcc-wrapper-inner">
<div class="iwcc-summary" id="iwcc-summary">
<p class="iwcc-headline"><?= $iwcc->texts['headline'] ?></p>
<p class="iwcc-text"><?= nl2br($iwcc->texts['description']) ?></p>
<div class="iwcc-cookiegroups">
<?php
foreach ($iwcc->cookiegroups as $cookiegroup) {
if ($cookiegroup['required']) {
echo '<div class="iwcc-cookiegroup-checkbox">';
echo '<input id="' . $cookiegroup['uid'] . '" type="checkbox" data-action="toggle-cookie" data-uid="' . $cookiegroup['uid'] . '" data-cookie-uids=\'' . json_encode($cookiegroup['cookie_uids']) . '\' disabled="disabled" checked="checked">';
echo '<label for="' . $cookiegroup['uid'] . '">' . $cookiegroup['name'] . '</label>';
if ($cookiegroup['script'])
{
echo '<div class="iwcc-script" data-script="' . $cookiegroup['script'] . '"></div>';
}
echo '</div>';
}
else {
echo '<div class="iwcc-cookiegroup-checkbox">';
echo '<input id="' . $cookiegroup['uid'] . '" type="checkbox" data-uid="' . $cookiegroup['uid'] . '" tabindex="1" autocomplete="off" data-cookie-uids=\'' . json_encode($cookiegroup['cookie_uids']) . '\'>';
echo '<label for="' . $cookiegroup['uid'] . '">' . $cookiegroup['name'] . '</label>';
if ($cookiegroup['script'])
{
echo '<div class="iwcc-script" data-script="' . $cookiegroup['script'] . '"></div>';
}
echo '</div>';
}
}
?>
<div class="iwcc-show-details">
<a id="iwcc-toggle-details" class="omnMoreInfo"><?= $iwcc->texts['toggle_details'] ?></a>
</div>
</div>
</div>
<div class="iwcc-detail iwcc-hidden" id="iwcc-detail">
<?php
foreach ($iwcc->cookiegroups as $cookiegroup)
{
echo '<div class="iwcc-cookiegroup-title iwcc-headline">';
echo $cookiegroup['name'] . ' <span>(' . count($cookiegroup['cookie']) . ')</span>';
echo '</div>';
echo '<div class="iwcc-cookiegroup-description">';
echo $cookiegroup['description'];
echo '</div>';
echo '<div class="iwcc-cookiegroup">';
foreach ($cookiegroup['cookie'] as $cookie)
{
echo '<div class="iwcc-cookie">';
echo '<span class="iwcc-cookie-name"><strong>' . $cookie['cookie_name'] . '</strong> (' . $cookie['service_name'] . ')</span>';
echo '<span class="iwcc-cookie-description">' . $cookie['description'] . '</span>';
echo '<span class="iwcc-cookie-description">' . $iwcc->texts['lifetime'] . ' ' . $cookie['cookie_lifetime'] . '</span>';
echo '<span class="iwcc-cookie-provider">' . $iwcc->texts['provider'] . ' ' . $cookie['provider'] . '</span>';
echo '<span class="iwcc-cookie-link-privacy-policy"><a href="' . $cookie['provider_link_privacy'] . '">' . $iwcc->texts['link_privacy'] . '</a></span>';
echo '</div>';
}
echo '</div>';
}
?>
</div>
<div class="iwcc-buttons-sitelinks">
<div class="iwcc-buttons">
<a class="iwcc-save-selection iwcc-close uk-button uk-button-default"><?= $iwcc->texts['button_accept'] ?></a>
<a class="iwcc-accept-all iwcc-close uk-button uk-button-primary"><?= $iwcc->texts['button_select_all'] ?></a>
</div>
<div class="iwcc-sitelinks">
<?php
foreach ($iwcc->links as $v)
{
echo '<a href="' . rex_getUrl($v) . '">' . rex_article::get($v)->getName() . '</a>';
}
?>
</div>
</div>
<a class="icon-cancel iwcc-close iwcc-close-box uk-hidden"></a>
</div>
</div>
</div>
</script>
<?php endif; ?>
.iwcc-background {
position: fixed;
left: 0;
top: 0;
right: 0;
bottom: 0;
background: rgba(0, 0, 0, 0.6);
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
padding: 1em;
z-index: 999999;
height: 100%;
width: 100%;
overflow: hidden;
.iwcc-wrapper {
background: #fff;
position: relative;
font-size: 13px;
line-height: 16px;
width: 100%;
max-width: 60em;
max-height: 100vh;
overflow-y: auto;
a {
cursor: pointer;
}
}
&.fr-version-bottom {
left: auto;
top: auto;
right: auto;
bottom: 0px;
padding: 0;
height: auto;
width: 100%;
background-color: white;
color: #666;
border-top: 1px solid black;
box-shadow: #ccc 2px 2px 8px 2px;
.iwcc-wrapper {
background: transparent;
}
}
}
.iwcc-wrapper-inner {
padding: 1em;
position: relative;
}
.iwcc-hidden {
display: none;
}
.iwcc-detail {
margin-bottom: 1em;
}
.iwcc-headline {
font-weight: bold;
font-size: 1em;
margin-bottom: 5px;
span {
font-weight: normal;
}
}
.iwcc-text {
margin: 0;
}
.iwcc-sitelinks {
a {
display: inline-block;
margin: 0 0.5em;
color: #999;
text-decoration: none;
&:hover {
color: #404040;
text-decoration: none;
}
&:first-child {
margin-left: 0;
}
}
}
.iwcc-save-selection {
color: #A5A5A5 !important;
}
.iwcc-close-box {
position: absolute;
right: 0.5em;
top: 0.5em;
display: block;
padding: 0;
margin: 0;
border: 0;
cursor: pointer;
color: #999;
font-size: 1.8em;
background: none transparent;
line-height: 1;
text-decoration: none;
&:before {
margin: 0;
}
&:hover {
color: #404040;
background: none transparent;
text-decoration: none;
}
}
.iwcc-cookiegroups {
margin: 8px 0 8px;
border: 1px solid #ccc;
padding: 4px 8px;
border-radius: 4px 0 0 4px;
&:after {
content: "";
clear: both;
display: table;
}
}
.iwcc-cookiegroup-checkbox, .iwcc-show-details {
margin: 0;
position: relative;
display: inline-block;
white-space: nowrap;
padding: 4px 10px;
line-height: 17px;
&:hover {
background-color: #EDEDED;
a {
text-decoration: none;
color: #666;
}
}
}
.iwcc-cookiegroup + .iwcc-cookiegroup-title {
margin-top: 1em;
}
.iwcc-cookie {
margin-top: 0.5em;
border-left: 2px solid #999;
padding: 0.5em 0.5em 0.5em 1em;
background: #f9f9f9;
span {
display: block;
}
}
.iwcc-wrapper {
input[type="checkbox"] {
opacity: 0;
height: 17px;
width: 17px;
position: absolute;
top: 0;
left: 0;
z-index: 2;
padding: 4px 8px;
}
input[type="checkbox"] + label, a.omnMoreInfo {
height: auto;
width: auto;
min-height: 17px;
display: block;
position: relative;
z-index: 1;
vertical-align: top;
line-height: 17px;
cursor: pointer;
padding: 1px 0 0 22px;
}
input[type="checkbox"] + label::before, a.omnMoreInfo::before {
position: absolute;
background-repeat: no-repeat;
background-position: left top;
height: 17px;
width: 17px;
display:inline-block;
padding: 0;
top: 0;
left: 0;
z-index: 1;
content: '';
}
input[type="checkbox"] + label::before {
background-image: url('');
}
input[type="checkbox"]:checked + label::before {
background-image: url('');
}
input[type="checkbox"]:disabled, input[type="checkbox"]:disabled + label {
cursor: not-allowed;
color: #666666;
}
input[type="checkbox"]:disabled + label::before {
background-image: url('');
}
a.omnMoreInfo::before {
background-image: url('');
}
}
@media (max-width:35em){
.iwcc-buttons {
display: flex;
justify-content: center;
align-items: center;
flex-direction: column-reverse;
}
.iwcc-save-selection, .iwcc-accept-all {
margin: 0em 0 0.5em 0;
}
.iwcc-buttons-sitelinks {
text-align: center;
}
}
@media (min-width: 35em) {
.iwcc-cookiegroups {
display: flex;
flex-wrap: wrap;
//justify-content: flex-end;
justify-content: flex-start;
}
.iwcc-buttons {
display: flex;
justify-content: flex-end;
align-items: center;
}
.iwcc-save-selection,
.iwcc-accept-all {
display: inline-block;
margin: 0 0 0 0.5em;
}
.iwcc-buttons-sitelinks {
display: flex;
justify-content: space-between;
flex-wrap: wrap;
flex-direction: row-reverse;
}
}