Compare commits
4 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
c863ab98f0 | ||
|
|
80dd19257c | ||
|
|
980a6d83dd | ||
|
|
4ef0608d64 |
@@ -9,3 +9,5 @@ $GLOBALS['BE_MOD']['content']['pinnwand'] = [
|
|||||||
];
|
];
|
||||||
|
|
||||||
$GLOBALS['TL_MODELS']['tl_pinnwand'] = PinboardModel::class;
|
$GLOBALS['TL_MODELS']['tl_pinnwand'] = PinboardModel::class;
|
||||||
|
|
||||||
|
$GLOBALS['TL_DCA']['tl_module']['palettes']['pinnwand'] = '{title_legend},name,headline,type;{image_legend},imgSize;{protected_legend:hide},protected;{expert_legend:hide},guests,cssID';
|
||||||
|
|||||||
5
contao/dca/tl_module.php
Normal file
5
contao/dca/tl_module.php
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
$GLOBALS['TL_DCA']['tl_module']['palettes']['pinnwand'] = '{title_legend},name,headline,type;{image_legend},imgSize;{protected_legend:hide},protected;{expert_legend:hide},guests,cssID';
|
||||||
@@ -102,14 +102,16 @@ $GLOBALS['TL_DCA']['tl_pinnwand'] = [
|
|||||||
'sorting' => true,
|
'sorting' => true,
|
||||||
'flag' => 6,
|
'flag' => 6,
|
||||||
'inputType' => 'text',
|
'inputType' => 'text',
|
||||||
'eval' => ['rgxp' => 'datim', 'datepicker' => true, 'mandatory' => true, 'default' => time(), 'tl_class' => 'w50 wizard'],
|
'default' => time(),
|
||||||
|
'eval' => ['rgxp' => 'datim', 'datepicker' => true, 'mandatory' => true, 'tl_class' => 'w50 wizard'],
|
||||||
'sql' => 'int(10) unsigned NOT NULL default 0',
|
'sql' => 'int(10) unsigned NOT NULL default 0',
|
||||||
],
|
],
|
||||||
'dateModified' => [
|
'dateModified' => [
|
||||||
'sorting' => true,
|
'sorting' => true,
|
||||||
'flag' => 6,
|
'flag' => 6,
|
||||||
'inputType' => 'text',
|
'inputType' => 'text',
|
||||||
'eval' => ['rgxp' => 'datim', 'readonly' => true, 'default' => time(), 'tl_class' => 'w50'],
|
'default' => time(),
|
||||||
|
'eval' => ['rgxp' => 'datim', 'readonly' => true, 'tl_class' => 'w50'],
|
||||||
'sql' => 'int(10) unsigned NOT NULL default 0',
|
'sql' => 'int(10) unsigned NOT NULL default 0',
|
||||||
],
|
],
|
||||||
'published' => [
|
'published' => [
|
||||||
@@ -145,14 +147,14 @@ $GLOBALS['TL_DCA']['tl_pinnwand']['fields']['ueberschrift']['save_callback'][] =
|
|||||||
$start = 2;
|
$start = 2;
|
||||||
$base = $baseHeadline;
|
$base = $baseHeadline;
|
||||||
|
|
||||||
if (preg_match('/^(.*)\s-\s(\d+)$/', $baseHeadline, $matches)) {
|
if (preg_match('/^(.*)\s\((\d+)\)$/', $baseHeadline, $matches)) {
|
||||||
$base = trim($matches[1]);
|
$base = trim($matches[1]);
|
||||||
$start = (int) $matches[2] + 1;
|
$start = (int) $matches[2] + 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
$id = (int) ($dataContainer->id ?? 0);
|
$id = (int) ($dataContainer->id ?? 0);
|
||||||
$number = max(2, $start);
|
$number = max(2, $start);
|
||||||
$candidate = sprintf('%s - %d', $base, $number);
|
$candidate = sprintf('%s (%d)', $base, $number);
|
||||||
|
|
||||||
do {
|
do {
|
||||||
$exists = Database::getInstance()
|
$exists = Database::getInstance()
|
||||||
@@ -164,6 +166,18 @@ $GLOBALS['TL_DCA']['tl_pinnwand']['fields']['ueberschrift']['save_callback'][] =
|
|||||||
}
|
}
|
||||||
|
|
||||||
++$number;
|
++$number;
|
||||||
$candidate = sprintf('%s - %d', $base, $number);
|
$candidate = sprintf('%s (%d)', $base, $number);
|
||||||
} while (true);
|
} while (true);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
$GLOBALS['TL_DCA']['tl_pinnwand']['fields']['dateAdded']['load_callback'][] = static function (mixed $value): int {
|
||||||
|
$timestamp = (int) $value;
|
||||||
|
|
||||||
|
return $timestamp > 0 ? $timestamp : time();
|
||||||
|
};
|
||||||
|
|
||||||
|
$GLOBALS['TL_DCA']['tl_pinnwand']['fields']['dateModified']['load_callback'][] = static function (mixed $value): int {
|
||||||
|
$timestamp = (int) $value;
|
||||||
|
|
||||||
|
return $timestamp > 0 ? $timestamp : time();
|
||||||
|
};
|
||||||
|
|||||||
0
contao/templates/.twig-root
Normal file
0
contao/templates/.twig-root
Normal file
@@ -1,4 +1,6 @@
|
|||||||
<link rel="stylesheet" href="{{ asset('bundles/contaopinboard/css/pinboard.css') }}">
|
{% use '@Contao/component/_figure.html.twig' %}
|
||||||
|
|
||||||
|
<link rel="stylesheet" href="{{ asset('bundles/contaopinboard/assets/pinboard.css') }}">
|
||||||
|
|
||||||
<section class="pinboard" data-pinboard>
|
<section class="pinboard" data-pinboard>
|
||||||
<div class="pinboard__surface" data-pinboard-surface>
|
<div class="pinboard__surface" data-pinboard-surface>
|
||||||
@@ -10,9 +12,9 @@
|
|||||||
data-seed="{{ entry.id }}"
|
data-seed="{{ entry.id }}"
|
||||||
aria-label="{{ entry.headline }}"
|
aria-label="{{ entry.headline }}"
|
||||||
>
|
>
|
||||||
{% if entry.imagePath %}
|
{% if entry.imageFigure %}
|
||||||
<figure class="pin-note__image-wrap">
|
<figure class="pin-note__image-wrap">
|
||||||
<img src="{{ asset(entry.imagePath) }}" alt="" class="pin-note__image">
|
{% with {figure: entry.imageFigure} %}{{ block('figure_component') }}{% endwith %}
|
||||||
</figure>
|
</figure>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
@@ -31,4 +33,4 @@
|
|||||||
</div>
|
</div>
|
||||||
</section>
|
</section>
|
||||||
|
|
||||||
<script src="{{ asset('bundles/contaopinboard/js/pinboard.js') }}" defer></script>
|
<script src="{{ asset('bundles/contaopinboard/assets/pinboard.js') }}" defer></script>
|
||||||
|
|||||||
Reference in New Issue
Block a user