The following has evaluated to null or missing:
==> categoryResponse[0] [in template "62757443695457#32456#108258" at line 10, column 27]
----
Tip: It's the final [] step that caused this error, not those before it.
----
Tip: If the failing expression is known to legally refer to something that's sometimes null or missing, either specify a default value like myOptionalVar!myDefault, or use <#if myOptionalVar??>when-present<#else>when-missing</#if>. (These only cover the last step of the expression; to cover the whole expression, use parenthesis: (myOptionalVar.foo)!myDefault, (myOptionalVar.foo)??
----
----
FTL stack trace ("~" means nesting-related):
- Failed at: #assign categoryId = categoryResponse... [in template "62757443695457#32456#108258" at line 10, column 5]
----
1<#assign contents = []>
2<#assign categoryName = "">
3<#assign peti = "/headless-delivery/v1.0/sites/" + groupId + "/content-structures?filter=name eq 'Hotel Card'"/>
4<#assign structures = restClient.get("/headless-delivery/v1.0/sites/" + groupId + "/content-structures?filter=name eq 'Hotel Card'").items/>
5<#if (structures?size > 0)>
6 <#assign categoryName = (shortName.getData()!"")>
7 <#assign vocabularyResponse = restClient.get("/headless-admin-taxonomy/v1.0/sites/" + groupId + "/taxonomy-vocabularies?filter=name eq 'Destinations'").items>
8 <#assign vocabularyId = vocabularyResponse[0].id>
9 <#assign categoryResponse = restClient.get("/headless-admin-taxonomy/v1.0/taxonomy-vocabularies/" + vocabularyId + "/taxonomy-categories?filter=name eq '" + categoryName + "'").items>
10 <#assign categoryId = categoryResponse[0].id>
11
12 <#assign response = restClient.get("/headless-delivery/v1.0/content-structures/" + structures[0].id + "/structured-contents?filter=taxonomyCategoryIds/any(t:t eq " + categoryId + ")&pageSize=100")>
13 <#assign contents = response.items>
14</#if>
15<#if (contents?size >0)>
16 <section class="mp-max-width-section">
17 <div class="our-accomodations__wrapper">
18 <h2 class="mp-title-section mp-text-center">
19 <#if containsCircuits?? && getterUtil.getBoolean(containsCircuits.getData())>
20 Información adicional y alojamientos en ${categoryName?lower_case?cap_first}
21 <#else>
22 Nuestros alojamientos en ${categoryName?lower_case?cap_first}
23 </#if>
24
25 </h2>
26 <div class="swiper">
27 <ul class="cards-list__wrapper swiper-wrapper" aria-label="Carousel">
28 <#list contents as content>
29
30 <li class="swiper-slide">
31 <a href="/viajes/${content.friendlyUrlPath}">
32 <div class="card-2__wrapper card-2__wrapper--resume">
33 <div class="image-container">
34 <#assign imageField = getFieldByName(content.contentFields, "images")>
35 <#if imageField?has_content && imageField.contentFieldValue.image?has_content>
36 <img src="${imageField.contentFieldValue.image.contentUrl}"
37 alt="${imageField.contentFieldValue.image.description}"
38 loading="lazy">
39 </#if>
40 </div>
41 <div class="data__wrapper">
42 <#assign nameField = getFieldByName(content.contentFields, "name")>
43 <#if nameField?has_content>
44 <h3>${nameField.contentFieldValue.data}</h3>
45 </#if>
46 <#assign categoryField = getFieldByName(content.contentFields, "category")>
47 <#if categoryField?has_content>
48 <#assign category = categoryField.contentFieldValue.data>
49 <#attempt>
50 <#assign stars = category?split("*")[0]?number>
51 <#recover>
52 <#assign stars = 0>
53 </#recover>
54 <#if (stars > 0)>
55 <ul class="stars__wrapper" role="img" aria-label="Rating: ${stars} de 5 estrellas">
56 <#list 1..stars as i>
57 <li aria-hidden="true">
58 <svg width="16" height="16" viewBox="0 0 16 16" data-icon="star">
59 <symbol id="ai:local:star">
60 <path fill="currentColor" d="m8 12.689-3.89 2.346a.72.72 0 0 1-.436.107.79.79 0 0 1-.396-.147.84.84 0 0 1-.273-.332.648.648 0 0 1-.03-.453l1.032-4.417L.573 6.82a.737.737 0 0 1-.245-.388.702.702 0 0 1 .027-.428.845.845 0 0 1 .233-.34.807.807 0 0 1 .416-.171l4.532-.396L7.296.925a.68.68 0 0 1 .291-.344.819.819 0 0 1 .825 0 .68.68 0 0 1 .291.344l1.76 4.172 4.533.396a.807.807 0 0 1 .415.172.846.846 0 0 1 .233.34.703.703 0 0 1 .028.427.737.737 0 0 1-.245.388l-3.435 2.973 1.033 4.417a.648.648 0 0 1-.031.453.839.839 0 0 1-.273.332.79.79 0 0 1-.396.147.72.72 0 0 1-.435-.107L8 12.689Z"></path>
61 </symbol>
62 <use xlink:href="#ai:local:star"></use>
63 </svg>
64 </li>
65 </#list>
66 </ul>
67 </#if>
68 </#if>
69 <div class="info__description">
70 <svg width="24" height="24" viewBox="0 0 12 20" data-icon="distance">
71 <symbol id="ai:local:distance">
72 <path fill="currentColor"
73 d="M6.441 19.5c-1.612 0-2.932-.231-3.96-.693C1.456 18.345.942 17.742.942 17c0-.391.168-.749.504-1.073.336-.324.8-.605 1.394-.842l.287.957c-.347.148-.619.303-.813.467-.195.163-.315.327-.36.491.114.446.598.808 1.452 1.085.854.276 1.866.415 3.036.415 1.158 0 2.168-.139 3.03-.415.862-.277 1.35-.639 1.465-1.085-.045-.164-.165-.325-.36-.482a3.956 3.956 0 0 0-.813-.476l.305-.957c.594.237 1.055.518 1.382.842.328.324.491.682.491 1.073 0 .742-.513 1.345-1.54 1.807-1.027.462-2.347.693-3.96.693Zm0-5.137c.3-.588.656-1.188 1.066-1.8.41-.613.831-1.198 1.263-1.755.643-.839 1.157-1.601 1.543-2.288.385-.686.578-1.543.578-2.57 0-1.228-.434-2.277-1.303-3.146C8.718 1.934 7.67 1.5 6.44 1.5c-1.228 0-2.277.435-3.146 1.304-.869.87-1.304 1.918-1.304 3.146 0 1.027.197 1.884.589 2.57a22.38 22.38 0 0 0 1.533 2.288c.432.557.853 1.142 1.263 1.755.41.612.765 1.212 1.065 1.8Zm0 1.522a.603.603 0 0 1-.403-.163 1.077 1.077 0 0 1-.287-.399c-.435-1.055-.924-1.94-1.47-2.658l-1.565-2.06a12.42 12.42 0 0 1-1.224-2.043c-.334-.707-.5-1.577-.5-2.612 0-1.526.526-2.815 1.58-3.87C3.626 1.028 4.916.5 6.442.5c1.525 0 2.815.527 3.869 1.58 1.053 1.055 1.58 2.344 1.58 3.87 0 1.035-.162 1.905-.488 2.612a10.973 10.973 0 0 1-1.237 2.044c-.482.656-1 1.343-1.552 2.06-.554.716-1.048 1.602-1.482 2.657a1.09 1.09 0 0 1-.287.4.603.603 0 0 1-.404.162Zm0-8.406c.43 0 .792-.148 1.087-.442.295-.295.442-.658.442-1.087 0-.43-.147-.792-.442-1.087a1.477 1.477 0 0 0-1.087-.442c-.43 0-.791.148-1.086.442a1.477 1.477 0 0 0-.442 1.087c0 .43.147.792.442 1.087a1.48 1.48 0 0 0 1.086.442Z"></path>
74 </symbol>
75 <use xlink:href="#ai:local:distance"></use>
76 </svg>
77 <#assign streetField = getFieldByName(content.contentFields, "street")>
78 <#if streetField?has_content>
79 <p>${streetField.contentFieldValue.data}</p>
80 </#if>
81 </div>
82 <#assign codeField = getFieldByName(content.contentFields, "code")>
83 <#assign dataHotel = "">
84 <#if codeField?has_content>
85 <#assign dataHotel = "data-hotel='" + codeField.contentFieldValue.data + "'">
86 <div class="data__wrapper__footer d-none">
87 <p class="data__wrapper__footer__price">
88 <span class="price-line">
89 Desde
90 <span ${dataHotel} class="price"></span>
91 </span>
92 <span class="extra-fees">por persona</span>
93 </p>
94 </div>
95 </#if>
96 </div>
97 </div>
98 </a>
99 <li>
100 </#list>
101 </ul>
102 </div>
103 </div>
104 </section>
105</#if>
106
107<#function getFieldByName contentFields, name>
108 <#list contentFields as field>
109 <#if field.name == name>
110 <#return field>
111 </#if>
112 </#list>
113 <#return "">
114</#function>
115
116<script>
117 new Swiper(".our-accomodations__wrapper .swiper", {
118 direction: 'horizontal',
119 spaceBetween: 0,
120 slidesPerView: 'auto',
121 centeredSlides: true,
122 breakpoints: {
123 768: {
124 allowTouchMove: false,
125 }
126 },
127 navigation: {
128 nextEl: '.swiper-button-next',
129 prevEl: '.swiper-button-prev',
130 },
131 pagination: {
132 el: '.swiper-pagination',
133 },
134 keyboard: {
135 enabled: true,
136 onlyInViewport: true,
137 },
138 });
139
140 async function fetchLiferayDocument(url) {
141 return fetchLiferayApi("documents/d/guest/" + url);
142 }
143
144 function numberWithCommas (x){
145
146 return x.toFixed(Number.isInteger(x) ? 0 : 2).toString().replace(".", ",").replace(/\B(?=(\d{3})+(?!\d))/g, ".");
147 }
148
149 async function loadHotelsPrice() {
150 const hotelsResult = await fetchLiferayDocument("hotels");
151 const hotelsJson = await hotelsResult.json();
152
153 const hotelElements = document.querySelectorAll("span[data-hotel]");
154 hotelElements.forEach(hotelElement => {
155 const hotelCode = hotelElement.dataset.hotel;
156 const hotel = hotelsJson.find(hotel => hotel.code === +hotelCode);
157 if (!!hotel && !!hotel.bestPrice) {
158 hotelElement.innerText = numberWithCommas(hotel.bestPrice) + "€";
159
160 const parent = hotelElement.closest(".data__wrapper__footer");
161 parent.classList.remove("d-none");
162 }
163 })
164 }
165
166 loadHotelsPrice();
167</script>
Conoce Baviera En Navidad
Un viaje entre mercadillos navideños, ciudades históricas y paisajes de ensueño.
Descubre la magia del Adviento en Baviera con un recorrido pensado para disfrutar de algunos de los mercadillos navideños más famosos de Alemania, ciudades llenas de historia y paisajes alpinos de cuento. Este viaje combina la elegancia de Múnich, el encanto medieval de Núremberg y la visita al espectacular Castillo de Neuschwanstein, uno de los iconos más reconocibles de Europa.
Un itinerario diseñado para viajeros que desean vivir la Navidad europea con comodidad, disfrutando de tradiciones, gastronomía bávara y tiempo libre para pasear entre luces, mercados y plazas históricas en un ambiente único.
INFORMACIÓN DE INTERÉS

DOCUMENTACIÓN
Los ciudadanos españoles precisan llevar el documento de identidad válido o pasaporte en vigor.
CAMBIO
La moneda oficial es el euro
VESTUARIO
Se recomienda llevar ropa de abrigo, sobre todo guantes, gorros, calcetines de invierno e incluso orejeras.
ELECTRICIDAD
El voltaje del suministro eléctrico normalizado es de 230 voltios.
REFERENCIA HORARIA
Se aplica la hora Central de Europa (CET), misma que en España.
TELÉFONO
Código de acceso desde España: (+49)
Código de acceso desde Alemania: (+34)