... | ... |
@@ -20,7 +20,8 @@ |
20 | 20 |
"symfony/config": "^5.4", |
21 | 21 |
"symfony/dependency-injection": "^5.4", |
22 | 22 |
"symfony/http-kernel": "^5.4", |
23 |
- "vonrotenberg/htmx-bundle": "^1.0" |
|
23 |
+ "vonrotenberg/htmx-bundle": "^1.0", |
|
24 |
+ "menatwork/contao-multicolumnwizard-bundle": "^3.6" |
|
24 | 25 |
}, |
25 | 26 |
"require-dev": { |
26 | 27 |
"bamarni/composer-bin-plugin": "^1.5", |
... | ... |
@@ -9,17 +9,19 @@ |
9 | 9 |
*/ |
10 | 10 |
|
11 | 11 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungRebsorteModel; |
12 |
+use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungLeseartModel; |
|
12 | 13 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungReservationModel; |
13 | 14 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungSlotsModel; |
14 | 15 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungStandortModel; |
15 | 16 |
|
16 | 17 |
$GLOBALS['BE_MOD']['content']['weinanlieferung'] = array |
17 | 18 |
( |
18 |
- 'tables' => array('tl_vr_wa_standort', 'tl_vr_wa_slot', 'tl_vr_wa_rebsorte'), |
|
19 |
+ 'tables' => array('tl_vr_wa_standort', 'tl_vr_wa_slot', 'tl_vr_wa_rebsorte','tl_vr_wa_leseart'), |
|
19 | 20 |
'stylesheet' => array('bundles/vonrotenbergweinanlieferung/css/backend.css') |
20 | 21 |
); |
21 | 22 |
|
22 | 23 |
$GLOBALS['TL_MODELS']['tl_vr_wa_slot'] = WeinanlieferungSlotsModel::class; |
23 | 24 |
$GLOBALS['TL_MODELS']['tl_vr_wa_standort'] = WeinanlieferungStandortModel::class; |
24 | 25 |
$GLOBALS['TL_MODELS']['tl_vr_wa_rebsorte'] = WeinanlieferungRebsorteModel::class; |
26 |
+$GLOBALS['TL_MODELS']['tl_vr_wa_leseart'] = WeinanlieferungLeseartModel::class; |
|
25 | 27 |
$GLOBALS['TL_MODELS']['tl_vr_wa_reservation'] = WeinanlieferungReservationModel::class; |
26 | 28 |
new file mode 100644 |
... | ... |
@@ -0,0 +1,124 @@ |
1 |
+<?php |
|
2 |
+ |
|
3 |
+/** |
|
4 |
+ * This file is part of contao-weinanlieferung-bundle. |
|
5 |
+ * |
|
6 |
+ * (c) vonRotenberg |
|
7 |
+ * |
|
8 |
+ * @license commercial |
|
9 |
+ */ |
|
10 |
+ |
|
11 |
+use Contao\DC_Table; |
|
12 |
+use Contao\DataContainer; |
|
13 |
+ |
|
14 |
+$GLOBALS['TL_DCA']['tl_vr_wa_leseart'] = array |
|
15 |
+( |
|
16 |
+ // Config |
|
17 |
+ 'config' => array |
|
18 |
+ ( |
|
19 |
+ 'dataContainer' => DC_Table::class, |
|
20 |
+ 'enableVersioning' => true, |
|
21 |
+ 'sql' => array |
|
22 |
+ ( |
|
23 |
+ 'keys' => array |
|
24 |
+ ( |
|
25 |
+ 'id' => 'primary' |
|
26 |
+ ) |
|
27 |
+ ) |
|
28 |
+ ), |
|
29 |
+ |
|
30 |
+ // List |
|
31 |
+ 'list' => array |
|
32 |
+ ( |
|
33 |
+ 'sorting' => array |
|
34 |
+ ( |
|
35 |
+ 'mode' => DataContainer::MODE_SORTED, |
|
36 |
+ 'fields' => array('title'), |
|
37 |
+ 'flag' => DataContainer::SORT_INITIAL_LETTER_ASC, |
|
38 |
+ 'panelLayout' => 'limit' |
|
39 |
+ ), |
|
40 |
+ 'label' => array( |
|
41 |
+ 'fields' => array('title'), |
|
42 |
+ 'format' => '%s' |
|
43 |
+ ), |
|
44 |
+ 'global_operations' => array |
|
45 |
+ ( |
|
46 |
+ 'back' => array |
|
47 |
+ ( |
|
48 |
+ 'href' => 'table=tl_vr_wa_standort', |
|
49 |
+ 'class' => 'header_back', |
|
50 |
+ ), |
|
51 |
+ 'all' => array |
|
52 |
+ ( |
|
53 |
+ 'href' => 'act=select', |
|
54 |
+ 'class' => 'header_edit_all', |
|
55 |
+ 'attributes' => 'onclick="Backend.getScrollOffset()" accesskey="e"' |
|
56 |
+ ) |
|
57 |
+ ), |
|
58 |
+ 'operations' => array |
|
59 |
+ ( |
|
60 |
+ 'edit' => array |
|
61 |
+ ( |
|
62 |
+ 'href' => 'act=edit', |
|
63 |
+ 'icon' => 'edit.gif', |
|
64 |
+ ), |
|
65 |
+ 'copy' => array |
|
66 |
+ ( |
|
67 |
+ 'href' => 'act=paste&mode=copy', |
|
68 |
+ 'icon' => 'copy.svg' |
|
69 |
+ ), |
|
70 |
+ 'cut' => array |
|
71 |
+ ( |
|
72 |
+ 'href' => 'act=paste&mode=cut', |
|
73 |
+ 'icon' => 'cut.svg', |
|
74 |
+ 'attributes' => 'onclick="Backend.getScrollOffset()"' |
|
75 |
+ ), |
|
76 |
+ 'delete' => array |
|
77 |
+ ( |
|
78 |
+ 'href' => 'act=delete', |
|
79 |
+ 'icon' => 'delete.gif', |
|
80 |
+ ), |
|
81 |
+ 'show' => array |
|
82 |
+ ( |
|
83 |
+ 'icon' => 'show.gif', |
|
84 |
+ ), |
|
85 |
+ ) |
|
86 |
+ ), |
|
87 |
+ |
|
88 |
+ // Palettes |
|
89 |
+ 'palettes' => array |
|
90 |
+ ( |
|
91 |
+ 'default' => '{title_legend},title' |
|
92 |
+ ), |
|
93 |
+ |
|
94 |
+ // Subpalettes |
|
95 |
+ 'subpalettes' => array |
|
96 |
+ ( |
|
97 |
+ ), |
|
98 |
+ |
|
99 |
+ // Fields |
|
100 |
+ 'fields' => array |
|
101 |
+ ( |
|
102 |
+ 'id' => array |
|
103 |
+ ( |
|
104 |
+ 'sql' => "int(10) unsigned NOT NULL auto_increment" |
|
105 |
+ ), |
|
106 |
+ 'tstamp' => array |
|
107 |
+ ( |
|
108 |
+ 'sql' => "int(10) unsigned NOT NULL default 0" |
|
109 |
+ ), |
|
110 |
+ 'title' => array |
|
111 |
+ ( |
|
112 |
+ 'exclude' => true, |
|
113 |
+ 'sorting' => true, |
|
114 |
+ 'flag' => DataContainer::SORT_INITIAL_LETTER_ASC, |
|
115 |
+ 'inputType' => 'text', |
|
116 |
+ 'eval' => array |
|
117 |
+ ( |
|
118 |
+ 'mandatory' => true, |
|
119 |
+ 'maxlength' => 255 |
|
120 |
+ ), |
|
121 |
+ 'sql' => "varchar(255) NOT NULL default ''" |
|
122 |
+ ) |
|
123 |
+ ) |
|
124 |
+); |
... | ... |
@@ -56,7 +56,7 @@ $GLOBALS['TL_DCA']['tl_vr_wa_reservation'] = array |
56 | 56 |
'sorten' => array |
57 | 57 |
( |
58 | 58 |
'foreignKey' => 'tl_vr_wa_rebsorte.title', |
59 |
- 'eval' => array('multiple'=>true, 'csv'=>','), |
|
59 |
+ 'eval' => array('multiple'=>true, 'csv'=>';'), |
|
60 | 60 |
'sql' => "blob NULL", |
61 | 61 |
'relation' => array('type' => 'hasMany', 'load' => 'lazy') |
62 | 62 |
), |
... | ... |
@@ -89,7 +89,7 @@ $GLOBALS['TL_DCA']['tl_vr_wa_slot'] = array |
89 | 89 |
'palettes' => array |
90 | 90 |
( |
91 | 91 |
'__selector__' => array('addEnclosure'), |
92 |
- 'default' => '{time_legend},date,time;{type_legend},behaelter,leseart,sorte;{info_legend},anmerkungen,addEnclosure;{booking_legend},buchbar,buchbar_bis' |
|
92 |
+ 'default' => '{time_legend},date,time;{type_legend},behaelter,sorten;{info_legend},anmerkungen,addEnclosure;{booking_legend},buchbar,buchbar_bis' |
|
93 | 93 |
), |
94 | 94 |
|
95 | 95 |
// Subpalettes |
... | ... |
@@ -149,23 +149,32 @@ $GLOBALS['TL_DCA']['tl_vr_wa_slot'] = array |
149 | 149 |
'eval' => array('rgxp' => 'natural', 'mandatory' => true, 'includeBlankOption' => true, 'tl_class' => 'w50'), |
150 | 150 |
'sql' => "smallint(3) unsigned NOT NULL default 0" |
151 | 151 |
), |
152 |
- 'leseart' => array |
|
152 |
+ 'sorten' => array |
|
153 | 153 |
( |
154 | 154 |
'exclude' => true, |
155 |
- 'inputType' => 'select', |
|
156 |
- 'options' => [], |
|
157 |
- 'reference' => &$GLOBALS['TL_LANG']['MSC']['leseart'], |
|
158 |
- 'eval' => array('rgxp' => 'natural', 'mandatory' => false, 'includeBlankOption' => true, 'tl_class' => 'clr w50'), |
|
159 |
- 'sql' => "varchar(32) NOT NULL default ''" |
|
160 |
- ), |
|
161 |
- 'sorte' => array |
|
162 |
- ( |
|
163 |
- 'exclude' => true, |
|
164 |
- 'inputType' => 'select', |
|
165 |
- 'foreignKey' => 'tl_vr_wa_rebsorte.title', |
|
166 |
- 'eval' => array('rgxp' => 'natural', 'mandatory' => false, 'multiple'=>true,'chosen'=>true,'includeBlankOption' => true, 'tl_class' => 'w50','csv'=>','), |
|
155 |
+ 'inputType' => 'multiColumnWizard', |
|
156 |
+ 'eval' => array( |
|
157 |
+ 'minCount' => 1, |
|
158 |
+ 'tl_class' => 'clr', |
|
159 |
+ 'columnFields' => array |
|
160 |
+ ( |
|
161 |
+ 'sorte' => array |
|
162 |
+ ( |
|
163 |
+ 'label' => $GLOBALS['TL_LANG']['MSC']['wa_sorte'], |
|
164 |
+ 'inputType' => 'select', |
|
165 |
+ 'foreignKey' => 'tl_vr_wa_rebsorte.title', |
|
166 |
+ 'eval' => array('style' => 'width:350px','mandatory' => true,'chosen'=>true,'includeBlankOption' => true) |
|
167 |
+ ), |
|
168 |
+ 'leseart' => array |
|
169 |
+ ( |
|
170 |
+ 'label' => $GLOBALS['TL_LANG']['MSC']['wa_leseart'], |
|
171 |
+ 'inputType' => 'select', |
|
172 |
+ 'foreignKey' => 'tl_vr_wa_leseart.title', |
|
173 |
+ 'eval' => array('style' => 'width:350px','mandatory' => true,'chosen'=>true,'includeBlankOption' => true) |
|
174 |
+ ) |
|
175 |
+ ) |
|
176 |
+ ), |
|
167 | 177 |
'sql' => "blob NULL", |
168 |
- 'relation' => array('type' => 'hasMany', 'load' => 'lazy') |
|
169 | 178 |
), |
170 | 179 |
'anmerkungen' => array |
171 | 180 |
( |
... | ... |
@@ -49,6 +49,11 @@ $GLOBALS['TL_DCA']['tl_vr_wa_standort'] = array |
49 | 49 |
'href' => 'table=tl_vr_wa_rebsorte', |
50 | 50 |
'class' => 'header_rebsorte', |
51 | 51 |
), |
52 |
+ 'leseart' => array |
|
53 |
+ ( |
|
54 |
+ 'href' => 'table=tl_vr_wa_leseart', |
|
55 |
+ 'class' => 'header_leseart', |
|
56 |
+ ), |
|
52 | 57 |
'all' => array |
53 | 58 |
( |
54 | 59 |
'href' => 'act=select', |
55 | 60 |
new file mode 100644 |
... | ... |
@@ -0,0 +1,12 @@ |
1 |
+<?php |
|
2 |
+ |
|
3 |
+/** |
|
4 |
+ * This file is part of contao-weinanlieferung-bundle. |
|
5 |
+ * |
|
6 |
+ * (c) vonRotenberg |
|
7 |
+ * |
|
8 |
+ * @license commercial |
|
9 |
+ */ |
|
10 |
+ |
|
11 |
+$GLOBALS['TL_LANG']['MSC']['wa_sorte'] = 'Rebsorte'; |
|
12 |
+$GLOBALS['TL_LANG']['MSC']['wa_leseart'] = 'Leseart'; |
... | ... |
@@ -14,6 +14,7 @@ use vonRotenberg\WeinanlieferungBundle\Controller\Frontend\Module\Weinanlieferun |
14 | 14 |
$GLOBALS['TL_LANG']['MOD']['weinanlieferung'][0] = 'Weinanlieferung'; |
15 | 15 |
$GLOBALS['TL_LANG']['MOD']['weinanlieferung'][1] = 'Buchungstool zur Weinanlieferung'; |
16 | 16 |
$GLOBALS['TL_LANG']['MOD']['tl_vr_wa_rebsorte'] = 'Rebsorten'; |
17 |
+$GLOBALS['TL_LANG']['MOD']['tl_vr_wa_leseart'] = 'Leseart'; |
|
17 | 18 |
$GLOBALS['TL_LANG']['MOD']['tl_vr_wa_slot'] = 'Zeitslots'; |
18 | 19 |
|
19 | 20 |
$GLOBALS['TL_LANG']['FMD'][WeinanlieferungSlotsListModuleController::TYPE][0] = 'Weinanlieferung-Zeitslotliste'; |
... | ... |
@@ -16,8 +16,8 @@ $GLOBALS['TL_LANG']['tl_vr_wa_slot']['behaelter'][0] = 'Behälter'; |
16 | 16 |
$GLOBALS['TL_LANG']['tl_vr_wa_slot']['behaelter'][1] = 'Anzahl der Behälter, die verarbeitet werden können.'; |
17 | 17 |
$GLOBALS['TL_LANG']['tl_vr_wa_slot']['leseart'][0] = 'Leseart'; |
18 | 18 |
$GLOBALS['TL_LANG']['tl_vr_wa_slot']['leseart'][1] = 'Die verwendete Leseart.'; |
19 |
-$GLOBALS['TL_LANG']['tl_vr_wa_slot']['sorte'][0] = 'Rebsorten'; |
|
20 |
-$GLOBALS['TL_LANG']['tl_vr_wa_slot']['sorte'][1] = 'Die Rebsorten, die in diesem Zeitslot verarbeitet werden.'; |
|
19 |
+$GLOBALS['TL_LANG']['tl_vr_wa_slot']['sorten'][0] = 'Rebsorten'; |
|
20 |
+$GLOBALS['TL_LANG']['tl_vr_wa_slot']['sorten'][1] = 'Die Rebsorten, die in diesem Zeitslot verarbeitet werden.'; |
|
21 | 21 |
$GLOBALS['TL_LANG']['tl_vr_wa_slot']['anmerkungen'][0] = 'Anmerkungen'; |
22 | 22 |
$GLOBALS['TL_LANG']['tl_vr_wa_slot']['anmerkungen'][1] = 'Ergänzende Hinweise zu diesem Zeitslot.'; |
23 | 23 |
$GLOBALS['TL_LANG']['tl_vr_wa_slot']['addEnclosure'][0] = 'Anhänge'; |
... | ... |
@@ -14,3 +14,4 @@ $GLOBALS['TL_LANG']['tl_vr_wa_standort']['title'][1] = 'Der Name des Anlieferung |
14 | 14 |
$GLOBALS['TL_LANG']['tl_vr_wa_standort']['title_legend'] = 'Standort'; |
15 | 15 |
|
16 | 16 |
$GLOBALS['TL_LANG']['tl_vr_wa_standort']['rebsorte'] = 'Rebsorten'; |
17 |
+$GLOBALS['TL_LANG']['tl_vr_wa_standort']['leseart'] = 'Leseart'; |
... | ... |
@@ -23,7 +23,7 @@ |
23 | 23 |
</div> |
24 | 24 |
<div class="col u-text-right action"> |
25 | 25 |
<a hx-get="/_ajax/vr_wa/v1/slot?do=booking&id={{ booking.id }}" hx-target="body" hx-swap="beforeend" href="javascript:;" class="btn btn--xs m-0">Anzeigen</a> |
26 |
- <a hx-get="/_ajax/vr_wa/v1/slot?do=delete&id={{ booking.id }}" hx-target="body" hx-swap="beforeend" href="javascript:;" class="btn btn--xs btn-danger m-0">Löschen</a> |
|
26 |
+ <a hx-get="/_ajax/vr_wa/v1/slot?do=delete&id={{ booking.id }}" hx-target="body" hx-swap="beforeend" hx-confirm="Sind Sie sicher, dass Sie diese Reservierung löschen möchten?" href="javascript:;" class="btn btn--xs btn-danger m-0">Löschen</a> |
|
27 | 27 |
</div> |
28 | 28 |
</div> |
29 | 29 |
{% endfor %} |
... | ... |
@@ -1,4 +1,5 @@ |
1 |
-.header_rebsorte { |
|
1 |
+.header_rebsorte, |
|
2 |
+.header_leseart { |
|
2 | 3 |
padding:3px 0 3px 21px; |
3 | 4 |
background-position:left center; |
4 | 5 |
background-repeat:no-repeat; |
... | ... |
@@ -7,3 +8,6 @@ |
7 | 8 |
.header_rebsorte { |
8 | 9 |
background-image:url("/bundles/vonrotenbergweinanlieferung/images/icons/reben.svg"); |
9 | 10 |
} |
11 |
+.header_leseart { |
|
12 |
+ background-image:url("/bundles/vonrotenbergweinanlieferung/images/icons/schere.svg"); |
|
13 |
+} |
... | ... |
@@ -1 +1 @@ |
1 |
-<?xml version="1.0" encoding="UTF-8" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg width="16px" height="16px" viewBox="0 0 600 600" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:2;"><g><g><path d="M128.043,160.998c21.826,3.314 36.857,23.724 33.543,45.551c-3.314,21.827 -23.724,36.857 -45.551,33.543c-21.826,-3.313 -36.856,-23.724 -33.543,-45.551c3.314,-21.826 23.724,-36.856 45.551,-33.543Z" style="fill:#462592;"/><path d="M129.244,153.089c26.191,3.976 44.228,28.469 40.251,54.661c-3.976,26.192 -28.469,44.228 -54.66,40.251c-26.192,-3.976 -44.228,-28.468 -40.252,-54.66c3.976,-26.192 28.469,-44.228 54.661,-40.252Z" style="fill:#462592;"/><path d="M173.554,260.962c26.192,3.976 44.228,28.469 40.252,54.661c-3.976,26.191 -28.469,44.228 -54.661,40.251c-26.191,-3.976 -44.228,-28.469 -40.251,-54.66c3.976,-26.192 28.469,-44.228 54.66,-40.252Z" style="fill:#462592;"/><path d="M217.865,368.835c26.192,3.976 44.228,28.469 40.252,54.66c-3.976,26.192 -28.469,44.228 -54.661,40.252c-26.191,-3.976 -44.228,-28.469 -40.251,-54.661c3.976,-26.191 28.469,-44.228 54.66,-40.251Z" style="fill:#462592;"/><path d="M336.506,386.846c26.192,3.976 44.228,28.469 40.252,54.661c-3.977,26.192 -28.469,44.228 -54.661,40.251c-26.192,-3.976 -44.228,-28.469 -40.252,-54.66c3.976,-26.192 28.469,-44.228 54.661,-40.252Z" style="fill:#462592;"/><path d="M262.176,476.707c26.192,3.977 44.228,28.469 40.252,54.661c-3.976,26.192 -28.469,44.228 -54.661,40.252c-26.192,-3.976 -44.228,-28.469 -40.252,-54.661c3.977,-26.192 28.469,-44.228 54.661,-40.252Z" style="fill:#462592;"/><path d="M247.884,171.1c26.192,3.977 44.228,28.469 40.252,54.661c-3.976,26.192 -28.469,44.228 -54.661,40.252c-26.192,-3.977 -44.228,-28.469 -40.252,-54.661c3.977,-26.192 28.469,-44.228 54.661,-40.252Z" style="fill:#462592;"/><path d="M292.195,278.973c26.192,3.976 44.228,28.469 40.252,54.661c-3.976,26.192 -28.469,44.228 -54.661,40.252c-26.192,-3.977 -44.228,-28.469 -40.252,-54.661c3.977,-26.192 28.469,-44.228 54.661,-40.252Z" style="fill:#462592;"/><path d="M410.836,296.984c26.192,3.977 44.228,28.469 40.251,54.661c-3.976,26.192 -28.469,44.228 -54.66,40.252c-26.192,-3.976 -44.228,-28.469 -40.252,-54.661c3.976,-26.192 28.469,-44.228 54.661,-40.252Z" style="fill:#462592;"/><path d="M366.525,189.112c26.192,3.976 44.228,28.469 40.252,54.66c-3.977,26.192 -28.469,44.228 -54.661,40.252c-26.192,-3.976 -44.228,-28.469 -40.252,-54.661c3.976,-26.191 28.469,-44.228 54.661,-40.251Z" style="fill:#462592;"/><path d="M485.165,207.123c26.192,3.976 44.228,28.469 40.252,54.661c-3.976,26.191 -28.469,44.228 -54.661,40.251c-26.191,-3.976 -44.228,-28.469 -40.251,-54.66c3.976,-26.192 28.469,-44.228 54.66,-40.252Z" style="fill:#462592;"/></g><path d="M301.146,167.049c0,-0 25.368,-112.94 68.42,-131.217l39.547,6.003c-0,0 -39.5,19.327 -88.762,128.129l-19.205,-2.915Z" style="fill:#259232;"/></g></svg> |
|
2 | 1 |
\ No newline at end of file |
2 |
+<?xml version="1.0" encoding="UTF-8" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg width="16px" height="16px" viewBox="0 0 600 600" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:2;"><g><g><path d="M127.578,156.518c24.702,3.75 41.711,26.849 37.961,51.55c-3.75,24.701 -26.848,41.711 -51.55,37.961c-24.701,-3.75 -41.71,-26.849 -37.961,-51.55c3.75,-24.701 26.849,-41.711 51.55,-37.961Z" style="fill:#462592;"/><path d="M174.53,246.999c34.3,5.207 57.919,37.282 52.712,71.582c-5.207,34.3 -37.282,57.92 -71.582,52.712c-34.3,-5.207 -57.92,-37.282 -52.712,-71.581c5.207,-34.3 37.282,-57.92 71.582,-52.713Z" style="fill:#462592;"/><path d="M225.829,374.71c23.351,3.545 39.431,25.381 35.886,48.732c-3.545,23.351 -25.381,39.431 -48.732,35.886c-23.352,-3.545 -39.432,-25.381 -35.887,-48.732c3.545,-23.351 25.382,-39.431 48.733,-35.886Z" style="fill:#462592;"/><path d="M342.957,422.684c17.852,2.71 30.146,19.405 27.436,37.257c-2.711,17.853 -19.405,30.146 -37.257,27.436c-17.853,-2.71 -30.146,-19.405 -27.436,-37.257c2.71,-17.853 19.404,-30.146 37.257,-27.436Z" style="fill:#462592;"/><path d="M260.921,477.436c26.192,3.976 44.228,28.469 40.252,54.661c-3.977,26.191 -28.469,44.228 -54.661,40.251c-26.192,-3.976 -44.228,-28.469 -40.252,-54.661c3.977,-26.191 28.469,-44.228 54.661,-40.251Z" style="fill:#462592;"/><path d="M245.895,166.666c23.521,3.571 39.719,25.567 36.148,49.089c-3.571,23.522 -25.567,39.719 -49.089,36.148c-23.521,-3.571 -39.719,-25.567 -36.148,-49.088c3.571,-23.522 25.567,-39.72 49.089,-36.149Z" style="fill:#462592;"/><path d="M300.796,280.648c25.67,3.897 43.346,27.901 39.449,53.57c-3.897,25.67 -27.901,43.346 -53.57,39.449c-25.67,-3.897 -43.346,-27.901 -39.449,-53.57c3.897,-25.67 27.901,-43.346 53.57,-39.449Z" style="fill:#462592;"/><path d="M398.518,314.709c22.331,3.39 37.708,24.272 34.317,46.602c-3.39,22.33 -24.271,37.708 -46.601,34.317c-22.331,-3.39 -37.708,-24.271 -34.318,-46.601c3.391,-22.331 24.272,-37.708 46.602,-34.318Z" style="fill:#462592;"/><path d="M363.102,204.117c18.312,2.78 30.922,19.904 28.142,38.216c-2.78,18.312 -19.904,30.922 -38.216,28.142c-18.312,-2.78 -30.922,-19.904 -28.142,-38.216c2.78,-18.312 19.904,-30.922 38.216,-28.142Z" style="fill:#462592;"/><path d="M484.777,202.139c29.345,4.455 49.552,31.896 45.097,61.24c-4.455,29.345 -31.896,49.552 -61.24,45.097c-29.344,-4.455 -49.552,-31.896 -45.097,-61.24c4.455,-29.345 31.896,-49.552 61.24,-45.097Z" style="fill:#462592;"/></g><path d="M301.146,167.049c0,-0 25.368,-112.94 68.42,-131.217l39.547,6.003c-0,0 -39.5,19.327 -88.762,128.129l-19.205,-2.915Z" style="fill:#259232;"/></g></svg> |
|
3 | 3 |
\ No newline at end of file |
4 | 4 |
new file mode 100644 |
... | ... |
@@ -0,0 +1 @@ |
1 |
+<?xml version="1.0" encoding="UTF-8" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg width="16px" height="16px" viewBox="0 0 600 600" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:2;"><g><path d="M339.851,268.552l-41.185,20.628l-15.669,-31.276l41.192,-20.641l15.662,31.289Z" style="fill:#585858;fill-rule:nonzero;"/><path d="M381.328,317.165l-0.994,-46.062l-34.982,0.765l0.997,46.051l34.979,-0.754Z" style="fill:#585858;fill-rule:nonzero;"/><path d="M434.823,17.328c36.356,21.909 37.361,83.346 6.034,135.316c-32.157,53.355 -86.977,79.343 -122.509,57.928l116.475,-193.244Z" style="fill:#3b3b3b;fill-rule:nonzero;"/><path d="M320.409,207.207c14.396,-23.864 45.395,-31.558 69.256,-17.173c23.872,14.388 31.558,45.394 17.17,69.266c-14.381,23.86 -45.382,31.545 -69.258,17.163c-23.866,-14.384 -31.552,-45.39 -17.168,-69.256Z" style="fill:#585858;fill-rule:nonzero;"/><path d="M62.816,411.922l40.125,47.985l194.647,-162.455c10.483,-5.437 15.577,-17.595 12.151,-28.912c-4.099,-13.509 -18.656,-20.754 -31.937,-16.009l-214.986,159.391Z" style="fill:#9f3330;fill-rule:nonzero;"/><path d="M346.134,582.672l-61.764,-10.361l53.321,-250.689c-0.089,-11.809 8.282,-21.991 19.894,-24.249c13.846,-2.693 27.059,6.803 29.068,20.768l-40.519,264.531Z" style="fill:#9f3330;fill-rule:nonzero;"/><path d="M489.563,50.321c121.816,73.42 -12.415,310.3 -151.998,226.176l52.122,-86.479c33.649,20.29 81.83,11.759 103.949,-33.404l8.312,-23.876c7.448,-34.427 -5.818,-63.6 -12.385,-82.417Z" style="fill:#585858;fill-rule:nonzero;"/><path d="M370.883,221.206c6.656,4.01 8.799,12.656 4.793,19.312c-4.01,6.653 -12.66,8.797 -19.313,4.787c-6.66,-4.014 -8.797,-12.657 -4.787,-19.313c4.015,-6.654 12.653,-8.798 19.307,-4.786Z" style="fill-rule:nonzero;"/></g></svg> |
|
0 | 2 |
\ No newline at end of file |
... | ... |
@@ -18,12 +18,15 @@ use Contao\CoreBundle\Framework\ContaoFramework; |
18 | 18 |
use Contao\CoreBundle\Security\Authentication\Token\TokenChecker; |
19 | 19 |
use Contao\FrontendUser; |
20 | 20 |
use Contao\Input; |
21 |
+use Contao\StringUtil; |
|
21 | 22 |
use Contao\System; |
22 | 23 |
use Doctrine\DBAL\Connection; |
23 | 24 |
use Symfony\Component\HttpFoundation\Request; |
24 | 25 |
use Symfony\Component\HttpFoundation\Response; |
25 | 26 |
use Symfony\Component\Routing\Annotation\Route; |
26 | 27 |
use Symfony\Contracts\Translation\TranslatorInterface; |
28 |
+use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungLeseartModel; |
|
29 |
+use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungRebsorteModel; |
|
27 | 30 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungReservationModel; |
28 | 31 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungSlotsModel; |
29 | 32 |
|
... | ... |
@@ -83,7 +86,6 @@ class SlotAjaxController extends AbstractController |
83 | 86 |
} |
84 | 87 |
|
85 | 88 |
return new Response('',500); |
86 |
- return new Response(null,203); |
|
87 | 89 |
} |
88 | 90 |
|
89 | 91 |
protected function renderDetails(bool $blnModal=true) |
... | ... |
@@ -106,10 +108,18 @@ class SlotAjaxController extends AbstractController |
106 | 108 |
foreach ($Reservations as $reservation) |
107 | 109 |
{ |
108 | 110 |
$arrSortenBooked = []; |
109 |
- if (($Sorten = $reservation->getRelated('sorten')) !== null) |
|
111 |
+ $SortenLeseart = explode(';',$reservation->sorten); |
|
112 |
+ foreach($SortenLeseart as $sorteLeseart) |
|
110 | 113 |
{ |
111 |
- $arrSortenBooked = $Sorten->fetchEach('title'); |
|
114 |
+ list($sorte,$leseart) = explode(',',$sorteLeseart); |
|
115 |
+ $objSorte = WeinanlieferungRebsorteModel::findByPk($sorte); |
|
116 |
+ $objLeseart = WeinanlieferungLeseartModel::findByPk($leseart); |
|
117 |
+ $arrSortenBooked[$objSorte->id.','.$objLeseart->id] = ($objSorte !== null ? $objSorte->title : '') . ' ' . ($objLeseart !== null ? $objLeseart->title : ''); |
|
112 | 118 |
} |
119 |
+ /*if (($Sorten = $reservation->getRelated('sorten')) !== null) |
|
120 |
+ { |
|
121 |
+ $arrSortenBooked = $Sorten->fetchEach('title'); |
|
122 |
+ }*/ |
|
113 | 123 |
$arrReservations[] = array_merge($reservation->row(),[ |
114 | 124 |
'sorten' => $arrSortenBooked |
115 | 125 |
]); |
... | ... |
@@ -118,10 +128,17 @@ class SlotAjaxController extends AbstractController |
118 | 128 |
|
119 | 129 |
// Build data |
120 | 130 |
$arrSorten = []; |
121 |
- if (($Sorten = $Slot->getRelated('sorte')) !== null) |
|
131 |
+ $Sorten = StringUtil::deserialize($Slot->sorten,true); |
|
132 |
+ foreach($Sorten as $sorte) |
|
122 | 133 |
{ |
123 |
- $arrSorten = array_combine($Sorten->fetchEach('id'),$Sorten->fetchEach('title')); |
|
134 |
+ $objSorte = WeinanlieferungRebsorteModel::findByPk($sorte['sorte']); |
|
135 |
+ $objLeseart = WeinanlieferungLeseartModel::findByPk($sorte['leseart']); |
|
136 |
+ $arrSorten[$objSorte->id.','.$objLeseart->id] = ($objSorte !== null ? $objSorte->title : '') . ' ' . ($objLeseart !== null ? $objLeseart->title : ''); |
|
124 | 137 |
} |
138 |
+ /*if (($Sorten = $Slot->getRelated('sorte')) !== null) |
|
139 |
+ { |
|
140 |
+ $arrSorten = array_combine($Sorten->fetchEach('id'),$Sorten->fetchEach('title')); |
|
141 |
+ }*/ |
|
125 | 142 |
|
126 | 143 |
$intAvailableBehaelter = $Slot->getAvailableBehaelter(); |
127 | 144 |
|
... | ... |
@@ -158,14 +175,21 @@ class SlotAjaxController extends AbstractController |
158 | 175 |
} |
159 | 176 |
|
160 | 177 |
$arrSortenAvailable = []; |
161 |
- if (($Sorten = $Slot->getRelated('sorte')) !== null) |
|
178 |
+ $Sorten = StringUtil::deserialize($Slot->sorten,true); |
|
179 |
+ foreach($Sorten as $sorte) |
|
162 | 180 |
{ |
163 |
- $arrSortenAvailable = array_combine($Sorten->fetchEach('id'),$Sorten->fetchEach('title')); |
|
181 |
+ $objSorte = WeinanlieferungRebsorteModel::findByPk($sorte['sorte']); |
|
182 |
+ $objLeseart = WeinanlieferungLeseartModel::findByPk($sorte['leseart']); |
|
183 |
+ $arrSortenAvailable[$objSorte->id.','.$objLeseart->id] = ($objSorte !== null ? $objSorte->title : '') . ' ' . ($objLeseart !== null ? $objLeseart->title : ''); |
|
164 | 184 |
} |
165 | 185 |
$arrSortenBooked = []; |
166 |
- if (($Sorten = $Booking->getRelated('sorten')) !== null) |
|
186 |
+ $SortenLeseart = explode(';',$Booking->sorten); |
|
187 |
+ foreach($SortenLeseart as $sorteLeseart) |
|
167 | 188 |
{ |
168 |
- $arrSortenBooked = array_combine($Sorten->fetchEach('id'),$Sorten->fetchEach('title')); |
|
189 |
+ list($sorte,$leseart) = explode(',',$sorteLeseart); |
|
190 |
+ $objSorte = WeinanlieferungRebsorteModel::findByPk($sorte); |
|
191 |
+ $objLeseart = WeinanlieferungLeseartModel::findByPk($leseart); |
|
192 |
+ $arrSortenBooked[$objSorte->id.','.$objLeseart->id] = ($objSorte !== null ? $objSorte->title : '') . ' ' . ($objLeseart !== null ? $objLeseart->title : ''); |
|
169 | 193 |
} |
170 | 194 |
|
171 | 195 |
$intAvailableBehaelter = $Slot->getAvailableBehaelter(); |
... | ... |
@@ -203,7 +227,7 @@ class SlotAjaxController extends AbstractController |
203 | 227 |
{ |
204 | 228 |
$arrSorten[] = Input::post('sorten'); |
205 | 229 |
} else { |
206 |
- $arrSorten = implode(',', Input::post('sorten')); |
|
230 |
+ $arrSorten = implode(';', Input::post('sorten')); |
|
207 | 231 |
} |
208 | 232 |
|
209 | 233 |
$Reservation = new WeinanlieferungReservationModel(); |
... | ... |
@@ -21,9 +21,11 @@ use Contao\Date; |
21 | 21 |
use Contao\FrontendUser; |
22 | 22 |
use Contao\ModuleModel; |
23 | 23 |
use Contao\StringUtil; |
24 |
+use Contao\System; |
|
24 | 25 |
use Contao\Template; |
25 | 26 |
use Symfony\Component\HttpFoundation\Request; |
26 | 27 |
use Symfony\Component\HttpFoundation\Response; |
28 |
+use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungLeseartModel; |
|
27 | 29 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungRebsorteModel; |
28 | 30 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungReservationModel; |
29 | 31 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungSlotsModel; |
... | ... |
@@ -58,9 +60,13 @@ class WeinanlieferungBookedListModuleController extends AbstractFrontendModuleCo |
58 | 60 |
$day = new Date($Slot->date); |
59 | 61 |
$arrSorten = []; |
60 | 62 |
|
61 |
- if (($Sorten = $booking->getRelated('sorten')) !== null) |
|
63 |
+ $SortenLeseart = explode(';',$booking->sorten); |
|
64 |
+ foreach($SortenLeseart as $sorteLeseart) |
|
62 | 65 |
{ |
63 |
- $arrSorten = $Sorten->fetchEach('title'); |
|
66 |
+ list($sorte,$leseart) = explode(',',$sorteLeseart); |
|
67 |
+ $objSorte = WeinanlieferungRebsorteModel::findByPk($sorte); |
|
68 |
+ $objLeseart = WeinanlieferungLeseartModel::findByPk($leseart); |
|
69 |
+ $arrSorten[$objSorte->id.','.$objLeseart->id] = ($objSorte !== null ? $objSorte->title : '') . ' ' . ($objLeseart !== null ? $objLeseart->title : ''); |
|
64 | 70 |
} |
65 | 71 |
|
66 | 72 |
$arrData['days'][$day->dayBegin][] = array_merge($booking->row(), [ |
... | ... |
@@ -21,9 +21,11 @@ use Contao\Date; |
21 | 21 |
use Contao\FrontendUser; |
22 | 22 |
use Contao\ModuleModel; |
23 | 23 |
use Contao\StringUtil; |
24 |
+use Contao\System; |
|
24 | 25 |
use Contao\Template; |
25 | 26 |
use Symfony\Component\HttpFoundation\Request; |
26 | 27 |
use Symfony\Component\HttpFoundation\Response; |
28 |
+use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungLeseartModel; |
|
27 | 29 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungRebsorteModel; |
28 | 30 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungReservationModel; |
29 | 31 |
use vonRotenberg\WeinanlieferungBundle\Model\WeinanlieferungSlotsModel; |
... | ... |
@@ -59,8 +61,9 @@ class WeinanlieferungSlotsListModuleController extends AbstractFrontendModuleCon |
59 | 61 |
if (!empty($_GET['filter_sorte'])) |
60 | 62 |
{ |
61 | 63 |
$arrData['filter']['sorte']['selected'] = $_GET['filter_sorte']; |
62 |
- $arrOptions['column'][] = 'FIND_IN_SET(?,sorte)'; |
|
63 |
- $arrOptions['value'][] = $_GET['filter_sorte']; |
|
64 |
+// $arrOptions['column'][] = 'FIND_IN_SET(?,sorte)'; |
|
65 |
+ $arrOptions['column'][] = "REGEXP_LIKE(sorten,'\"sorte\";s:[0-9]+:\"" . intval($_GET['filter_sorte']) . "\"')"; |
|
66 |
+// $arrOptions['value'][] = $_GET['filter_sorte']; |
|
64 | 67 |
} |
65 | 68 |
$arrData['filter']['kapazitaet']['options'] = range(1,30); |
66 | 69 |
|
... | ... |
@@ -79,10 +82,17 @@ class WeinanlieferungSlotsListModuleController extends AbstractFrontendModuleCon |
79 | 82 |
$arrSorten = []; |
80 | 83 |
$intAvailableBehaelter = $slot->getAvailableBehaelter(); |
81 | 84 |
|
82 |
- if (($Sorten = $slot->getRelated('sorte')) !== null) |
|
85 |
+ $Sorten = StringUtil::deserialize($slot->sorten,true); |
|
86 |
+ foreach($Sorten as $sorte) |
|
83 | 87 |
{ |
84 |
- $arrSorten = $Sorten->fetchEach('title'); |
|
88 |
+ $objSorte = WeinanlieferungRebsorteModel::findByPk($sorte['sorte']); |
|
89 |
+ $objLeseart = WeinanlieferungLeseartModel::findByPk($sorte['leseart']); |
|
90 |
+ $arrSorten[] = ($objSorte !== null ? $objSorte->title : '') . ' ' . ($objLeseart !== null ? $objLeseart->title : ''); |
|
85 | 91 |
} |
92 |
+ /*if (($Sorten = $slot->getRelated('sorte')) !== null) |
|
93 |
+ { |
|
94 |
+ $arrSorten = $Sorten->fetchEach('title'); |
|
95 |
+ }*/ |
|
86 | 96 |
|
87 | 97 |
$arrData['days'][$day->dayBegin][] = array_merge($slot->row(),[ |
88 | 98 |
'sorte' => $arrSorten, |
89 | 99 |
new file mode 100644 |
... | ... |
@@ -0,0 +1,24 @@ |
1 |
+<?php |
|
2 |
+ |
|
3 |
+declare(strict_types=1); |
|
4 |
+ |
|
5 |
+/* |
|
6 |
+ * This file is part of contao-weinanlieferung-bundle. |
|
7 |
+ * |
|
8 |
+ * (c) vonRotenberg |
|
9 |
+ * |
|
10 |
+ * @license commercial |
|
11 |
+ */ |
|
12 |
+ |
|
13 |
+namespace vonRotenberg\WeinanlieferungBundle\Model; |
|
14 |
+ |
|
15 |
+use Contao\Model; |
|
16 |
+ |
|
17 |
+class WeinanlieferungLeseartModel extends Model |
|
18 |
+{ |
|
19 |
+ /** |
|
20 |
+ * Table name |
|
21 |
+ * @var string |
|
22 |
+ */ |
|
23 |
+ protected static $strTable = 'tl_vr_wa_leseart'; |
|
24 |
+} |