Um erro ocorreu enquanto processava o modelo.
The following has evaluated to null or missing: ==> cardData [in template "20099#20135#10700480" at line 1373, column 69] ---- 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: ${cardData.media.videoYotubeID} [in template "20099#20135#10700480" in macro "renderNewsFeaturedMedia" at line 1373, column 67] - Reached through: @renderNewsFeaturedMedia newsInfo [in template "20099#20135#10700480" at line 471, column 21] ----
1<#-- Conteúdo Web -> Templates: Site de Crise - Include de templates-->
2<#-- include "${templatesPath}/1975602" -->
3
4<#-- Conteúdo Web -> Templates: Site de Crise - Funções gerais-->
5<#include "${templatesPath}/1975398" />
6
7<#-- Conteúdo Web -> Templates: Busca pelas imagens do tipo de noticia -->
8<#include "${templatesPath}/18598756" />
9
10<#assign POST_TYPES_CATEGORIES = getPostTypeImages()!default([]) />
11
12<#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Extrair dados de Notícias -->
13<#--include "${templatesPath}/7762031" -->
14
15<#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Título -->
16<#-- include "${templatesPath}/7761976" -->
17
18<#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Redes sociais e data de publicação -->
19<#--include "${templatesPath}/7762069" -->
20
21<#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Áudios do conteúdo da notícia -->
22<#-- include "${templatesPath}/7761972" -->
23<#function getNodesByLabel fieldList parentNode label>
24 <#assign result = []/>
25 <#attempt>
26 <#assign groupId = getIdFromFieldName(fieldList, label) />
27 <#assign xSeletorCaminho = saxReaderUtil.createXPath("dynamic-element[@name='${groupId}' ]") />
28 <#assign result = xSeletorCaminho.selectNodes(parentNode) />
29 <#return result />
30 <#recover>
31 <#return result />
32 </#attempt>
33</#function>
34
35<#function findVocabulary vocabularyName vocabularies>
36 <#assign vocabularyNameLowerCase = vocabularyName?lower_case>
37 <#list vocabularies as vocabulary>
38 <#if vocabulary.name?lower_case == vocabularyNameLowerCase>
39 <#return vocabulary>
40 </#if>
41 </#list>
42 <#return {}>
43</#function>
44
45<#-- ############# Conteúdo Web -> Templates: Site de Crise - Include de templates #################################### -->
46<#function getSiteUrl>
47 <#assign portalUtil = staticUtil["com.liferay.portal.kernel.util.PortalUtil"]>
48 <#if layout?? && layout?has_content>
49 <#return portalUtil.getLayoutFriendlyURL(layout, themeDisplay)?replace(layout.getFriendlyURL(), "")>
50 </#if>
51 <#return portalUtil.getLayoutFriendlyURL(layout, themeDisplay)>
52</#function>
53
54<#function getSiteName>
55 <#return layout.getGroup().getDescriptiveName(locale)>
56</#function>
57
58<#function mountUrlToPage targetPage>
59 <#assign baseUrl = getSiteUrl()>
60 <#assign trimmedUrl = baseUrl?replace("/w/", "/")>
61 <#assign trimmedUrl = trimmedUrl?substring(0, trimmedUrl?last_index_of("/"))>
62 <#return trimmedUrl + "/" + targetPage>
63</#function>
64<#-- ################################################################################################################## -->
65
66
67<#assign
68 journalArticleLocalService = serviceLocator.findService("com.liferay.journal.service.JournalArticleLocalService")
69 assetVocabularyService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetVocabularyLocalService")
70 assetCategoryLocalService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetCategoryLocalService")
71 vocabularies = assetVocabularyService.getGroupVocabularies(groupId)
72 tagsLocalService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetTagLocalService")
73 tagVocabulary = findVocabulary("Tag", vocabularies)
74 flagVocabulary = findVocabulary("Flag", vocabularies)
75 tagCategoryTitles = extractVocabularyTitles(tagVocabulary)
76 flagCategoryTitles = extractVocabularyTitles(flagVocabulary)
77 assetEntryLocalService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetEntryLocalService")
78 fileEntryService = staticUtil["com.liferay.document.library.kernel.service.DLFileEntryLocalServiceUtil"]
79 layoutLocalService = serviceLocator.findService("com.liferay.portal.kernel.service.LayoutLocalService")
80 PortalUtil = staticUtil["com.liferay.portal.kernel.util.PortalUtil"]
81 AssetEntryQueryService = objectUtil("com.liferay.asset.kernel.service.AssetEntryLocalServiceUtil").getService()
82 AssetEntryQuery = objectUtil('com.liferay.asset.kernel.service.persistence.AssetEntryQuery')
83/>
84
85<#-- Nome das midias adaptativas de imagem para desktop e mobile -->
86<#assign adaptativeMediaDesktopResolutionName = "Preview-1000x0" />
87<#assign adaptativeMediaMobileResolutionName = "Thumbnail-300x300" />
88
89<#assign typeOfNewsVocabulary = findVocabulary("Tipo de Notícia", vocabularies)/>
90<#assign ourEnergyVocabulary = findVocabulary("Nossa Energia", vocabularies)/>
91
92<#assign newsJournalArticle = "">
93<#assign assetEntry = getAssetEntryFromRequest(assetEntryLocalService)>
94<#if assetEntry?? && assetEntry?has_content>
95 <#assign newsJournalArticle = journalArticleLocalService.fetchLatestArticle(assetEntry.classPK)/>
96</#if>
97
98<#function getSingleNode name root>
99 <#attempt>
100 <#assign xPathSelector = saxReaderUtil.createXPath("dynamic-element[@name='${name}']/dynamic-content[@language-id='${locale}']") />
101 <#return xPathSelector.selectSingleNode( root ) />
102 <#recover>
103 <#assign xPathSelector = saxReaderUtil.createXPath("dynamic-element[@name='${name}']") />
104 <#return xPathSelector.selectSingleNode( root ) />
105 </#attempt>
106</#function>
107
108<#-- Função para obter a primeira categoria associonada a um Vocabulário o qual está associado a um Jornal Article -->
109<#function getFirstCategoryOfVocabulary journalArticle vocabulary >
110 <#attempt>
111 <#assign categories = assetCategoryLocalService.getCategories("com.liferay.journal.model.JournalArticle", journalArticle.getClassPK()) />
112 <#list categories as category>
113 <#if vocabulary.getVocabularyId() == category.getVocabularyId()>
114 <#return category.getName()>
115 </#if>
116 </#list>
117 <#return "">
118
119 <#recover>
120 <#return "" />
121 </#attempt>
122</#function>
123
124<#function getFirstCategoryObjectOfVocabulary journalArticle vocabulary >
125 <#attempt>
126 <#assign categories = assetCategoryLocalService.getCategories("com.liferay.journal.model.JournalArticle", journalArticle.getClassPK()) />
127 <#list categories as category>
128 <#if vocabulary.getVocabularyId() == category.getVocabularyId()>
129 <#return category>
130 </#if>
131 </#list>
132 <#return "">
133
134 <#recover>
135 <#return "" />
136 </#attempt>
137</#function>
138
139<#-- Função para obter todas os ids das categorias associonadas a um Vocabulário o qual está associado a um Jornal Article -->
140<#function getAllCategoryIdOfVocabulary journalArticle vocabulary >
141 <#attempt>
142 <#assign categoriesIds = [] />
143 <#assign categories = assetCategoryLocalService.getCategories("com.liferay.journal.model.JournalArticle", journalArticle.getClassPK()) />
144 <#list categories as category>
145 <#if vocabulary.getVocabularyId() == category.getVocabularyId()>
146 <#assign categoriesIds = categoriesIds + [category.getCategoryId()] />
147 </#if>
148 </#list>
149 <#return categoriesIds>
150
151 <#recover>
152 <#return [] />
153 </#attempt>
154</#function>
155
156<#if newsJournalArticle?? && newsJournalArticle?has_content>
157
158 <div class="breadcrumb-breakpoint breakpoint">
159 <div class="breadcrumb-col col-2-11 md-col-1-8 sm-col-1-4">
160 <#assign homeURL = "/" />
161
162 <#if currentURL?contains('webserver')>
163 <#assign homeURL = "/web/nossa-energia" />
164 </#if>
165
166 <a href="${homeURL}" class="breadcrumb-page text previous-page paragraph-micro-regular" tabindex="0">
167 <span class="breadcrumb-text-truncate" original-text="Home">Home</span>
168 <div class="icon"></div>
169 </a>
170
171 <#assign currentUrl = getSiteUrl()>
172
173 <#assign lastIndex = currentUrl?last_index_of("/")>
174 <#assign urlWithoutLastSegment = currentUrl?substring(0, lastIndex+1)>
175 <#assign urlWithoutW = urlWithoutLastSegment?replace("/w/", "/")>
176
177 <#assign breadcrumbOurEnergyCategory = getFirstCategoryObjectOfVocabulary(assetEntry, ourEnergyVocabulary) />
178 <#assign categoryURL = urlWithoutW/>
179 <a href="${categoryURL}" class="breadcrumb-page text previous-page paragraph-micro-regular" tabindex="0">
180 <span class="breadcrumb-text-truncate" original-text="${breadcrumbOurEnergyCategory.getTitle(locale)}">${breadcrumbOurEnergyCategory.getTitle(locale)}</span>
181 <div class="icon"></div>
182 </a>
183
184 <span original-text="${newsJournalArticle.getTitle(locale)}" class="breadcrumb-page text active-page active paragraph-micro-bold">${newsJournalArticle.getTitle(locale)}</span>
185 </div>
186 </div>
187
188 <div class="ptb-news__read-news">
189 <div class="ptb-news__read-news-post ">
190 <div class="ptb-news__read-content">
191
192 <#assign
193 ddmStructure = newsJournalArticle.getDDMStructure()
194 fieldList = getFieldListByStructure(ddmStructure)
195 xmlArticle = newsJournalArticle.getDocument().getRootElement()
196 >
197
198 <#assign
199 <#-- Título principal da notícia -->
200 mainHeadlineOfTheNews = newsJournalArticle.getTitle(locale, true)
201 <#-- Título de destaque da notícia -->
202 featuredNewsHeadline = extractFeaturedNewsHeadline(fieldList, xmlArticle)
203 <#-- Sumário da notícia -->
204 newsSummary = extractNewsSummary(fieldList, xmlArticle)
205 <#-- Data de publicação da notícia -->
206 lastPublishDate = extractPublishDate(newsJournalArticle)
207 <#-- Data de criação da notícia -->
208 createDate = newsJournalArticle.getCreateDate()
209 >
210
211 <#-- Flag da notícia ---------------------------------------------------------------------------------->
212 <#assign flag = getFirstCategoryTitle(newsJournalArticle, flagCategoryTitles, assetCategoryLocalService)>
213
214 <#-- Url amigável da notícia para visualização em DisplayPage ----------------------------------------->
215 <#assign newsJournalArticleFriendlyUrl = themeDisplay.getPortalURL() + themeDisplay.getPathFriendlyURLPublic() + layout.getGroup().friendlyURL + "/w/" + newsJournalArticle.getUrlTitle()>
216
217 <#-- Conteúdo da notícia ------------------------------------------------------------------------------>
218 <#assign newsContent = getFieldValue(fieldList, xmlArticle, "Corpo da notícia")>
219
220 <#assign WEB_STORIES_FIELD_SET_FIELD_REF = "Fieldset91054335" />
221 <#assign WEB_STORIES_IDENTIFICATION_FIELD_LABEL = "Identificador do Carousel" />
222 <#assign WEB_STORIES_TITLE_FIELD_LABEL = "Título do carrossel" />
223
224 <#assign webStoriesCarouselsIds = [] />
225 <#assign webStoriesCarouselsTitles = [] />
226 <#assign webStoriesCarouselsIdsFieldSetList = getNodes(WEB_STORIES_FIELD_SET_FIELD_REF, xmlArticle) />
227
228 <#list webStoriesCarouselsIdsFieldSetList as webStoriesFieldSet>
229 <#assign webStoriesCarouselsIds = webStoriesCarouselsIds + [ getFieldValue(fieldList, webStoriesFieldSet, WEB_STORIES_IDENTIFICATION_FIELD_LABEL) ] />
230 <#assign webStoriesCarouselsTitles = webStoriesCarouselsTitles + [ getFieldValue(fieldList, webStoriesFieldSet, WEB_STORIES_TITLE_FIELD_LABEL) ] />
231 </#list>
232
233 <#assign wsCarouselContent = '
234 <div id="[CAROUSEL_ID]" class="ws-carousel">
235 <div class="ws-carousel-header">
236 <h1 class="h2">
237 [CAROUSEL_TITLE]
238 </h1>
239 <div class="nav-buttons">
240 <svg class="nav-arrow left-arrow inactive" width="33" height="33" viewBox="0 0 33 33" fill="none" xmlns="http://www.w3.org/2000/svg">
241 <path d="M1 16C1 7.16344 8.16344 0 17 0C25.8366 0 33 7.16344 33 16C33 24.8366 25.8366 32 17 32C8.16344 32 1 24.8366 1 16Z" stroke="#bababa"/>
242 <path d="M11.5 16H22.5M22.5 16L18 11.5M22.5 16L18 20.5" stroke="#bababa" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
243 </svg>
244 <svg class="nav-arrow right-arrow active" width="33" height="33" viewBox="0 0 33 33" fill="none" xmlns="http://www.w3.org/2000/svg">
245 <path d="M1 16C1 7.16344 8.16344 0 17 0C25.8366 0 33 7.16344 33 16C33 24.8366 25.8366 32 17 32C8.16344 32 1 24.8366 1 16Z" stroke="#008542"/>
246 <path d="M11.5 16H22.5M22.5 16L18 11.5M22.5 16L18 20.5" stroke="#008542" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
247 </svg>
248 </div>
249 </div>
250 <div class="ws-carousel-body">
251 <div class="ws-container">
252 </div>
253 </div>
254 </div>' />
255
256 <#list webStoriesCarouselsIds as item >
257 <#assign carouselDiv = wsCarouselContent?replace("[CAROUSEL_ID]", item)?replace("[CAROUSEL_TITLE]", webStoriesCarouselsTitles[item?index]) />
258 <#assign newsContent = newsContent?replace("<p>#[${item}]</p>", carouselDiv) />
259 </#list>
260
261
262 <#assign WEB_STORIES_FIELD_SET_FIELD_REF = "Fieldset91054335" />
263 <#assign WEB_STORIES_IDENTIFICATION_FIELD_LABEL = "Identificador do Carousel" />
264 <#assign WEB_STORIES_TITLE_FIELD_LABEL = "Título do carrossel" />
265
266 <#assign webStoriesCarouselsIds = [] />
267 <#assign webStoriesCarouselsTitles = [] />
268 <#assign webStoriesCarouselsIdsFieldSetList = getNodes(WEB_STORIES_FIELD_SET_FIELD_REF, xmlArticle) />
269
270 <#list webStoriesCarouselsIdsFieldSetList as webStoriesFieldSet>
271 <#assign webStoriesCarouselsIds = webStoriesCarouselsIds + [ getFieldValue(fieldList, webStoriesFieldSet, WEB_STORIES_IDENTIFICATION_FIELD_LABEL) ] />
272 <#assign webStoriesCarouselsTitles = webStoriesCarouselsTitles + [ getFieldValue(fieldList, webStoriesFieldSet, WEB_STORIES_TITLE_FIELD_LABEL) ] />
273 </#list>
274
275 <#assign wsCarouselContent = '
276 <div id="[CAROUSEL_ID]" class="ws-carousel">
277 <div class="ws-carousel-header">
278 <h1 class="h2">
279 [CAROUSEL_TITLE]
280 </h1>
281 <div class="nav-buttons">
282 <svg class="nav-arrow left-arrow inactive" width="33" height="33" viewBox="0 0 33 33" fill="none" xmlns="http://www.w3.org/2000/svg">
283 <path d="M1 16C1 7.16344 8.16344 0 17 0C25.8366 0 33 7.16344 33 16C33 24.8366 25.8366 32 17 32C8.16344 32 1 24.8366 1 16Z" stroke="#bababa"/>
284 <path d="M11.5 16H22.5M22.5 16L18 11.5M22.5 16L18 20.5" stroke="#bababa" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
285 </svg>
286 <svg class="nav-arrow right-arrow active" width="33" height="33" viewBox="0 0 33 33" fill="none" xmlns="http://www.w3.org/2000/svg">
287 <path d="M1 16C1 7.16344 8.16344 0 17 0C25.8366 0 33 7.16344 33 16C33 24.8366 25.8366 32 17 32C8.16344 32 1 24.8366 1 16Z" stroke="#008542"/>
288 <path d="M11.5 16H22.5M22.5 16L18 11.5M22.5 16L18 20.5" stroke="#008542" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
289 </svg>
290 </div>
291 </div>
292 <div class="ws-carousel-body">
293 <div class="ws-container">
294 </div>
295 </div>
296 </div>' />
297
298 <#list webStoriesCarouselsIds as item >
299 <#assign carouselDiv = wsCarouselContent?replace("[CAROUSEL_ID]", item)?replace("[CAROUSEL_TITLE]", webStoriesCarouselsTitles[item?index]) />
300 <#assign newsContent = newsContent?replace("<p>#[${item}]</p>", carouselDiv) />
301 </#list>
302
303
304 <#-- Seção do áudio para o conteúdo da notícia -------------------------------------------------------->
305 <#assign audios = []
306 audioIdentifierFieldSetList = getNodes("Fieldset65862311", xmlArticle)
307 >
308 <#list audioIdentifierFieldSetList as audioIdentifierFieldSet>
309 <#assign
310 <#-- Grupo com as informações de url e legenda do áudio -->
311 audioInfoFieldSet = getGroupNode("Fieldset24035689",audioIdentifierFieldSet)>
312 <#assign
313 externalAudioUrl = getFieldValue(fieldList, audioInfoFieldSet, "URL externa do áudio")
314 internalAudioUrl = getFileFromXML("DocumentLibrary24170668", audioInfoFieldSet, fileEntryService)
315 audioLegend = getFieldValue(fieldList, audioInfoFieldSet, "Legenda do áudio")>
316
317 <#if externalAudioUrl?has_content || internalAudioUrl.url?has_content >
318 <#assign audios += [{
319 "id": getFieldValue(fieldList, audioIdentifierFieldSet, "Identificador de Áudio"),
320 "externalUrl" : externalAudioUrl,
321 "internalUrl" : internalAudioUrl,
322 "legend" : audioLegend
323 }]>
324 </#if>
325 </#list>
326
327
328 <#-- Seção de vídeo para o conteúdo da notícia -------------------------------------------------------->
329 <#assign videos = []
330 videoIdentifierFieldSetList = getNodes("Fieldset24460782", xmlArticle)
331 >
332 <#list videoIdentifierFieldSetList as videoIdentifierFieldSet>
333 <#assign
334 <#-- Grupo com as informações de url e legenda do áudio -->
335 videoInfoFieldSet = getGroupNode("Fieldset51040010",videoIdentifierFieldSet)
336
337 videos += [{
338 "id": getFieldValue(fieldList,videoIdentifierFieldSet, "Identificador de Vídeo"),
339 "youtubeID" : getFieldValue(fieldList, videoInfoFieldSet, "ID do vídeo do YouTube"),
340 "internalUrl" : getFileFromXML("DocumentLibrary15265409", videoInfoFieldSet, fileEntryService),
341 "legend" : getFieldValue(fieldList, videoInfoFieldSet, "Legenda do vídeo")
342 }]
343 >
344 </#list>
345
346
347 <#-- Seção de links para o conteúdo da notícia -------------------------------------------------------->
348 <#assign
349 links = []
350 linksFieldSetList = getNodes("Fieldset37770113", xmlArticle)
351 >
352 <#list linksFieldSetList as linksFieldSet>
353 <#assign linkFieldSetList = getNodes("Fieldset10524367", linksFieldSet)>
354
355 <#list linkFieldSetList as linkFieldSet>
356 <#assign
357 linkId = getFieldValue(fieldList, linkFieldSet, "Identificador do link")
358
359 <#-- Grupo com as informações de url e legenda do áudio -->
360 linkInfoFieldSeet = getGroupNode("Fieldset86037074", linkFieldSet)
361
362 iconType = getFieldValue(fieldList, linkInfoFieldSeet, "Ícone do link")
363 links += [{
364 "id": linkId,
365 "externalLink" : getFieldValue(fieldList, linkInfoFieldSeet, "Link externo"),
366 "pageLink" : getPageLayoutLinkFromXML("LinkToLayout77941175", linkInfoFieldSeet, layoutLocalService),
367 "file" : getFileFromXML("DocumentLibrary34820760", linkInfoFieldSeet, fileEntryService),
368 "title" : getFieldValue(fieldList, linkInfoFieldSeet, "Título do link"),
369 "iconType" : iconType
370 }]
371 >
372 </#list>
373 </#list>
374
375
376
377 <#assign galleryItems = []/>
378
379 <#assign mediaGroupList = getNodes(getIdFromFieldName(fieldList, "Galeria de multimídia"), xmlArticle) />
380
381 <#list mediaGroupList as mediaGroup >
382 <#assign nodes = getNodes(getIdFromFieldName(fieldList, "Imagem da Galeria") , mediaGroup) />
383 <#list nodes as node>
384 <#assign image = getMediaInfo(fieldList, node, "Imagem", fileEntryService) />
385 <#if image?? && image?has_content && image.url?has_content>
386 <#assign galleryItems += [{"image": image}] />
387 </#if>
388 </#list>
389 </#list>
390
391 <#-- Seção de Quotes para o conteúdo da notícia -------------------------------------------------------->
392 <#-- Seção de Quotes para o conteúdo da notícia -------------------------------------------------------->
393 <#assign quotes = [] />
394 <#assign quotesRootFieldSetList = getNodes(getIdFromFieldName(fieldList, "Quotes da notícia"), xmlArticle) />
395 <#list quotesRootFieldSetList as quotesFieldSetList>
396 <#assign quoteFieldSetList = getNodes(getIdFromFieldName(fieldList, "Quote"), quotesFieldSetList) />
397 <#list quoteFieldSetList as quoteFieldSet>
398 <#assign imageJsonString = getSingleNodeString("Image94530628", quoteFieldSet) />
399 <#assign imageJson = {"url": "", "alt": "", "fileEntryId" : "", "title" : ""} />
400 <#attempt>
401 <#if imageJsonString ?? && imageJsonString?has_content>
402 <#assign imageJson = jsonFactoryUtil.createJSONObject(imageJsonString) />
403 </#if>
404
405 <#if !imageJson.url?? || !imageJson.url?has_content>
406 <#assign imageJson = {"url": "", "alt": "", "fileEntryId" : "", "title" : ""} />
407 </#if>
408 <#recover>
409 </#attempt>
410
411 <#if !imageJson.url?? || !imageJson.url?has_content>
412 <#assign imageJson = {"url": "", "alt": "", "fileEntryId" : "", "title" : ""} />
413 </#if>
414
415 <#assign quotes += [{
416 "id": getFieldValue(fieldList, quoteFieldSet, "Identificador do Quote"),
417 "content" : getFieldValue(fieldList, quoteFieldSet, "Texto do Quote"),
418 "author" : getFieldValue(fieldList, quoteFieldSet, "Nome do autor"),
419 "image" : {"url": imageJson.url, "alt": imageJson.alt, "fileEntryId" : imageJson.fileEntryId, "title" : imageJson.title}
420 }] />
421 </#list>
422 </#list>
423
424 <#assign newsInfo = {
425 "mainHeadlineOfTheNews": mainHeadlineOfTheNews,
426 "featuredNewsHeadline" : featuredNewsHeadline,
427 "displayDate" : formatDate(createDate),
428 "createDate": createDate,
429 "newsSummary" : newsSummary,
430 "newsMedia": extractNewsMedia(fieldList, xmlArticle, fileEntryService),
431 "lastPublishDate": lastPublishDate,
432 "flag": flag,
433 "url": newsJournalArticleFriendlyUrl,
434 "newsContent": newsContent,
435 "audios": audios,
436 "videos": videos,
437 "galleryItems": galleryItems,
438 "links": links,
439 "quotes": quotes
440 }/>
441
442 <#-- Renderizar o título principal da notícia -->
443 <#-- Conteúdo-> Conteúdo Web -> Templates: Site de Crise - Notícia - Título -->
444 <@renderHeadLine newsInfo/>
445
446 <#-- Renderizar o resumo da notícia -->
447 <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Resumo -->
448 <@renderReview newsInfo/>
449
450 <#-- Renderizar a data de publicação/edição da notícia e redes sociais -->
451 <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Redes sociais e data de publicação -->
452 <@renderPublishAndSocialMediasInfos newsJournalArticle newsInfo/>
453
454 <#-- Renderizar as tags da notícia -->
455 <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Render Tags -->
456 <#assign categoriesAsssetEntryResponse = restClient.get("/headless-delivery/v1.0/structured-contents/${assetEntry.getClassPK()}?nestedFields=embeddedTaxonomyCategory&fields=taxonomyCategoryBriefs") />
457
458 <#if categoriesAsssetEntryResponse?? && categoriesAsssetEntryResponse?has_content && categoriesAsssetEntryResponse.taxonomyCategoryBriefs??>
459 <#assign tagCategoryList = getCategoriesNamesAndIds("Tags", categoriesAsssetEntryResponse.taxonomyCategoryBriefs) />
460 <#assign removeStartParameterWhenTagIsClicked = true />
461 <#assign includeRequestParams = false />
462 <#assign NEWS_PAGE_NAME= "categorias"/>
463 </#if>
464
465
466 <#-- Renderizar a imagem de destaque da notícia -->
467 <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Imagem de destaque -->
468 <#assign typeOfNews = getFirstCategoryOfVocabulary(assetEntry, typeOfNewsVocabulary) />
469
470 <#if !typeOfNews?? || !typeOfNews?has_content || typeOfNews != "Infográfico" >
471 <@renderNewsFeaturedMedia newsInfo />
472 </#if>
473
474 <#-- Renderizar o conteúdo da notícia -->
475 <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Conteúdo da notícia -->
476 <@renderNewsContent newsInfo/>
477
478 <#-- Renderizar o conteúdo da notícia-->
479 <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Conteúdo da notícia -->
480
481 <#-- Renderizar o conteúdo da notícia-->
482 <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Conteúdo da notícia -->
483
484 <#-- Renderiza botoes de compartilhamento na versao mobile -->
485 <div class="render-share-news-container publish_and_social_medias_infos_desk mobile">
486 <@renderShareAndCopyNews/>
487 </div>
488
489 <#-- Renderizar links da notícia -->
490 <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Links do conteúdo da notícia -->
491 <@renderLinks newsInfo />
492
493 <@renderCite />
494
495 <#-- Renderizar áudios da notícia -->
496 <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Áudios do conteúdo da notícia -->
497
498 <#-- Renderizar galeria de imagens notícia -->
499 <#-- Conteúdo Web -> Templates: Site de Crise - Notícia - Render galeria -->
500 <@renderGallery newsInfo />
501
502 <#-- Renderizar quotes da notícia -->
503 <@renderQuotes newsInfo />
504 </div>
505 </div>
506 </div>
507<#else >
508 <div class="ptb-news__read-news paragraph-sm-regular">
509 <p> <#if locale == "pt_BR"> Nenhuma notícia <#else> There are no news </#if></p>
510 </div>
511
512 <style>
513 .ptb-news__read-news p {
514 color: #515867;
515 }
516
517 body.high-contrast-active .ptb-news__read-news p {
518 color: var(--color-neutral-100);
519 }
520 </style>
521</#if>
522
523<style>
524 .breadcrumb-breakpoint {
525 padding-top: var(--space-xxl);
526 padding-bottom: var(--space-xl);
527 }
528
529 body.high-contrast-active .breadcrumb-breakpoint {
530 background: var(--background-surface-level-01, #010101);
531 }
532
533 .breadcrumb-breakpoint .breadcrumb-col {
534 display: flex;
535 width: max-content;
536 gap: var(--space-xxs);
537 height: fit-content;
538 overflow-x: hidden;
539 }
540
541 .breadcrumb-breakpoint #liferay-breadcrumb {
542 display: none;
543 }
544
545 .breadcrumb-breakpoint .breadcrumb-page {
546 display: flex;
547 gap: var(--space-micro);
548 height: var(--size-md);
549 size: var(--size-md);
550 border: 1px solid rgba(0, 0, 0, 0);
551 box-sizing: border-box;
552 border-radius: var(--border-radius-sm);
553 }
554
555 .breadcrumb-breakpoint a.breadcrumb-page.text span,
556 .breadcrumb-breakpoint span.breadcrumb-page.text {
557 white-space: nowrap;
558 }
559
560 .breadcrumb-breakpoint .breadcrumb-page a:focus {
561 outline: none;
562 }
563
564 .breadcrumb-breakpoint .breadcrumb-page.active-page {
565 color: var(--color-text-primary-default);
566 background-color: var(--color-background-default-level-02);
567 border-radius: var(--border-radius-sm);
568 }
569
570 body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page.active-page {
571 background: var(--background-surface-level-02, #373737);
572 color: var(--text-primary-default, #FFF);
573 }
574
575 .breadcrumb-breakpoint .breadcrumb-page.previous-page {
576 transition: 300ms ease-in-out;
577 }
578
579 .breadcrumb-breakpoint .breadcrumb-page.previous-page.text {
580 text-decoration: var(--text-decoration-none);
581 color: var(--color-text-primary-default);
582 text-transform: capitalize;
583 padding-left: var(--space-xxs);
584 padding-right: var(--space-xxs);
585 }
586
587 body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page.previous-page.text {
588 color: var(--text-primary-default, #FFF);
589 }
590
591 .breadcrumb-breakpoint .breadcrumb-page.active-page.text {
592 color: var(--color-text-primary-default);
593 text-decoration: var(--text-decoration-none);
594 background-color: var(--color-background-default-level-02);
595 text-transform: capitalize;
596 padding-left: var(--space-xxs);
597 padding-right: var(--space-xxs);
598 }
599
600 body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page.previous-page.text {
601 color: var(--text-primary-default, #FFF);
602 }
603
604 .breadcrumb-breakpoint .breadcrumb-page.previous-page:not(.three-dots):hover {
605 background-color: var(--color-background-default-level-01);
606 border-color: var(--border-color-dark);
607 border-radius: var(--border-radius-sm);
608 border: 1px solid;
609 transition: all 300ms ease-in-out;
610 }
611
612 body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page.previous-page:not(.three-dots):hover {
613 background-color: transparent;
614 }
615
616 .breadcrumb-breakpoint .breadcrumb-page:focus-visible {
617 margin: var(--space-micro);
618 border-radius: var(--space-micro);
619 outline: none;
620 border: 1px solid var(--color-primary-medium);
621 box-sizing: border-box;
622 transition: 300ms ease-in-out;
623 }
624
625 body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page:focus-visible {
626 border: 1px solid rgba(228, 247, 232, 1);
627 }
628
629 .breadcrumb-breakpoint .breadcrumb-page .icon {
630 width: var(--size-xxs);
631 height: var(--size-xxs);
632 border-color: var(--border-color-darkest);
633 background-image: url('data:image/svg+xml,%3Csvg width="12" height="12" viewBox="0 0 12 12" fill="none" xmlns="http://www.w3.org/2000/svg"%3E%3Cpath d="M4.5 2.25L8.25 6L4.5 9.75" stroke="%23525252" stroke-linecap="round" stroke-linejoin="round"%3E%3C/path%3E%3C/svg%3E');
634 background-size: cover;
635 margin-top: auto;
636 margin-bottom: auto;
637 }
638
639 body.high-contrast-active .breadcrumb-breakpoint .breadcrumb-page .icon {
640 background-image: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" viewBox="0 0 12 12" fill="none"><path d="M4.5 2.25L8.25 6L4.5 9.75" stroke="white" stroke-linecap="round" stroke-linejoin="round"/></svg>');
641 }
642
643 .ptb-news__read-news {
644 overflow: hidden;
645 }
646
647 body.high-contrast-active .ptb-news__read-news {
648 background: var(--background-surface-level-01, #010101);
649 }
650</style>
651
652
653<#-- ############# Site de Crise - Notícia - Redes sociais e data de publicação ####################################### -->
654<#--
655Add elements from the sidebar to define your template. Type "${" to use the
656autocomplete feature.
657-->
658
659<#macro renderHeadLine newsInfo>
660
661 <div class="main-headline-container breakpoint">
662 <div class="main-headline-container-col col-2-11 md-col-1-8 sm-col-1-4">
663 <h1 class="main-headline display-sm">${newsInfo.featuredNewsHeadline}</h1>
664 <div class="bar"></div>
665 </div>
666 </div>
667
668 <style>
669 .ptb-news__read-news .main-headline-container .main-headline-container-col {
670 display: flex;
671 flex-direction: column;
672 gap: var(--space-sm);
673 padding-bottom: var(--space-lg);
674 }
675
676 .ptb-news__read-news .main-headline-container .main-headline-container-col * {
677 margin: 0;
678 padding: 0;
679 }
680
681 .ptb-news__read-news .main-headline-container .main-headline {
682 font-family: var(--font-family-base);
683 color: var(--color-neutral-800);
684 }
685
686 body.high-contrast-active .ptb-news__read-news .main-headline-container .main-headline {
687 color: var(--text-primary-default, var(--color-neutral-100));
688 }
689
690 .ptb-news__read-news .main-headline-container .bar {
691 width: 32px;
692 height: var(--size-micro);
693 background: var(--color-secondary-medium);
694 }
695
696 body.high-contrast-active .ptb-news__read-news .main-headline-container .bar{
697 background: var(--text-secondary-accent, #FFEEB3);
698 }
699
700 @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) {
701 .ptb-news__read-news .main-headline-container .main-headline-container-col {
702 gap: var(--space-xs, 12px);
703 }
704 }
705 </style>
706</#macro>
707<#-- ################################################################################################################## -->
708
709<#-- ############# Site de Crise - Notícia - Redes sociais e data de publicação ####################################### -->
710<#macro renderReview newsInfo>
711 <#assign summaryCssRoot = "summary-container" />
712
713 <div class="${summaryCssRoot}-breakpoint breakpoint">
714 <div class="${summaryCssRoot} col-2-11 md-col-1-8 sm-col-1-4">
715 <p class="summary paragraph-lg-regular">
716 ${newsInfo.newsSummary}
717 </p>
718 </div>
719
720 </div>
721
722 <style>
723 .${summaryCssRoot} .summary {
724 padding-bottom: var(--space-lg);
725 }
726
727 .${summaryCssRoot} .summary,
728 .${summaryCssRoot} .summary * {
729 color: var(--color-neutral-800, #373737);
730 font-family: var(--font-family-base);
731 font-style: var(--font-style-italic);
732 margin: var(--space-none);
733 }
734
735 body.high-contrast-active .summary,
736 body.high-contrast-active .summary * {
737 color: var(--text-secondary-default, #F8F8F8);
738 }
739 </style>
740</#macro>
741<#-- ################################################################################################################## -->
742
743<#-- ############# Site de Crise - Notícia - Redes sociais e data de publicação ####################################### -->
744<#macro renderPublishAndSocialMediasInfos journalArticle newsInfo>
745
746 <div class="publish_and_social_medias_infos_desk-breakpoint breakpoint">
747 <div class="publish_and_social_medias_infos_desk col-2-11 md-col-1-8 sm-col-1-4">
748 <div class="publish_and_update_date">
749 <#assign lastPublishDate = journalArticle.getModifiedDate()>
750 <#assign createDate = journalArticle.getCreateDate()>
751 <#if journalArticle.getLastPublishDate()??>
752 <#assign lastPublishDate = journalArticle.getLastPublishDate()>
753 </#if>
754
755 <#if locale == "pt_BR">
756 <p class="updated">Atualizado em ${formatDate(lastPublishDate)}</p>
757 <p class="published">Postado em ${formatDate(createDate)}</p>
758 <#else >
759 <p class="updated">Updated on ${formatDate(lastPublishDate)}</p>
760 <p class="published">Posted on ${formatDate(createDate)}</p>
761 </#if>
762 </div>
763 <div class="render-share-news-container desktop">
764 <@renderShareAndCopyNews/>
765 </div>
766 </div>
767 </div>
768
769 <style>
770 .ptb-news__read-news .hidden {
771 display: none;
772 }
773 /*Data de publicação e redes sociais */
774
775 /* Desktop */
776 .ptb-news__read-news .publish_and_social_medias_infos_desk {
777 position: relative;
778 display: grid;
779 grid-template-columns: auto 1fr auto;
780 }
781
782 .ptb-news__read-news .render-share-news-container.mobile {
783 display: none;
784 }
785
786 .ptb-news__read-news .publish_and_social_medias_infos_desk * {
787 padding: var(--space-none, 0);
788 margin: var(--space-none, 0);
789 font-family: var(--font-family-base);
790 font-style: var(--font-style-normal, normal);
791 font-weight: var(--font-weight-regular, 400);
792 font-size: var(--font-size-xxs, 16px);
793 line-height: var(--line-height-xl, 160%);
794 color: var(--color-neutral-800, #373737);
795 }
796
797 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk * {
798 color: var(--text-secondary-default, #F8F8F8);
799 }
800
801 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk a svg path,
802 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .mobile-share svg path {
803 stroke: var(--color-neutral-500, #D7D7D7);
804 fill: rgba(255, 255, 255, 0.32);
805 }
806
807 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk a svg circle,
808 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .mobile-share svg circle {
809 fill: rgba(255, 255, 255, 0.32);
810 }
811
812 .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date {
813 display: flex;
814 align-items: center;
815 gap: var(--space-sm, 16px);
816 }
817
818 .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date .updated {
819 font-weight: var(--font-weight-bold, 700);
820 font-size: var(--font-size-xxxs, 14px);
821 }
822
823 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date .updated {
824 color: var(--text-primary-default, var(--color-neutral-100));
825 }
826
827 .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date .published {
828 font-weight: var(--font-weight-normal, 400);
829 font-size: var(--font-size-xxxs, 14px);
830 }
831
832 .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container {
833 display: flex;
834 width: 100%;
835 justify-content: flex-end;
836 align-items: center;
837 gap: var(--space-sm, 16px);
838 }
839
840 .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container .social-media-share {
841 position: relative;
842 }
843
844 .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container .social-media-share span {
845 position: absolute;
846 width: 100%;
847 height: 100%;
848 opacity: 0;
849 overflow: hidden;
850 pointer-events: none;
851 }
852
853 .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container .mobile-share {
854 display: none;
855 }
856
857 .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container {
858 background: var(--color-neutral-100);
859 border: var(--border-width-hairline, 1px) solid #CCCCCC;
860 border-radius: 32px;
861 display: flex;
862 align-items: center;
863 gap: var(--space-sm, 16px);
864 padding: 6px var(--space-xxs, 8px);
865 height: 36px;
866 margin: 0;
867 cursor: pointer;
868 }
869
870 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container {
871 background: rgba(255, 255, 255, 0.32);
872 border: var(--border-width-hairline, 1px) solid rgba(255, 255, 255, 0.32);
873 }
874
875 .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container svg {
876 width: 18px;
877 }
878
879 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk svg path {
880 stroke: var(--color-neutral-500, #D7D7D7);
881 }
882
883 .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container .text {
884 font-family: var(--font-family-base);
885 font-style: normal;
886 margin: 0;
887 height: 100%;
888 display: flex;
889 align-items: center;
890 color: var(--color-primary-medium, #008542);
891 font-size: var(--font-size-micro, 12px);
892 font-weight: var(--font-weight-bold, 700);
893 line-height: var(--line-height-lg, 144%);
894 pointer-events: none;
895 }
896
897 .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container .text .copy-text-title-news {
898 position: absolute;
899 width: 100%;
900 height: 100%;
901 opacity: 0;
902 overflow: hidden;
903 }
904
905 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container .text {
906 color: var(--text-primary-accent, #E4F7E8);
907 }
908
909 .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-message {
910 display: none;
911 position: absolute;
912 bottom: -43px;
913 right: -15px;
914 padding: var(--space-xxxs, 4px) 15px;
915 margin: var(--space-micro, 2px) 10px;
916 width: 110px;
917 font-family: var(--font-family-base);
918 font-size: var(--font-size-micro, 12px);
919
920 color: #008542;
921 background: var(--color-neutral-100);
922 border-radius: var(--border-radius-md, 8px);
923
924 filter: drop-shadow(0px 4px 16px rgba(0, 0, 0, 0.16));
925
926 cursor: pointer;
927 }
928
929 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-message {
930 background: rgba(255, 255, 255, 0.32);
931 color: var(--text-primary-accent, #E4F7E8);
932 }
933
934 .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-message-active {
935 display: block;
936 }
937
938 /* Mobile */
939
940 .ptb-news__read-news .publish_and_social_medias_infos_mobile {
941 display: flex;
942 flex-direction: column;
943 gap: 19px;
944 }
945
946 .ptb-news__read-news .publish_and_social_medias_infos_mobile {
947 display: none;
948 }
949
950 .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text {
951 display: flex;
952 justify-content: space-between;
953 align-items: center;
954 margin-bottom: var(--space-lg, 32px);
955 }
956
957 .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .publish_and_update_date * {
958 padding: 0;
959 margin: 0;
960 font-family: var(--font-family-base);
961 font-style: var(--font-style-normal, normal);
962 font-size: var(--font-size-micro, 12px);
963 line-height: 136%;
964 color: var(--color-neutral-800, #373737);
965 }
966
967 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .publish_and_update_date * {
968 color: var(--text-primary-accent, #E4F7E8);
969 }
970
971 .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .publish_and_update_date {
972 display: flex;
973 flex-direction: column;
974 gap: 0;
975 }
976
977 .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .publish_and_update_date .updated {
978 font-weight: var(--font-weight-bold, 700);
979 }
980
981 .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .publish_and_update_date .published {
982 font-weight: var(--font-weight-regular, 400);
983 }
984
985 .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .copy-text-container {
986 background: var(--color-neutral-100);
987 border: var(--border-width-hairline, 1px) solid #CCCCCC;
988 border-radius: 32px;
989 display: flex;
990 align-items: center;
991 gap: var(--space-sm, 16px);
992 padding: 6px var(--space-xxs, 8px);
993 width: 112px;
994 height: 36px;
995 }
996
997 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .copy-text-container {
998 background: rgba(255, 255, 255, 0.32);
999 color: var(--text-primary-accent, #E4F7E8);
1000 }
1001
1002 .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .copy-text-container p.text {
1003 margin: 0;
1004 }
1005
1006 .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .copy-text-container .text {
1007 font-family: var(--font-family-base);
1008 font-style: var(--font-style-normal, normal);
1009 font-weight: var(--font-weight-regular, 400);
1010 font-size: 13px;
1011 line-height: 14px;
1012 color: #008542;
1013 }
1014
1015 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_mobile .publish_and_update_date_and_copy_text .copy-text-container .text {
1016 background: rgba(255, 255, 255, 0.32);
1017 color: var(--text-primary-accent, #E4F7E8);
1018 }
1019
1020 @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) {
1021
1022 .ptb-news__read-news .publish_and_social_medias_infos_desk .render-share-news-container.desktop {
1023 display: none;
1024 }
1025
1026 .ptb-news__read-news .render-share-news-container.mobile {
1027 display: block;
1028 margin: var(--space-xl) var(--space-lg) 0 var(--space-lg);
1029 }
1030
1031 .ptb-news__read-news .publish_and_social_medias_infos_desk * {
1032 font-size: var(--font-size-micro, 12px);
1033 }
1034
1035 .ptb-news__read-news .publish_and_social_medias_infos_desk {
1036 display: grid;
1037 grid-template-columns: 100%;
1038 grid-template-rows: 1fr 100%;
1039 }
1040
1041 .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date {
1042 grid-column-start: 1;
1043 grid-column-end: 1;
1044 grid-row-start: 1;
1045 grid-row-end: 1;
1046 gap: var(--space-xxs, 8px);
1047 }
1048
1049 .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date * {
1050 padding: 0;
1051 margin: 0;
1052 font-family: var(--font-family-base);
1053 font-style: var(--font-style-normal);
1054 color: var(--color-neutral-800, #373737);
1055 font-weight: var(--font-weight-bold);
1056 font-size: var(--font-size-xxxs, 14px);
1057 line-height: var(--line-height-md, 132%);
1058 }
1059
1060 body.high-contrast-active .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date * {
1061 color: var(--text-primary-accent, #E4F7E8);
1062 }
1063
1064 .ptb-news__read-news .publish_and_social_medias_infos_desk .publish_and_update_date .published {
1065 font-weight: var(--font-weight-regular, 400);
1066 }
1067
1068 .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container {
1069 grid-column-start: 1;
1070 grid-column-end: 2;
1071 grid-row-start: 2;
1072 grid-row-end: 2;
1073 justify-content: center;
1074 gap: var(--space-xs, 12px);
1075 height: 36px;
1076 }
1077
1078 .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container {
1079 grid-column-start: 1;
1080 grid-column-end: 2;
1081 grid-row-start: 2;
1082 grid-row-end: 2;
1083 max-width: 112px;
1084 place-self: end;
1085 }
1086
1087 .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-text-container .text {
1088 display: none;
1089 }
1090
1091 .ptb-news__read-news .publish_and_social_medias_infos_desk .copy-message {
1092 bottom: 0;
1093 right: -9px;
1094 }
1095
1096 .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container .mobile-share {
1097 display: initial;
1098 }
1099 }
1100
1101 @media screen and (min-width: ${MIN_TABLET_WIDTH}px) and (max-width: ${MAX_TABLET_WIDTH}px) {
1102 .ptb-news__read-news .publish_and_social_medias_infos_desk .social-media-container {
1103 padding-right: 0;
1104 }
1105 }
1106
1107
1108 </style>
1109
1110 <script>
1111 AUI().ready(function () {
1112
1113 function copyOnClick(text) {
1114
1115 const strWithoutHtmlTags = text.replace(/(<([^>]+)>)/gi, "");
1116 const strWithoutMarcationBrackets = strWithoutHtmlTags.replace(/ *#\[[^\]]*]/g, "");
1117 const strWithoutNextPrevious = strWithoutMarcationBrackets.replace(/Previous Next/g, "");
1118 const strWithoutBlankEnters = strWithoutNextPrevious.replace(/^\s*$(?:\r\n?|\n)/gm, "");
1119 const strWithoutBlankLines = strWithoutBlankEnters.replace(/ /g, '');
1120 const tempInput = document.createElement("textarea");
1121 tempInput.value = strWithoutBlankLines;
1122
1123 document.body.appendChild(tempInput);
1124 tempInput.select();
1125 document.execCommand("copy");
1126
1127 if (tempInput.value.length > 0) {
1128 copyMessages.forEach(copyMessage => copyMessage.classList.add('copy-message-active'));
1129
1130 timerToMessage()
1131 }
1132
1133 document.body.removeChild(tempInput);
1134 }
1135
1136 const copyTextContainers = document.querySelectorAll(".publish_and_social_medias_infos_desk .copy-text-container");
1137 copyTextContainers.forEach(copyTextContainer => {
1138 copyTextContainer.addEventListener("click", (event) => {
1139 event.preventDefault();
1140 const titleText = document.querySelector(".main-headline-container .main-headline").innerHTML;
1141 const publishSocialMediaText = document.querySelector(".publish_and_social_medias_infos_desk .publish_and_update_date").innerHTML;
1142 const tagsText = document.querySelector(".tags").innerHTML;
1143 const newsContentText = document.querySelector(".news-content").innerHTML;
1144 const text = titleText + publishSocialMediaText + tagsText + newsContentText;
1145 copyOnClick(text)
1146 });
1147 });
1148
1149 const mobileShare = async () => {
1150 try {
1151 const shareData = {
1152 title: '${newsInfo.mainHeadlineOfTheNews}',
1153 text: '',
1154 url: '${newsInfo.url}'
1155 };
1156 await navigator.share(shareData);
1157 } catch (err) {
1158
1159 }
1160 };
1161
1162 const mobileShareButtons = document.querySelectorAll(".publish_and_social_medias_infos_desk .mobile-share");
1163 mobileShareButtons.forEach(mobileShareButton => {
1164 mobileShareButton.addEventListener("click", (event) => {
1165 event.preventDefault();
1166 mobileShare();
1167 });
1168 });
1169
1170 const copyMessages = document.querySelectorAll('.copy-message');
1171 const timerToMessage = () => {
1172 setTimeout(() => {
1173 removeMessage();
1174 }, 2500);
1175
1176 }
1177
1178 const removeMessage = () => {
1179 copyMessages.forEach(copyMessage => copyMessage.classList.remove('copy-message-active'));
1180 }
1181
1182 });
1183 </script>
1184
1185</#macro>
1186
1187<#-- ################################################################################################################## -->
1188
1189<#-- ############# Site de Crise - Notícia - Render Tags ############################################################## -->
1190
1191<#function getCategoriesNamesAndIds vocabularyName categoriesList>
1192 <#assign tagCategoryList = [] />
1193
1194 <#assign tagsVocabulary = assetVocabularyService.fetchGroupVocabulary(groupId, vocabularyName) />
1195 <#list categoriesList as cat>
1196 <#if tagsVocabulary.getVocabularyId() == cat.embeddedTaxonomyCategory.taxonomyVocabularyId >
1197 <#assign tagCategoryList += [[cat.taxonomyCategoryName, cat.taxonomyCategoryId]] />
1198 </#if>
1199 </#list>
1200 <#return tagCategoryList>
1201</#function>
1202
1203<#assign
1204flagVocabulary = findVocabulary("Flag", vocabularies)
1205assetCategoryPropService = serviceLocator.findService("com.liferay.asset.category.property.service.AssetCategoryPropertyLocalService")
1206/>
1207
1208<#macro renderNewsTags categoryList targetPageWhenClickTag removeStartParameterWhenTagIsClicked updateTagParamsWhenClicked>
1209 <#assign tagPrefix = "tags-" + randomNumber(groupId?number)>
1210 <div class="${tagPrefix}-breakpoint breakpoint">
1211 <div class="${tagPrefix} col-2-11 md-col-1-8 sm-col-1-4">
1212
1213 <div class="tags">
1214 <#list categoryList as cat>
1215 <#assign tagLink = mountUrlToPage("") />
1216 <#assign urlWithoutTrailingSlash = tagLink?substring(0, tagLink?length - 1)>
1217 <#assign lastSlashIndex = urlWithoutTrailingSlash?last_index_of("/")>
1218 <#assign newUrl = urlWithoutTrailingSlash?substring(0, lastSlashIndex + 1)>
1219 <#assign tagLink = newUrl + "categorias?category=" + cat[1] />
1220 <a href="${tagLink}"
1221 class="category" cetegoryid="${cat[1]}"># ${cat[0]}</a>
1222 </#list>
1223 </div>
1224 </div>
1225 </div>
1226
1227 <style>
1228 .${tagPrefix} {
1229 display: flex;
1230 flex-direction: column;
1231 padding: 0;
1232 gap: var(--space-sm);
1233 }
1234
1235 .${tagPrefix} * {
1236 margin: 0;
1237 padding: 0;
1238 }
1239
1240 .${tagPrefix} .tags {
1241 display: flex;
1242 flex-wrap: wrap;
1243 gap: var(--space-xxs, 8px);
1244 padding: var(--space-lg) 0 0;
1245 }
1246
1247 .${tagPrefix} .tags .category {
1248 padding: var(--space-xxxs) var(--space-xxs);
1249 background: var(--color-neutral-100);
1250 border: var(--border-width-hairline, 1px) solid var(--color-neutral-500);
1251 border-radius: var(--border-radius-xl);
1252
1253 font-family: var(--font-family-base);
1254 font-style: var(--font-style-normal);
1255 font-weight: var(--font-weight-regular);
1256 font-size: var(--font-size-xxxs);
1257 line-height: var(--line-height-xl);
1258 color: var(--color-neutral-800, #373737);
1259 cursor: pointer;
1260 }
1261
1262 body.high-contrast-active .${tagPrefix} .tags .category {
1263 background: rgba(255, 255, 255, 0.32);
1264 border: 1px solid rgba(255, 255, 255, 0.32);
1265 color: var(--text-secondary-default, #F8F8F8);
1266 }
1267
1268 @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) {
1269 .${tagPrefix} .tags {
1270 display: flex;
1271 flex-wrap: wrap;
1272 gap: 8px;
1273 padding: var(--space-sm) 0 var(--space-lg);
1274 }
1275
1276 .${tagPrefix} {
1277 margin-top: var(--space-sm);
1278 }
1279 }
1280 </style>
1281
1282 <script>
1283 AUI().ready(function () {
1284
1285 const urlParams = new URLSearchParams(window.location.search);
1286 const categories = urlParams.getAll("category").sort();
1287
1288 const root = document.querySelector(".${tagPrefix}");
1289 const tags = root.querySelectorAll(".category");
1290 tags.forEach((tag, index) => {
1291
1292 const categoryId = tag.getAttribute("cetegoryid");
1293 if (categories.indexOf(categoryId) != -1) {
1294 tag.classList.add("active");
1295 }
1296
1297 <#if updateTagParamsWhenClicked>
1298 tag.addEventListener("click", (e) => {
1299 e.preventDefault();
1300 const clickedTag = e.target;
1301 const urlParams = new URLSearchParams(window.location.search);
1302 urlParams.delete("tag");
1303 urlParams.delete("category");
1304
1305 const categoryId = clickedTag.getAttribute("cetegoryid");
1306 urlParams.append("category", categoryId);
1307
1308 <#if removeStartParameterWhenTagIsClicked>
1309 urlParams.delete("start");
1310 </#if>
1311
1312 const href = "${themeDisplay.getPortalURL() + mountUrlToPage(targetPageWhenClickTag)}?" + urlParams.toString();
1313 window.location.href = href;
1314 });
1315 </#if>
1316 });
1317 });
1318 </script>
1319
1320</#macro>
1321
1322<#-- ################################################################################################################## -->
1323
1324<#-- ############# Site de Crise - Notícia - Imagem de destaque ####################################################### -->
1325<#macro renderNewsFeaturedMedia newsInfo>
1326 <#if (newsInfo.newsMedia.imageSrc?? && newsInfo.newsMedia.imageSrc?has_content) || (newsInfo.newsMedia.videoYotubeID?? && newsInfo.newsMedia.videoYotubeID?has_content) || (newsInfo.newsMedia.internalVideo?? && newsInfo.newsMedia.internalVideo.url?has_content)>
1327 <div class="news-featured-media">
1328
1329 <div class="media-breakpoint breakpoint">
1330 <div class="media-col col-2-11 md-col-1-8 sm-col-1-4">
1331 <#if newsInfo.newsMedia.imageSrc?? && newsInfo.newsMedia.imageSrc?has_content>
1332 <#-- Midias adaptativas de imagem para desktop e mobile -->
1333 <#assign fileDataRequest = restClient.get("/headless-delivery/v1.0/documents/${newsInfo.newsMedia.fileEntryId}") />
1334 <#assign urlAdaptativeMediaMobile = newsInfo.newsMedia.imageSrc/>
1335 <#assign urlAdaptativeMediaDesktop = newsInfo.newsMedia.imageSrc/>
1336
1337 <#if fileDataRequest?? && fileDataRequest.adaptedImages?? >
1338 <#assign dataAdaptativeMedia = fileDataRequest.adaptedImages />
1339 <#list dataAdaptativeMedia as data>
1340 <#if data.resolutionName == adaptativeMediaDesktopResolutionName>
1341 <#assign urlAdaptativeMediaDesktop = data.contentUrl/>
1342 </#if>
1343 <#if data.resolutionName == adaptativeMediaMobileResolutionName>
1344 <#assign urlAdaptativeMediaMobile = data.contentUrl/>
1345 </#if>
1346 </#list>
1347 </#if>
1348
1349 <picture >
1350 <source media="(max-width:767px)" srcset="${urlAdaptativeMediaMobile}">
1351 <img src="${urlAdaptativeMediaDesktop}" loading="lazy" alt="${newsInfo.newsMedia.imageAlt}"/>
1352 </picture>
1353 <@liferay_util["html-top"]>
1354 <meta name="title" content="${newsInfo.mainHeadlineOfTheNews}">
1355 <meta name="description" content="${newsInfo.newsSummary}">
1356
1357 <meta property="og:url" content="${currentURL}">
1358 <meta property="og:type" content="website">
1359 <meta property="og:title" content="${newsInfo.mainHeadlineOfTheNews}">
1360 <meta property="og:description" content="${newsInfo.newsSummary}" />
1361 <meta property="og:image" content="${themeDisplay.getPortalURL()}/o/adaptive-media/image/${newsInfo.newsMedia.fileEntryId}/Thumbnail-300x300/image">
1362 <meta property="og:image:alt" content="${newsInfo.newsMedia.imageAlt}">
1363
1364 <meta name="twitter:card" content="summary_large_image">
1365 <meta name="twitter:url" content="${currentURL}" />
1366 <meta name="twitter:title" content="${newsInfo.mainHeadlineOfTheNews}">
1367 <meta name="twitter:description" content="${newsInfo.newsSummary}" />
1368 <meta name="twitter:image" content= "${themeDisplay.getPortalURL()}/o/adaptive-media/image/${newsInfo.newsMedia.fileEntryId}/Thumbnail-300x300/image" >
1369 <meta name="twitter:image:alt" content="${newsInfo.newsMedia.imageAlt}">
1370 </@>
1371 <#else>
1372 <#if newsInfo.newsMedia.videoYotubeID?? && newsInfo.newsMedia.videoYotubeID?has_content>
1373 <iframe loading="lazy" data-video-id="${cardData.media.videoYotubeID}" title="YouTube video player" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" allowfullscreen></iframe>
1374 <@liferay_util["html-top"]>
1375 <meta name="title" content="${newsInfo.mainHeadlineOfTheNews}">
1376 <meta name="description" content="${newsInfo.newsSummary}">
1377
1378 <meta property="og:url" content="${currentURL}">
1379 <meta property="og:type" content="website">
1380 <meta property="og:title" content="${newsInfo.mainHeadlineOfTheNews}">
1381 <meta property="og:description" content="${newsInfo.newsSummary}" />
1382 <meta property="og:image" content="https://img.youtube.com/vi/${newsInfo.newsMedia.videoYotubeID}/hqdefault.jpg">
1383 <meta property="og:image:alt" content="Youtube Video Thumbnail">
1384
1385 <meta name="twitter:card" content="summary_large_image">
1386 <meta name="twitter:url" content="${currentURL}" />
1387 <meta name="twitter:title" content="${newsInfo.mainHeadlineOfTheNews}">
1388 <meta name="twitter:description" content="${newsInfo.newsSummary}" />
1389 <meta name="twitter:image" content= "https://img.youtube.com/vi/${newsInfo.newsMedia.videoYotubeID}/hqdefault.jpg" >
1390 <meta name="twitter:image:alt" content="Youtube Video Thumbnail">
1391 </@>
1392 <#else>
1393 <video loading="lazy">
1394 <source src="${newsInfo.newsMedia.internalVideo.url}">
1395 Your browser does not support the video tag.
1396 </video>
1397 </#if>
1398
1399 <div class="banner-video-icons">
1400 <#if newsInfo.newsMedia.videoYotubeID?? && newsInfo.newsMedia.videoYotubeID?has_content>
1401 <picture >
1402 <source media="(max-width:767px)" srcset="https://img.youtube.com/vi/${newsInfo.newsMedia.videoYotubeID}/mqdefault.jpg">
1403 <img class="banner-video-thumb-iframe" loading="lazy" src="https://img.youtube.com/vi/${newsInfo.newsMedia.videoYotubeID}/hqdefault.jpg" alt="YouTube Thumbnail"/>
1404 </picture>
1405 </#if>
1406 <svg class="banner-video-icon-play" width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">
1407 <path d="M0 16C0 7.16344 7.16344 0 16 0C24.8366 0 32 7.16344 32 16C32 24.8366 24.8366 32 16 32C7.16344 32 0 24.8366 0 16Z" fill="white" fill-opacity="0.8"/>
1408 <path d="M22.2563 15.5744L13.2625 10.0744C13.1868 10.0277 13.1 10.0021 13.0111 10.0001C12.9221 9.99816 12.8343 10.02 12.7566 10.0633C12.6789 10.1066 12.6141 10.1698 12.569 10.2465C12.5239 10.3232 12.5001 10.4105 12.5 10.4994V21.4994C12.5001 21.5884 12.5239 21.6757 12.569 21.7524C12.6141 21.8291 12.6789 21.8923 12.7566 21.9356C12.8343 21.9789 12.9221 22.0007 13.0111 21.9988C13.1 21.9968 13.1868 21.9712 13.2625 21.9244L22.2563 16.4244C22.3301 16.3808 22.3913 16.3186 22.4338 16.2441C22.4763 16.1696 22.4987 16.0852 22.4987 15.9994C22.4987 15.9137 22.4763 15.8293 22.4338 15.7548C22.3913 15.6803 22.3301 15.6181 22.2563 15.5744Z" fill="#008542"/>
1409 </svg>
1410 </div>
1411 </#if>
1412 </div>
1413 </div>
1414
1415 <div class="credit-legend breakpoint">
1416
1417 <div class="credit-legend-container col-2-11 md-col-1-8 sm-col-1-4">
1418 <#if newsInfo.newsMedia.legend != "">
1419 <div class="legend paragraph-micro-regular">
1420 <p>${newsInfo.newsMedia.legend}</p>
1421 </div>
1422 </#if>
1423 <#if newsInfo.newsMedia.credits != "">
1424 <p class="credits paragraph-micro-regular">
1425 ${newsInfo.newsMedia.credits}
1426 </p>
1427 </#if>
1428
1429 </div>
1430 </div>
1431 </div>
1432 </#if>
1433 <style>
1434 .ptb-news__read-news .news-featured-media {
1435 padding: var(--space-xl) 0 var(--space-xl) 0;
1436 }
1437
1438 .ptb-news__read-news .news-featured-media .media-col {
1439 position: relative;
1440 }
1441
1442 .ptb-news__read-news .news-featured-media img,
1443 .ptb-news__read-news .news-featured-media video,
1444 .ptb-news__read-news .news-featured-media iframe {
1445 width: 100%;
1446 max-height: 567px;
1447 aspect-ratio: 16/9;
1448 object-fit: cover;
1449 border-radius: var(--border-radius-lg, 16px);
1450 }
1451
1452 .ptb-news__read-news .news-featured-media .banner-video-icons {
1453 width: 100%;
1454 height: 100%;
1455 position: absolute;
1456 top: 50%;
1457 left: 50%;
1458 transform: translate(-50%,-50%);
1459 cursor: pointer;
1460 }
1461
1462 .ptb-news__read-news .news-featured-media .banner-video-icons .banner-video-thumb-iframe {
1463 position: absolute;
1464 width: 100%;
1465 height: 100%;
1466 object-fit: cover;
1467 }
1468
1469 .ptb-news__read-news .news-featured-media .banner-video-icons .banner-video-icon-play {
1470 position: absolute;
1471 top: 50%;
1472 left: 50%;
1473 transform: translate(-50%,-50%);
1474 }
1475
1476 body.high-contrast-active .ptb-news__read-news .news-featured-media .banner-video-icons .banner-video-icon-play path:nth-child(1) {
1477 fill: black;
1478 }
1479
1480 body.high-contrast-active .ptb-news__read-news .news-featured-media .banner-video-icons .banner-video-icon-play path:nth-child(2) {
1481 fill: white;
1482 }
1483
1484 .ptb-news__read-news .news-featured-media *:not(.breakpoint) {
1485 margin: 0;
1486 }
1487 .ptb-news__read-news .news-featured-media * {
1488 padding: 0;
1489 font-family: var(--font-family-base);
1490 line-height: var(--line-height-xl);
1491 }
1492
1493 .ptb-news__read-news .news-featured-media .credits {
1494 text-align: right;
1495 color: var(--collor-neutral-dark-to-bright-200, #525252);
1496 margin-bottom: var(--space-xxxs, 4px);
1497 font-style: var(--font-style-italic, italic);
1498 margin-top: var(--space-xxs, 8px);
1499 margin-bottom: 0;
1500 }
1501
1502 body.high-contrast-active .ptb-news__read-news .news-featured-media .credits {
1503 color: var(--text-secondary-default, #F8F8F8);
1504 }
1505
1506 .ptb-news__read-news .news-featured-media .legend {
1507 margin-top: var(--space-xxs, 8px);
1508 display: flex;
1509 justify-content: space-between;
1510 }
1511
1512 .ptb-news__read-news .news-featured-media .legend,
1513 .ptb-news__read-news .news-featured-media .legend * {
1514 font-style: var(--font-style-italic, italic);
1515 color: var(--collor-neutral-dark-to-bright-200, #525252);
1516 }
1517
1518 .ptb-news__read-news .credit-legend .credit-legend-container {
1519 display: flex;
1520 justify-content: space-between;
1521 flex-wrap: wrap;
1522 gap: 8px;
1523 }
1524
1525 body.high-contrast-active .ptb-news__read-news .news-featured-media .legend,
1526 body.high-contrast-active .ptb-news__read-news .news-featured-media .legend * {
1527 color: var(--text-secondary-default, #F8F8F8);
1528 }
1529
1530 @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) {
1531 .ptb-news__read-news .news-featured-media .credits {
1532 text-align: left;
1533 }
1534 }
1535 </style>
1536
1537 <script>
1538 /* Manipulation video*/
1539 let videoIsPlaying = false;
1540
1541 const modalForClick = document.querySelector(".ptb-news__read-news .news-featured-media .banner-video-icons");
1542 const video = document.querySelector(".ptb-news__read-news .news-featured-media .media-col > :first-child");
1543
1544 const playIcon = modalForClick && modalForClick.querySelector(".banner-video-icon-play");
1545 modalForClick && modalForClick.addEventListener("click", ()=>{
1546 if(video.tagName === "VIDEO") {
1547 if(videoIsPlaying) {
1548 video.pause();
1549 playIcon.style.display = "";
1550 videoIsPlaying = false;
1551 }
1552 else {
1553 video.play();
1554 playIcon.style.display = "none";
1555 videoIsPlaying = true;
1556 }
1557 }
1558 else if(video.tagName === "IFRAME") {
1559 const thumbYoutube = modalForClick.querySelector(".banner-video-thumb-iframe");
1560 if(videoIsPlaying) {
1561 video.contentWindow.postMessage('{"event":"command","func":"pauseVideo"}', '*');
1562 playIcon.style.display = "";
1563 videoIsPlaying = false;
1564 }
1565 else {
1566 if (!video.getAttribute('src')) {
1567 const videoId = video.getAttribute('data-video-id');
1568 const youtubeIframeUrl = 'https://www.youtube-nocookie.com/embed/' + videoId + '?si=PDNu4EIwtCuSHC1S&controls=0&enablejsapi=1&rel=0';
1569 video.setAttribute('src', youtubeIframeUrl);
1570 video.setAttribute('allow', 'accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share');
1571
1572 video.onload = () => video.contentWindow.postMessage('{"event":"command","func":"playVideo"}', '*');
1573 }
1574 thumbYoutube && (thumbYoutube.style.display = "none");
1575 video.contentWindow.postMessage('{"event":"command","func":"playVideo"}', '*');
1576 playIcon.style.display = "none";
1577 videoIsPlaying = true;
1578 }
1579 }
1580 });
1581 </script>
1582<#--/#if -->
1583</#macro>
1584<#-- ################################################################################################################## -->
1585
1586<#-- ############# Site de Crise - Notícia - Conteúdo da notícia ###################################################### -->
1587
1588<#macro renderNewsContent newsInfo>
1589
1590 <#assign targetStr = "<div class='paragraph_separator'><span class='dot'></span><span class='dot'></span><span class='dot'></span><span class='dot'></span></div>">
1591 <#assign content = newsInfo.newsContent?replace("<p></p>", targetStr, 'r')>
1592 <#assign content = content?replace("<p> </p>", targetStr, 'r')>
1593 <#assign content = content?replace("<p></p>", targetStr, 'r')>
1594 <#assign content = content?replace("<p> </p>", targetStr, 'r')>
1595
1596
1597 <div class="news-content breakpoint">
1598 <div class="col-1-12 md-col-1-8 sm-col-1-4">
1599 ${content}
1600 </div>
1601 <div class="audio-template audio-pause audio-unmuted" style="display:none">
1602 <div class="audio-button-play">
1603 <svg class="audio-play-icon" width="100%" height="100%" viewBox="0 0 91 90" fill="#008542" xmlns="http://www.w3.org/2000/svg"><circle cx="45.2903" cy="45" r="44.5" stroke="#008542"></circle> <path d="M58.9759 43.2545C60.3409 44.0179 60.3409 45.9821 58.9759 46.7455L38.7505 58.0578C37.4173 58.8034 35.7742 57.8397 35.7742 56.3122L35.7742 33.6878C35.7742 32.1603 37.4173 31.1966 38.7505 31.9422L58.9759 43.2545Z" fill="white"></path>
1604 </svg>
1605
1606 <svg class="audio-pause-icon" width="100%" height="100%" viewBox="0 0 91 90" fill="#008542" xmlns="http://www.w3.org/2000/svg"><circle cx="45.2903" cy="45" r="44.5" stroke="#008542"></circle> <path d="M42.3736 30.4167H33.6236V59.5834H42.3736V30.4167Z" fill="white"></path> <path d="M48.2069 59.5834H56.9569V30.4167H48.2069V59.5834Z" fill="white"></path>
1607 </svg>
1608 </div>
1609 <div class="audio-sondwave">
1610 <svg class="audio-sondwave-desktop" width="100%" height="100%" viewBox="0 0 590 30" fill="none" xmlns="http://www.w3.org/2000/svg">
1611 <g clip-path="url(#clip0_2625_8152)">
1612 <line x1="0.75" y1="0.75" x2="0.749999" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1613 <line x1="5.91016" y1="7.75" x2="5.91016" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1614 <line x1="11.0723" y1="5.75" x2="11.0723" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1615 <line x1="16.2344" y1="11.75" x2="16.2344" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1616 <line x1="21.3945" y1="9.75" x2="21.3945" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1617 <line x1="26.5566" y1="9.75" x2="26.5566" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1618 <line x1="30.6855" y1="1.75" x2="30.6855" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1619 <line x1="35.8477" y1="12.75" x2="35.8477" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1620 <line x1="41.0078" y1="13.75" x2="41.0078" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1621 <line x1="46.1699" y1="10.75" x2="46.1699" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1622 <line x1="51.3301" y1="8.75" x2="51.3301" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1623 <line x1="56.4922" y1="0.75" x2="56.4922" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1624 <line x1="61.6523" y1="7.75" x2="61.6523" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1625 <line x1="66.8145" y1="5.75" x2="66.8145" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1626 <line x1="71.9766" y1="11.75" x2="71.9766" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1627 <line x1="77.1367" y1="9.75" x2="77.1367" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1628 <line x1="82.2988" y1="9.75" x2="82.2988" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1629 <line x1="86.4277" y1="1.75" x2="86.4277" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1630 <line x1="91.5879" y1="12.75" x2="91.5879" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1631 <line x1="96.75" y1="13.75" x2="96.75" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1632 <line x1="101.91" y1="10.75" x2="101.91" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1633 <line x1="107.072" y1="8.75" x2="107.072" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1634 <line x1="112.234" y1="0.75" x2="112.234" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1635 <line x1="117.395" y1="7.75" x2="117.395" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1636 <line x1="122.557" y1="5.75" x2="122.557" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1637 <line x1="127.717" y1="11.75" x2="127.717" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1638 <line x1="132.879" y1="9.75" x2="132.879" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1639 <line x1="138.041" y1="9.75" x2="138.041" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1640 <line x1="142.17" y1="1.75" x2="142.17" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1641 <line x1="147.33" y1="12.75" x2="147.33" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1642 <line x1="151.75" y1="0.75" x2="151.75" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1643 <line x1="156.91" y1="7.75" x2="156.91" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1644 <line x1="162.072" y1="5.75" x2="162.072" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1645 <line x1="167.234" y1="11.75" x2="167.234" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1646 <line x1="172.395" y1="9.75" x2="172.395" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1647 <line x1="177.557" y1="9.75" x2="177.557" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1648 <line x1="181.686" y1="1.75" x2="181.686" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1649 <line x1="186.848" y1="12.75" x2="186.848" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1650 <line x1="192.008" y1="13.75" x2="192.008" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1651 <line x1="197.17" y1="10.75" x2="197.17" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1652 <line x1="202.33" y1="8.75" x2="202.33" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1653 <line x1="207.492" y1="0.75" x2="207.492" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1654 <line x1="212.652" y1="7.75" x2="212.652" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1655 <line x1="217.814" y1="5.75" x2="217.814" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1656 <line x1="222.977" y1="11.75" x2="222.977" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1657 <line x1="228.137" y1="9.75" x2="228.137" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1658 <line x1="233.299" y1="9.75" x2="233.299" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1659 <line x1="237.428" y1="1.75" x2="237.428" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1660 <line x1="242.588" y1="12.75" x2="242.588" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1661 <line x1="247.75" y1="13.75" x2="247.75" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1662 <line x1="252.91" y1="10.75" x2="252.91" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1663 <line x1="258.072" y1="8.75" x2="258.072" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1664 <line x1="263.234" y1="0.75" x2="263.234" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1665 <line x1="268.395" y1="7.75" x2="268.395" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1666 <line x1="273.557" y1="5.75" x2="273.557" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1667 <line x1="278.717" y1="11.75" x2="278.717" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1668 <line x1="283.879" y1="9.75" x2="283.879" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1669 <line x1="289.041" y1="9.75" x2="289.041" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1670 <line x1="293.17" y1="1.75" x2="293.17" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1671 <line x1="298.33" y1="12.75" x2="298.33" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1672 <line x1="302.75" y1="10.75" x2="302.75" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1673 <line x1="307.912" y1="8.75" x2="307.912" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1674 <line x1="313.072" y1="0.75" x2="313.072" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1675 <line x1="318.234" y1="7.75" x2="318.234" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1676 <line x1="323.395" y1="5.75" x2="323.395" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1677 <line x1="328.557" y1="11.75" x2="328.557" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1678 <line x1="333.719" y1="9.75" x2="333.719" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1679 <line x1="338.879" y1="9.75" x2="338.879" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1680 <line x1="343.008" y1="1.75" x2="343.008" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1681 <line x1="348.17" y1="12.75" x2="348.17" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1682 <line x1="353.33" y1="13.75" x2="353.33" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1683 <line x1="358.492" y1="10.75" x2="358.492" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1684 <line x1="363.652" y1="8.75" x2="363.652" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1685 <line x1="368.814" y1="0.75" x2="368.814" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1686 <line x1="373.977" y1="7.75" x2="373.977" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1687 <line x1="379.137" y1="5.75" x2="379.137" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1688 <line x1="384.299" y1="11.75" x2="384.299" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1689 <line x1="389.459" y1="9.75" x2="389.459" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1690 <line x1="394.621" y1="9.75" x2="394.621" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1691 <line x1="398.75" y1="1.75" x2="398.75" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1692 <line x1="403.912" y1="12.75" x2="403.912" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1693 <line x1="408.33" y1="10.75" x2="408.33" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1694 <line x1="413.492" y1="8.75" x2="413.492" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1695 <line x1="418.654" y1="0.75" x2="418.654" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1696 <line x1="423.814" y1="7.75" x2="423.814" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1697 <line x1="428.977" y1="5.75" x2="428.977" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1698 <line x1="434.137" y1="11.75" x2="434.137" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1699 <line x1="439.299" y1="9.75" x2="439.299" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1700 <line x1="444.461" y1="9.75" x2="444.461" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1701 <line x1="448.59" y1="1.75" x2="448.59" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1702 <line x1="453.75" y1="12.75" x2="453.75" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1703 <line x1="458.912" y1="13.75" x2="458.912" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1704 <line x1="464.072" y1="10.75" x2="464.072" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1705 <line x1="469.234" y1="8.75" x2="469.234" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1706 <line x1="474.395" y1="0.75" x2="474.395" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1707 <line x1="479.557" y1="7.75" x2="479.557" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1708 <line x1="484.719" y1="5.75" x2="484.719" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1709 <line x1="489.879" y1="11.75" x2="489.879" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1710 <line x1="495.041" y1="9.75" x2="495.041" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1711 <line x1="500.201" y1="9.75" x2="500.201" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1712 <line x1="504.33" y1="1.75" x2="504.33" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1713 <line x1="509.492" y1="12.75" x2="509.492" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1714 <line x1="513.912" y1="10.75" x2="513.912" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1715 <line x1="519.072" y1="8.75" x2="519.072" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1716 <line x1="524.234" y1="0.75" x2="524.234" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1717 <line x1="529.395" y1="7.75" x2="529.395" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1718 <line x1="534.557" y1="5.75" x2="534.557" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1719 <line x1="539.719" y1="11.75" x2="539.719" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1720 <line x1="544.879" y1="9.75" x2="544.879" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1721 <line x1="550.041" y1="9.75" x2="550.041" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1722 <line x1="554.17" y1="1.75" x2="554.17" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1723 <line x1="559.332" y1="12.75" x2="559.332" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1724 <line x1="564.492" y1="13.75" x2="564.492" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1725 <line x1="569.654" y1="10.75" x2="569.654" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1726 <line x1="574.814" y1="8.75" x2="574.814" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1727 <line x1="579.977" y1="0.75" x2="579.977" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1728 <line x1="585.137" y1="7.75" x2="585.137" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1729 <line x1="590.299" y1="5.75" x2="590.299" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1730 </g>
1731 <defs>
1732 <clipPath id="clip0_2625_8152">
1733 <rect width="590" height="30" fill="white"/>
1734 </clipPath>
1735 </defs>
1736 </svg>
1737 <svg class="audio-sondwave-mobile" width="100%" height="100%" viewBox="0 0 102 30" fill="none" xmlns="http://www.w3.org/2000/svg">
1738 <g clip-path="url(#clip0_2625_8922)">
1739 <line x1="0.75" y1="0.75" x2="0.749999" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1740 <line x1="5.91016" y1="7.75" x2="5.91016" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1741 <line x1="11.0723" y1="5.75" x2="11.0723" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1742 <line x1="16.2344" y1="11.75" x2="16.2344" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1743 <line x1="21.3945" y1="9.75" x2="21.3945" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1744 <line x1="26.5566" y1="9.75" x2="26.5566" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1745 <line x1="30.6855" y1="1.75" x2="30.6855" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1746 <line x1="35.8477" y1="12.75" x2="35.8477" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1747 <line x1="41.0078" y1="13.75" x2="41.0078" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1748 <line x1="46.1699" y1="10.75" x2="46.1699" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1749 <line x1="51.3301" y1="8.75" x2="51.3301" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1750 <line x1="56.4922" y1="0.75" x2="56.4922" y2="29.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1751 <line x1="61.6523" y1="7.75" x2="61.6523" y2="21.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1752 <line x1="66.8145" y1="5.75" x2="66.8145" y2="24.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1753 <line x1="71.9766" y1="11.75" x2="71.9766" y2="18.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1754 <line x1="77.1367" y1="9.75" x2="77.1367" y2="20.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1755 <line x1="82.2988" y1="9.75" x2="82.2988" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1756 <line x1="86.4277" y1="1.75" x2="86.4277" y2="28.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1757 <line x1="91.5879" y1="12.75" x2="91.5879" y2="17.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1758 <line x1="96.75" y1="13.75" x2="96.75" y2="16.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1759 <line x1="101.91" y1="10.75" x2="101.91" y2="19.25" stroke="#008542" stroke-width="1.5" stroke-linecap="round"/>
1760 </g>
1761 <defs>
1762 <clipPath id="clip0_2625_8922">
1763 <rect width="102" height="30" fill="white"/>
1764 </clipPath>
1765 </defs>
1766 </svg>
1767 </div>
1768 <div class="audio-time paragraph-micro-bold"> </div>
1769 <div class="audio-button-mute">
1770 <svg xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32" fill="none">
1771 <path d="M27.3625 9.6375C28.1993 10.4723 28.8632 11.464 29.3161 12.5558C29.7691 13.6476 30.0023 14.818 30.0023 16C30.0023 17.182 29.7691 18.3524 29.3161 19.4442C28.8632 20.536 28.1993 21.5277 27.3625 22.3625M10 21H4C3.73478 21 3.48043 20.8946 3.29289 20.7071C3.10536 20.5196 3 20.2652 3 20V12C3 11.7348 3.10536 11.4804 3.29289 11.2929C3.48043 11.1054 3.73478 11 4 11H10M10 21L19 28V4L10 11M10 21V11M23.825 13.175C24.1969 13.5455 24.492 13.9857 24.6933 14.4705C24.8947 14.9553 24.9983 15.4751 24.9983 16C24.9983 16.5249 24.8947 17.0447 24.6933 17.5295C24.492 18.0143 24.1969 18.4545 23.825 18.825" stroke="#525252" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
1772 </svg>
1773 </div>
1774 </div>
1775 </div>
1776
1777 <#if categoriesAsssetEntryResponse?? && categoriesAsssetEntryResponse?has_content && categoriesAsssetEntryResponse.taxonomyCategoryBriefs??>
1778 <@renderNewsTags tagCategoryList NEWS_PAGE_NAME removeStartParameterWhenTagIsClicked includeRequestParams />
1779 </#if>
1780 <style>
1781
1782 .ptb-news__read-news .news-content p {
1783 margin-bottom: var(--space-md, 24px);
1784 }
1785
1786 .ptb-news__read-news .news-content strong {
1787 font-weight: var(--font-weight-bold);
1788 }
1789
1790 .ptb-news__read-news .news-content em {
1791 font-style: var(--font-style-italic);
1792 }
1793
1794 .ptb-news__read-news .news-content a:not(.stories-container *) {
1795 font-family: var(--font-family-base);
1796 font-style: var(--font-style-normal, normal);
1797 font-weight: var(--font-weight-bold, 700);
1798 font-size: var(--font-size-xs, 18px);
1799 line-height: var(--line-height-xl, 160%);
1800
1801 color: #008542;
1802 }
1803
1804 body.high-contrast-active .ptb-news__read-news .news-content a {
1805 color: #E4F7E8;
1806 }
1807
1808 .ptb-news__read-news .news-content ul {
1809 padding-left: 27px;
1810 margin-top: -16px;
1811 }
1812
1813 .ptb-news__read-news .news-content ul li::marker {
1814 content: "■" !important;
1815 color: var(--color-secondary-medium) !important;
1816 font-size: var(--size-xxs);
1817 }
1818
1819 .ptb-news__read-news .news-content ul li {
1820 color: var(--color-text-primary-default);
1821 padding: 8px 0;
1822
1823 /*paragraph-sm-regular*/
1824 font-size: var(--font-size-xxs);
1825 line-height: var(--line-height-xl);
1826 font-weight: var(--font-weight-regular);
1827 font-style: var(--font-style-normal);
1828 text-decoration: var(--text-decoration-none);
1829
1830 margin-left: calc(-1* var(--space-sm));
1831 padding-left: var(--space-sm);
1832 }
1833
1834 .ptb-news__read-news .news-content ul li * {
1835 color: var(--color-text-primary-default);
1836 padding: 8px 0;
1837
1838 /*paragraph-sm-regular*/
1839 font-size: var(--font-size-xxs);
1840 line-height: var(--line-height-xl);
1841 font-weight: var(--font-weight-regular);
1842 font-style: var(--font-style-normal);
1843 text-decoration: var(--text-decoration-none);
1844 }
1845
1846 @media screen and (min-width: 1024px) {
1847 .ptb-news__read-news .news-content > * {
1848 grid-column-start: 3;
1849 grid-column-end: 11;
1850 }
1851
1852 <#if typeOfNews?? && typeOfNews?has_content && typeOfNews == "Infográfico" >
1853 .ptb-news__read-news .news-content > *:has(img) {
1854 grid-column-start: 2;
1855 grid-column-end: 12;
1856 }
1857 }
1858
1859 </#if>
1860 }
1861
1862 .ptb-news__read-news .news-content figure {
1863 margin-bottom: var(--space-sm, 16px);
1864 }
1865
1866 .ptb-news__read-news .news-content figure figcaption {
1867 display: flex;
1868 justify-content: space-between;
1869 align-items: flex-start;
1870 align-self: stretch;
1871 margin-top: var(--space-xxs, 8px);
1872 text-align: justify;
1873 }
1874
1875 .ptb-news__read-news .news-content figure figcaption,
1876 .ptb-news__read-news .news-content figure figcaption * {
1877 color: var(--color-neutral-700, #525252);
1878 font-family: var(--font-family-base);
1879 font-size: var(--font-size-xxxs, 14px);
1880 font-style: var(--font-style-italic, italic);
1881 font-weight: var(--font-weight-regular, 400);
1882 line-height: var(--line-height-xl, 160%);
1883 }
1884
1885 body.high-contrast-active .ptb-news__read-news .news-content figure figcaption,
1886 body.high-contrast-active .ptb-news__read-news .news-content figure figcaption * {
1887 color: var(--text-secondary-default, #F8F8F8);
1888 }
1889
1890 .ptb-news__read-news .news-content figure figcaption br {
1891 display: none;
1892 }
1893
1894 .ptb-news__read-news .news-content .embed-responsive {
1895 width: 100% !important;
1896 border-radius: var(--border-radius-md, 16px);
1897 margin-bottom: var(--space-md, 16px);
1898 aspect-ratio: 16/9;
1899 }
1900
1901 .ptb-news__read-news .news-content img {
1902 width: 100%;
1903 height: auto;
1904 object-fit: cover;
1905 border-radius: var(--border-radius-md, 16px);
1906 }
1907
1908 <#if typeOfNews?? && typeOfNews?has_content && typeOfNews == "Artigo" >
1909 .ptb-news__read-news .news-content img {
1910 aspect-ratio: 16/9;
1911 }
1912 </#if>
1913
1914 .ptb-news__read-news .news-content .paragraph_separator {
1915 display: flex;
1916 width: 100%;
1917 height: fit-content;
1918 justify-content: center;
1919 gap: 6px;
1920 }
1921
1922 .ptb-news__read-news .news-content .paragraph_separator .dot {
1923 height: var(--size-micro, 4px);
1924 width: var(--size-micro, 4px);
1925 background-color: #959595;
1926 border-radius: 100%;
1927 display: inline-block;
1928 }
1929
1930 .ptb-news__read-news .news-content *:not(.stories-container *) {
1931 font-family: var(--font-family-base);
1932 font-style: var(--font-style-normal, normal);
1933 font-weight: var(--font-weight-regular, 400);
1934 font-size: var(--font-size-xs, 18px);
1935 line-height: var(--line-height-xl, 160%);
1936 color: var(--color-neutral-800, #373737);
1937 }
1938
1939 body.high-contrast-active .ptb-news__read-news .news-content * {
1940 color: var(--text-primary-default, var(--color-neutral-100));
1941 }
1942
1943 .ptb-news__read-news .news-content h1,
1944 .ptb-news__read-news .news-content h1 *,
1945 .ptb-news__read-news .news-content h2,
1946 .ptb-news__read-news .news-content h2 *,
1947 .ptb-news__read-news .news-content h3,
1948 .ptb-news__read-news .news-content h3 *,
1949 .ptb-news__read-news .news-content h4,
1950 .ptb-news__read-news .news-content h4 *,
1951 .ptb-news__read-news .news-content h5,
1952 .ptb-news__read-news .news-content h5 *,
1953 .ptb-news__read-news .news-content h6,
1954 .ptb-news__read-news .news-content h6 * {
1955 color: var(--color-neutral-800, #373737) !important;
1956 }
1957
1958 body.high-contrast-active .ptb-news__read-news .news-content h1,
1959 body.high-contrast-active .ptb-news__read-news .news-content h1 *,
1960 body.high-contrast-active .ptb-news__read-news .news-content h2,
1961 body.high-contrast-active .ptb-news__read-news .news-content h2 *,
1962 body.high-contrast-active .ptb-news__read-news .news-content h3,
1963 body.high-contrast-active .ptb-news__read-news .news-content h3 *,
1964 body.high-contrast-active .ptb-news__read-news .news-content h4,
1965 body.high-contrast-active .ptb-news__read-news .news-content h4 *,
1966 body.high-contrast-active .ptb-news__read-news .news-content h5,
1967 body.high-contrast-active .ptb-news__read-news .news-content h5 *,
1968 body.high-contrast-active .ptb-news__read-news .news-content h6,
1969 body.high-contrast-active .ptb-news__read-news .news-content h6 * {
1970 color: var(--text-primary-default, var(--color-neutral-100)) !important;
1971 }
1972
1973 .ptb-news__read-news .news-content h1:last-child,
1974 .ptb-news__read-news .news-content h2:last-child,
1975 .ptb-news__read-news .news-content h3:last-child,
1976 .ptb-news__read-news .news-content h4:last-child,
1977 .ptb-news__read-news .news-content h5:last-child,
1978 .ptb-news__read-news .news-content h5:last-child,
1979 .ptb-news__read-news .news-content h6:last-child,
1980 .ptb-news__read-news .news-content p:last-child {
1981 padding-bottom: 0 !important;
1982 }
1983
1984 .ptb-news__read-news .news-content h1,
1985 .ptb-news__read-news .news-content h1 * {
1986 font-size: var(--font-size-xxl) !important;
1987 line-height: var(--line-height-sm) !important;
1988 font-weight: var(--font-weight-bold) !important;
1989 font-style: var(--font-style-normal) !important;
1990 text-decoration: var(--text-decoration-none) !important;
1991 }
1992
1993 .ptb-news__read-news .news-content h2,
1994 .ptb-news__read-news .news-content h2 * {
1995
1996 font-size: var(--font-size-xl) !important;
1997 line-height: var(--line-height-sm) !important;
1998 font-weight: var(--font-weight-bold) !important;
1999 font-style: var(--font-style-normal) !important;
2000 text-decoration: var(--text-decoration-none) !important;
2001
2002 }
2003
2004 .ptb-news__read-news .news-content h2 {
2005 margin-top: 48px !important;
2006 margin-bottom: var(--space-xl, 40px) !important;
2007
2008 }
2009
2010 .ptb-news__read-news .news-content h3,
2011 .ptb-news__read-news .news-content h3 * {
2012 font-size: var(--font-size-lg) !important;
2013 line-height: var(--line-height-sm) !important;
2014 font-weight: var(--font-weight-bold) !important;
2015 font-style: var(--font-style-normal) !important;
2016 text-decoration: var(--text-decoration-none) !important;
2017 }
2018
2019 .ptb-news__read-news .news-content h3 {
2020 margin-bottom: var(--space-sm, 16px) !important;
2021 margin-top: 48px !important;
2022 }
2023
2024 .ptb-news__read-news .news-content h4,
2025 .ptb-news__read-news .news-content h4 * {
2026 font-size: var(--font-size-md) !important;
2027 line-height: var(--line-height-md) !important;
2028 font-weight: var(--font-weight-bold) !important;
2029 font-style: var(--font-style-normal) !important;
2030 text-decoration: var(--text-decoration-none) !important;
2031 }
2032
2033 .ptb-news__read-news .news-content h4 {
2034 margin-top: 48px !important;
2035 margin-bottom: var(--space-sm, 16px) !important;
2036 }
2037
2038 .ptb-news__read-news .news-content h5,
2039 .ptb-news__read-news .news-content h5 * {
2040 font-size: var(--font-size-sm) !important;
2041 line-height: var(--line-height-md) !important;
2042 font-weight: var(--font-weight-bold) !important;
2043 font-style: var(--font-style-normal) !important;
2044 text-decoration: var(--text-decoration-none) !important;
2045 }
2046
2047 .ptb-news__read-news .news-content h5 {
2048 margin-top: 48px !important;
2049 margin-bottom: var(--space-sm, 16px) !important;
2050 }
2051
2052 .ptb-news__read-news .news-content table {
2053 border-collapse: collapse;
2054 border: none;
2055 width: 100% !important;
2056 margin: var(--space-md, 24px) 0;
2057 }
2058
2059 .ptb-news__read-news .news-content table * {
2060 font-size: var(--font-size-xxs, 16px);
2061 font-style: var(--font-style-normal, normal);
2062 font-weight: var(--font-weight-regular, 400);
2063 line-height: var(--line-height-xl, 160%);
2064 color: var(--color-neutral-800, #373737);
2065 border: 0;
2066 }
2067
2068 body.high-contrast-active .ptb-news__read-news .news-content table * {
2069 color: var(--text-primary-default, var(--color-neutral-100));
2070 }
2071
2072 .ptb-news__read-news .news-content table tbody > :first-child,
2073 .ptb-news__read-news .news-content table tbody > :first-child * {
2074 font-weight: var(--font-weight-bold, 700);
2075 flex: 1 0 0;
2076 background: var(--background-Surface-level-02, #F8F8F8);
2077 }
2078
2079 body.high-contrast-active .ptb-news__read-news .news-content table tbody > :first-child,
2080 body.high-contrast-active .ptb-news__read-news .news-content table tbody > :first-child * {
2081 background: #373737;
2082 }
2083
2084 .ptb-news__read-news .news-content table tbody {
2085 display: flex;
2086 flex-direction: column;
2087 }
2088
2089 .ptb-news__read-news .news-content table tbody * {
2090 display: flex;
2091 height: 100%;
2092 align-items: center;
2093 flex: 1 0 0;
2094 }
2095
2096 .ptb-news__read-news .news-content table tbody tr * {
2097 padding: 23px var(--space-lg, 32px);
2098 }
2099
2100
2101 .ptb-news__read-news .news-content table tbody tr {
2102 border-radius: var(--border-radius-md);
2103 border: var(--border-width-hairline, 1px) solid #EEEEEE;
2104 }
2105
2106 body.high-contrast-active .ptb-news__read-news .news-content table tbody tr {
2107 border: var(--border-width-hairline, 1px) solid #525252;
2108 }
2109
2110 .ptb-news__read-news .news-content table tbody tr:not(:last-child) {
2111 border-bottom-left-radius: 0;
2112 border-bottom-right-radius: 0;
2113 }
2114
2115 .ptb-news__read-news .news-content table tbody tr:not(:first-child) {
2116 border-top-left-radius: 0;
2117 border-top-right-radius: 0;
2118 border-top: none;
2119 }
2120
2121 .ptb-news__read-news .news-content table tbody tr td:not(:last-child) {
2122 border-right: var(--border-width-hairline, 1px) solid #EEEEEE;
2123 }
2124
2125 body.high-contrast-active .ptb-news__read-news .news-content table tbody tr td:not(:last-child) {
2126 border-right: var(--border-width-hairline, 1px) solid #525252;
2127 }
2128
2129 .ptb-news__read-news .news-content table tbody tr:first-child td {
2130 border-top: var(--border-width-hairline, 1px) solid #EEEEEE;
2131 border-bottom: var(--border-width-hairline, 1px) solid #EEEEEE;
2132 }
2133
2134 body.high-contrast-active .ptb-news__read-news .news-content table tbody tr:first-child td {
2135 border-top: var(--border-width-hairline, 1px) solid #525252;
2136 border-bottom: var(--border-width-hairline, 1px) solid #525252;
2137 }
2138
2139 .ptb-news__read-news .news-content table tbody tr td:first-child {
2140 padding-left: 0;
2141 }
2142
2143 .ptb-news__read-news .news-content table tbody tr td:last-child{
2144 padding-right: 0;
2145 }
2146
2147 .ptb-news__read-news .news-content audio {
2148 display: none;
2149 }
2150
2151 .ptb-news__read-news .news-content .audio-template {
2152 display: flex;
2153 padding: var(--space-sm, 16px);
2154 align-items: center;
2155 gap: var(--space-md, 24px);
2156 align-self: stretch;
2157 border-radius: var(--border-radius-lg, 16px);
2158 border: var(--border-width-hairline, 1px) solid var(--border-color-mid);
2159 background: var(--background-card-default, #FFF);
2160 max-height: var(--size-giant, 72px);
2161 margin: 48px 0;
2162 }
2163
2164 body.high-contrast-active .ptb-news__read-news .news-content .audio-template {
2165 background: var(--background-card-default, #010101);
2166 border: var(--border-width-hairline, 1px) solid #525252;
2167 }
2168
2169 .ptb-news__read-news .news-content .audio-template .audio-button-play {
2170 display: flex;
2171 width: var(--size-xl, 40px);
2172 height: var(--size-xl, 40px);
2173 justify-content: center;
2174 align-items: center;
2175 flex-grow: 0;
2176 flex-shrink: 0;
2177 cursor: pointer;
2178 }
2179
2180 body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-button-play .audio-play-icon,
2181 body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-button-play .audio-pause-icon {
2182 fill: #FFFFFF;
2183 }
2184
2185 body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-button-play .audio-play-icon path,
2186 body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-button-play .audio-pause-icon path {
2187 fill: #010101;
2188 }
2189
2190 .ptb-news__read-news .news-content .audio-template.audio-pause .audio-button-play .audio-play-icon {
2191 display: block;
2192 }
2193
2194 .ptb-news__read-news .news-content .audio-template.audio-pause .audio-button-play .audio-pause-icon {
2195 display: none;
2196 }
2197
2198 .ptb-news__read-news .news-content .audio-template.audio-play .audio-button-play .audio-play-icon {
2199 display: none;
2200 }
2201
2202 .ptb-news__read-news .news-content .audio-template.audio-play .audio-button-play .audio-pause-icon {
2203 display: block;
2204 }
2205
2206 .ptb-news__read-news .news-content .audio-template .audio-sondwave {
2207 display: flex;
2208 flex-direction: column;
2209 align-items: flex-start;
2210 gap: var(--space-xxs, 8px);
2211 flex: 1 0 0;
2212 height: 100%;
2213 flex-grow: 1;
2214 flex-shrink: 1;
2215 }
2216
2217 .ptb-news__read-news .news-content .audio-template .audio-sondwave line {
2218 stroke: #008542;
2219 }
2220
2221 .ptb-news__read-news .news-content .audio-template .audio-sondwave line.line-active {
2222 stroke: #90EE90;
2223 }
2224
2225 body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-sondwave line {
2226 stroke: #E4F7E8;
2227 }
2228
2229 body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-sondwave line.line-active {
2230 stroke: #666666;
2231 }
2232
2233 .ptb-news__read-news .news-content .audio-template .audio-sondwave .audio-sondwave-mobile {
2234 display: none;
2235 }
2236
2237 .ptb-news__read-news .news-content .audio-template .audio-time {
2238 display: flex;
2239 flex-direction: column;
2240 align-items: flex-start;
2241 gap: var(--space-xxs, 8px);
2242 flex: 1 0 0;
2243 color: var(--text-primary-accent, #008542);
2244 text-align: center;
2245 font-family: var(--font-family-base);
2246 line-height: 124% !important;
2247 flex-grow: 0;
2248 flex-shrink: 0;
2249 }
2250
2251 body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-time {
2252 color: var(--text-primary-accent, #E4F7E8);
2253 }
2254
2255 .ptb-news__read-news .news-content .audio-template .audio-button-mute {
2256 width: var(--size-lg, 32px);
2257 height: var(--size-lg, 32px);
2258 flex-grow: 0;
2259 flex-shrink: 0;
2260 cursor: pointer;
2261 }
2262
2263 body.high-contrast-active .ptb-news__read-news .news-content .audio-template .audio-button-mute svg path {
2264 stroke: white;
2265 fill: none;
2266 }
2267
2268 .ptb-news__read-news .news-content .audio-template.audio-muted .audio-button-mute {
2269 opacity: 0.6;
2270 }
2271
2272
2273 @media screen and (max-width: 1023px) and (min-width: ${MAX_MOBILE_WIDTH}px) {
2274 .ptb-news__read-news .news-content > * {
2275 grid-column-start: 1;
2276 grid-column-end: 9;
2277 }
2278 }
2279
2280
2281 @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) {
2282
2283 .ptb-news__read-news .news-content * {
2284 font-size: var(--font-size-xxs, 16px);
2285 }
2286
2287
2288 .ptb-news__read-news .news-content > * {
2289 grid-column-start: 1;
2290 grid-column-end: 5;
2291 }
2292
2293
2294 .ptb-news__read-news .news-content h1,
2295 .ptb-news__read-news .news-content h1 * {
2296 font-size: var(--font-size-xl) !important;
2297 line-height: var(--line-height-sm) !important;
2298 font-weight: var(--font-weight-bold) !important;
2299 font-style: var(--font-style-normal) !important;
2300 text-decoration: var(--text-decoration-none) !important;
2301
2302 }
2303
2304 .ptb-news__read-news .news-content h2,
2305 .ptb-news__read-news .news-content h2 * {
2306 font-size: var(--font-size-lg) !important;
2307 line-height: var(--line-height-sm) !important;
2308 font-weight: var(--font-weight-bold) !important;
2309 font-style: var(--font-style-normal) !important;
2310 text-decoration: var(--text-decoration-none) !important;
2311 }
2312
2313 .ptb-news__read-news .news-content h2 {
2314 margin-bottom: var(--space-md, 24px) !important;
2315 }
2316
2317 .ptb-news__read-news .news-content h3,
2318 .ptb-news__read-news .news-content h3 * {
2319 font-size: var(--font-size-md) !important;
2320 line-height: var(--line-height-sm) !important;
2321 font-weight: var(--font-weight-bold) !important;
2322 font-style: var(--font-style-normal) !important;
2323 text-decoration: var(--text-decoration-none) !important;
2324 }
2325
2326 .ptb-news__read-news .news-content h3 {
2327 margin-top: var(--space-xxs, 8px) !important;
2328 }
2329
2330 .ptb-news__read-news .news-content h4,
2331 .ptb-news__read-news .news-content h4 * {
2332 font-size: var(--font-size-sm) !important;
2333 line-height: var(--line-height-md) !important;
2334 font-weight: var(--font-weight-bold) !important;
2335 font-style: var(--font-style-normal) !important;
2336 text-decoration: var(--text-decoration-none) !important;
2337 }
2338
2339 .ptb-news__read-news .news-content h5,
2340 .ptb-news__read-news .news-content h5 * {
2341 font-size: var(--font-size-xs) !important;
2342 line-height: var(--line-height-md) !important;
2343 font-weight: var(--font-weight-bold) !important;
2344 font-style: var(--font-style-normal) !important;
2345 text-decoration: var(--text-decoration-none) !important;
2346 }
2347
2348 .ptb-news__read-news .news-content figure figcaption {
2349 flex-direction: column;
2350 gap: var(--space-xxs, 8px);
2351 }
2352
2353 .ptb-news__read-news .news-content figure figcaption,
2354 .ptb-news__read-news .news-content figure figcaption * {
2355 font-size: var(--font-size-micro, 12px);
2356 }
2357
2358 .ptb-news__read-news .news-content table {
2359 margin-top: var(--space-xxs, 8px);
2360 margin-bottom: var(--space-lg, 32px);
2361 }
2362
2363 .ptb-news__read-news .news-content table * {
2364 font-size: var(--font-size-micro, 12px);
2365 line-height: 19.2%;
2366 }
2367
2368 .ptb-news__read-news .news-content table tbody * {
2369 height: 43px;
2370 padding: var(--space-xs, 12px);
2371 }
2372
2373 .ptb-news__read-news .news-content .audio-template {
2374 margin-top: var(--space-xxs, 8px);
2375 margin-bottom: var(--space-lg, 32px);
2376 }
2377 }
2378
2379 @media screen and (max-width: 500px) {
2380 .ptb-news__read-news .news-content .audio-template .audio-sondwave .audio-sondwave-desktop {
2381 display: none;
2382 }
2383
2384 .ptb-news__read-news .news-content .audio-template .audio-sondwave .audio-sondwave-mobile {
2385 display: block;
2386 }
2387 }
2388 </style>
2389
2390 <style>
2391.ws-carousel p {
2392 margin: var(--space-none, 0) !important;
2393}
2394
2395.ws-carousel {
2396 display: flex;
2397 flex-direction: column;
2398 gap: var(--space-lg, 32px);
2399 margin: var(--space-big, 72px) auto;
2400}
2401
2402.ws-carousel .ws-carousel-header {
2403 display: flex;
2404 justify-content: space-between;
2405}
2406
2407.ws-carousel .ws-carousel-header .h2,
2408.ws-carousel .ws-carousel-header h2 {
2409 color: var(--color-neutral-800, #373737) !important;
2410 font-family: var(--font-family-base), "Petrobras Sans" !important;
2411 line-height: 100% !important;
2412 margin: var(--space-none, 0) ! important;
2413}
2414
2415.ws-carousel .ws-carousel-header .nav-buttons {
2416 display: flex;
2417 justify-content: space-between;
2418 gap: var(--space-xxs, 8px);
2419}
2420
2421.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow.left-arrow {
2422 transform: scaleX(-1);
2423}
2424
2425.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow {
2426 cursor: pointer;
2427}
2428
2429.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow.inactive {
2430 cursor: not-allowed;
2431}
2432
2433
2434.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow path {
2435 transition: stroke 0.3s ease;
2436}
2437
2438.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow.inactive path {
2439 stroke: #bababa;
2440}
2441
2442.ws-carousel .ws-carousel-header .nav-buttons .nav-arrow.active path {
2443 stroke: #008542;
2444}
2445
2446
2447.ws-carousel .ws-carousel-body {
2448 overflow-x: scroll;
2449 -ms-overflow-style: none;
2450 -scrollbar-width: none;
2451}
2452
2453.ws-carousel .ws-carousel-body::-webkit-scrollbar {
2454 display: none;
2455}
2456
2457.ws-carousel .ws-carousel-body .ws-container {
2458 display: flex;
2459 gap: var(--space-lg, 32px);
2460}
2461
2462.ws-carousel .ws-carousel-body .ws-container .ws-item {
2463 min-width: 300px;
2464 max-width: 300px;
2465 min-height: 400px;
2466 max-height: 400px;
2467 position: relative;
2468 overflow: hidden;
2469 border-radius: var(--border-radius-lg);
2470 box-shadow: 0px 12px 60px -10px rgba(145, 147, 149, 0.12);
2471}
2472
2473.ws-carousel .ws-carousel-body .ws-container .ws-item:hover {
2474 cursor: pointer;
2475}
2476
2477.ws-carousel .ws-carousel-body .ws-container .ws-item .ws-image {
2478 position: absolute;
2479 top: 50%;
2480 left: 50%;
2481 transform: translate(-50%, -50%);
2482 height: 100%;
2483}
2484
2485.ws-carousel .ws-carousel-body .ws-container .ws-item .ws-overlay {
2486 position: absolute;
2487 background: linear-gradient(180deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 100%);
2488 width: 100%;
2489 height: 100%;
2490}
2491
2492.ws-carousel .ws-carousel-body .ws-container .ws-item .ws-label {
2493 position: absolute;
2494 margin: var(--space-md, 24px) 0 0 var(--space-md, 24px);
2495 border-radius: var(--border-radius-pill, 100%);
2496 background: linear-gradient(0deg, var(--Background-Surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 0%, var(--Background-Surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 100%), var(--Default-sup-green-water, #006B65);
2497 box-shadow: 0px 2px 6px 0px rgba(0, 178, 169, 0.10);
2498 padding: var(--space-micro, 2px) var(--space-xs, 12px);
2499
2500 color: var(--Default-sup-green-water, #006B65);
2501 font-family: var(--font-family-base), "Petrobras Sans";
2502 font-size: var(--font-size-xxxs, 12px);
2503 font-style: normal;
2504 font-weight: var(--font-weight-regular, 400);
2505 line-height: var(--line-height-sm, 120%);
2506 color: #006B65;
2507}
2508
2509.ws-carousel .ws-carousel-body .ws-container .ws-item .ws-content {
2510 position: relative;
2511 z-index: 1;
2512 height: 100%;
2513
2514 display: flex;
2515 padding: var(--space-lg, 32px) var(--space-md, 24px) var(--space-md, 24px) var(--space-md, 24px);
2516 flex-direction: column;
2517 justify-content: flex-end;
2518 align-items: flex-start;
2519 gap: var(--space-md, 24px);
2520}
2521
2522.ws-carousel .ws-carousel-body .ws-container .ws-item .ws-content .h5 {
2523 overflow: hidden;
2524 color: #FFF !important;
2525 text-overflow: ellipsis;
2526 margin: 0 !important;
2527 font-family: var(--font-family-base), "Petrobras Sans" !important;
2528}
2529
2530@media (max-width: 768px) {
2531
2532 .ws-carousel .ws-carousel-header .nav-buttons {
2533 gap: var(--space-micro, 12px);
2534 }
2535
2536 .ws-carousel .ws-carousel-header .nav-buttons .nav-arrow {
2537 width: 44px;
2538 height: 44px;
2539 }
2540
2541 .ws-carousel .ws-carousel-header {
2542 flex-direction: column;
2543 align-items: flex-start;
2544 gap: var(--space-lg, 32px);
2545 }
2546
2547 .ws-carousel .ws-carousel-header .h2 {
2548 font-size: var(--font-size-lg, 24px) !important;
2549 }
2550
2551 .ws-carousel .ws-carousel-body .ws-container {
2552 gap: var(--space-lg, 32px);
2553 }
2554
2555 .ws-carousel .ws-carousel-body .ws-container .ws-item {
2556 min-width: 225px;
2557 max-width: 225px;
2558 background: linear-gradient(180deg, rgba(0, 0, 0, 0.00) 0%, rgba(0, 0, 0, 0.80) 100%), url(<path-to-image>) lightgray 50% / cover no-repeat;
2559 box-shadow: 0px 12px 60px -10px rgba(145, 147, 149, 0.12);
2560 }
2561}
2562 </style>
2563
2564<#-- Exibição de um único story com naveação direto no conteúdo -->
2565<style>
2566 .stories-container * {
2567 margin: 0;
2568 padding: 0;
2569 box-sizing: border-box;
2570 }
2571
2572 .stories-container {
2573 position: relative;
2574 /*
2575 Largura das duas setas com position absolute: 64px
2576 Largura das somas margens das setas: 48px
2577
2578 */
2579 width: calc(100vw - 64px - 48px);
2580 max-width: 400px;
2581 height: auto;
2582 aspect-ratio: 59/105;
2583 border-radius: 8px;
2584 }
2585
2586 .header-container {
2587 position: absolute;
2588 top: 0;
2589 left: 0;
2590 right: 0;
2591 z-index: 3;
2592 padding: 16px 16px 0 16px;
2593 display: flex;
2594 flex-direction: column;
2595 gap: 24px;
2596 }
2597
2598 .story-header {
2599 display: flex;
2600 flex-direction: column;
2601 gap: 8px;
2602 }
2603
2604 .progress-bars {
2605 display: flex;
2606 gap: 5px;
2607 width: 100%;
2608 }
2609
2610 .progress-bar {
2611 height: 3px;
2612 background-color: rgba(255, 255, 255, 0.3);
2613 flex-grow: 1;
2614 border-radius: 3px;
2615 overflow: hidden;
2616 }
2617
2618 .story-progress {
2619 height: 100%;
2620 background-color: white;
2621 width: 0%;
2622 transition: width 0.2s linear;
2623 }
2624
2625 .story-progress.completed {
2626 width: 100% !important;
2627 }
2628
2629 .story-progress.active {
2630 animation: progress 8s linear forwards;
2631 }
2632
2633 @keyframes progress {
2634 from {
2635 width: 0%;
2636 }
2637
2638 to {
2639 width: 100%;
2640 }
2641 }
2642
2643 .story-slide {
2644 position: absolute;
2645 width: 100%;
2646 height: 100%;
2647 display: none;
2648 flex-direction: column;
2649 justify-content: center;
2650 align-items: center;
2651 color: white;
2652 overflow: hidden;
2653 border-radius: 8px;
2654 }
2655
2656 .story-slide::before {
2657 position: absolute;
2658 z-index: 2;
2659 content: '';
2660 width: 100%;
2661 height: 100%;
2662 background: linear-gradient(180deg, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0) 100%);
2663 }
2664
2665 .story-slide.active {
2666 display: flex;
2667 }
2668
2669 .story-image {
2670 width: 100%;
2671 height: 100% !important;
2672 object-fit: cover;
2673 position: absolute;
2674 top: 0;
2675 left: 0;
2676 z-index: 1;
2677 aspect-ratio: auto !important;
2678 }
2679
2680 .story-content {
2681 position: relative;
2682 z-index: 2;
2683 color: white;
2684 width: 100%;
2685 display: flex;
2686 flex-direction: column;
2687 justify-content: flex-end;
2688 height: 100%;
2689 padding: 16px 24px 64px 24px;
2690 }
2691
2692 .story-content .content-wrapper {
2693 display: flex;
2694 flex-direction: column;
2695 align-items: flex-start;
2696 gap: 24px;
2697 align-self: stretch;
2698 padding: 0 16px;
2699 }
2700
2701 .story-content .content-wrapper.no-padding {
2702 padding: 0;
2703 }
2704
2705 .story-title {
2706 display: flex;
2707 padding: 8px;
2708 flex-direction: column;
2709 align-items: flex-start;
2710 align-self: stretch;
2711 backdrop-filter: blur(3px);
2712 }
2713
2714 .story-title.button {
2715 display: none;
2716 }
2717
2718 .story-title.dark-theme,
2719 .story-description.dark-theme {
2720 background: rgba(13, 19, 16, 0.80);
2721 color: #FFF;
2722 }
2723
2724 .story-description.dark-theme p {
2725 color: #FFF !important;
2726 }
2727
2728 .story-title.light-theme,
2729 .story-description.light-theme {
2730 background: rgba(255, 255, 255, 0.90);
2731 color: #373737;
2732 }
2733
2734 .story-title.green-theme,
2735 .story-description.green-theme {
2736 background: rgba(0, 133, 66, 0.80);
2737 color: #FFF;
2738 }
2739
2740 .story-title .title-text {
2741 align-self: stretch;
2742 font-size: 24px;
2743 font-style: normal;
2744 font-weight: 700;
2745 line-height: 100%;
2746 }
2747
2748 .story-title .mischievous {
2749 color: #FDC82F;
2750 font-size: 24px;
2751 font-style: normal;
2752 font-weight: 700;
2753 line-height: 100%;
2754 width: 24px;
2755 }
2756
2757 .description-and-link {
2758 width: 100%;
2759 display: flex;
2760 flex-direction: column;
2761 gap: 8px;
2762 }
2763
2764 .story-description {
2765 padding: 8px;
2766 width: 100%;
2767 }
2768
2769 .story-description p {
2770 font-size: 16px;
2771 font-weight: 400;
2772 line-height: 120%;
2773 margin-bottom: 0;
2774 }
2775
2776 .story-description.button {
2777 padding: 0;
2778 display: flex;
2779 justify-content: center;
2780 }
2781
2782 .story-description.button p a {
2783 text-decoration: underline;
2784 font-weight: bold;
2785 }
2786
2787 .story-description.button p a {
2788 background: #FFF;
2789 width: fit-content;
2790 height: 48px;
2791 display: flex;
2792 justify-content: center;
2793 align-items: center;
2794 gap: 16px;
2795 text-decoration: none;
2796 color: #008542;
2797 border-radius: 100px;
2798 padding: 0 24px;
2799 box-shadow: 0px 4px 16px 0px #00000029;
2800 font-family: 'Petrobras Sans';
2801 font-weight: 700;
2802 font-size: 16px;
2803 line-height: 144%;
2804 letter-spacing: 0%;
2805 }
2806
2807 .story-description.button p a::after {
2808 content: '';
2809 display: inline-block;
2810 flex-shrink: 0;
2811 width: 20px;
2812 height: 20px;
2813 vertical-align: middle;
2814 background-image: url("");
2815 background-size: contain;
2816 background-repeat: no-repeat;
2817 background-position: center;
2818 }
2819
2820 .story-description a {
2821 position: relative;
2822 z-index: 3;
2823 color: #FFF;
2824 text-decoration: underline;
2825 }
2826
2827 .nav-area-container {
2828 position: absolute;
2829 top: 0;
2830 left: 0;
2831 right: 0;
2832 bottom: 0;
2833 display: flex;
2834 justify-content: space-between;
2835 align-items: center;
2836 z-index: 1;
2837 /* pointer-events: none; */
2838 }
2839
2840 .nav-area {
2841 height: 100%;
2842 width: 50%;
2843 display: flex;
2844 align-items: center;
2845 }
2846
2847 .nav-area .arrow,
2848 .nav-area .restart-icon {
2849 position: absolute;
2850 }
2851
2852 .nav-area .arrow:hover,
2853 .nav-area.next .restart-icon {
2854 cursor: pointer;
2855 }
2856
2857 .nav-area.prev .arrow {
2858 left: calc(-32px - 24px);
2859 }
2860
2861 .nav-area.next .arrow,
2862 .nav-area.next .restart-icon {
2863 right: calc(-32px - 24px);
2864 }
2865
2866 .nav-area .arrow.disabled {
2867 opacity: 0.4;
2868 }
2869
2870 .nav-area .arrow.disabled:hover {
2871 cursor: not-allowed;
2872 }
2873
2874 .nav-area .hidden {
2875 display: none;
2876 }
2877
2878 .action-buttons {
2879 display: flex;
2880 gap: 24px;
2881 justify-content: flex-end;
2882 }
2883
2884 .action-btn {
2885 background: transparent;
2886 border-radius: 50%;
2887 border: none;
2888 display: flex;
2889 align-items: center;
2890 justify-content: center;
2891 cursor: pointer;
2892 font-size: 14px;
2893 }
2894
2895 .action-btn.pause::before {
2896 content: '';
2897 display: inline-block;
2898 width: 15px;
2899 height: 18px;
2900 vertical-align: middle;
2901 background-image: url("");
2902 background-size: contain;
2903 background-repeat: no-repeat;
2904 background-position: center;
2905 }
2906
2907 .action-btn.play::before {
2908 content: '';
2909 display: inline-block;
2910 width: 18px;
2911 height: 18px;
2912 vertical-align: middle;
2913 background-image: url("");
2914 background-size: contain;
2915 background-repeat: no-repeat;
2916 background-position: center;
2917 }
2918
2919 .action-btn.share::before {
2920 content: '';
2921 display: inline-block;
2922 width: 18px;
2923 height: 18px;
2924 vertical-align: middle;
2925 background-image: url("");
2926 background-size: contain;
2927 background-repeat: no-repeat;
2928 background-position: center;
2929 }
2930
2931 @media (max-width: 768px) {
2932 .ws-carousel {
2933 margin: var(--space-lg, 32px) 0;
2934 }
2935
2936 .stories-container {
2937 /*
2938 Largura das duas setas com position absolute: 64px
2939 Largura das somas margens das setas mobile: 16px
2940 Soma das margens laterais: 48px
2941 */
2942 width: calc(100vw - 64px - 16px - 48px);
2943 }
2944
2945 .header-container {
2946 padding: 6px;
2947 }
2948
2949 .story-progress {
2950 height: 2px;
2951 }
2952
2953 .header-container,
2954 .action-buttons {
2955 gap: 12px;
2956 }
2957
2958 .action-btn.play::before,
2959 .action-btn.pause::before,
2960 .action-btn.share::before {
2961 width: 10px;
2962 height: 10px;
2963 }
2964
2965 .nav-area.prev .arrow {
2966 left: calc(-32px - 8px);
2967 }
2968
2969 .nav-area.next .arrow,
2970 .nav-area.next .restart-icon {
2971 right: calc(-32px - 8px);
2972 }
2973
2974 .story-content {
2975 padding: 16px 16px 32px 16px;
2976 }
2977
2978 .story-content .content-wrapper {
2979 padding: 0;
2980 }
2981
2982 .story-title .title-text {
2983 font-size: 16px;
2984 }
2985
2986 .story-description p,
2987 .story-description p a {
2988 font-size: 14px !important;
2989 }
2990 }
2991</style>
2992
2993<!-- Google tag (gtag.js) -->
2994<script async src="https://www.googletagmanager.com/gtag/js?id=G-9TG5WL85H3"></script>
2995<script>
2996 window.dataLayer = window.dataLayer || [];
2997 function gtag() { dataLayer.push(arguments); }
2998 gtag('js', new Date());
2999
3000 // Configuração do Google Analytics 4
3001 gtag('config', 'G-9TG5WL85H3');
3002</script>
3003
3004 <script>
3005/* CONSTANTS */
3006const PUBLISHER_LOGO_INDEX = 0;
3007const POSTER_PORTRAIT_INDEX = 1;
3008const PUBLISHER_INDEX = 2;
3009const COVER_INDEX = 3;
3010const STORIES_INDEX = 4;
3011
3012const COVER_HAS_COVER_INDEX = 0;
3013const COVER_TITLE_INDEX = 1;
3014const COVER_TEXT_INDEX = 2;
3015const COVER_IMAGE_INDEX = 3;
3016
3017const STORY_TITLE_INDEX = 0;
3018const STORY_TEXT_INDEX = 1;
3019const STORY_COLOR_THEME_INDEX = 2;
3020const STORY_IMAGE_INDEX = 3;
3021
3022const DETAILS_SVG = `<svg width="91" height="21" viewBox="0 0 91 21" fill="none" xmlns="http://www.w3.org/2000/svg"> <path d="M12.5 3.625H7.5C7.15482 3.625 6.875 3.90482 6.875 4.25V16.75C6.875 17.0952 7.15482 17.375 7.5 17.375H12.5C12.8452 17.375 13.125 17.0952 13.125 16.75V4.25C13.125 3.90482 12.8452 3.625 12.5 3.625Z" stroke="white" stroke-linecap="round" stroke-linejoin="round"/> <path d="M17.5 14.25V6.75C17.5 6.40482 17.2202 6.125 16.875 6.125H13.75C13.4048 6.125 13.125 6.40482 13.125 6.75V14.25C13.125 14.5952 13.4048 14.875 13.75 14.875H16.875C17.2202 14.875 17.5 14.5952 17.5 14.25Z" stroke="white" stroke-linecap="round" stroke-linejoin="round"/> <path d="M6.875 14.25L6.875 6.75C6.875 6.40482 6.59518 6.125 6.25 6.125H3.125C2.77982 6.125 2.5 6.40482 2.5 6.75L2.5 14.25C2.5 14.5952 2.77982 14.875 3.125 14.875H6.25C6.59518 14.875 6.875 14.5952 6.875 14.25Z" stroke="white" stroke-linecap="round" stroke-linejoin="round"/> <path d="M30.376 15.5L28.36 6.74H29.56L31.06 14.132L32.704 7.196H33.784L35.428 14.132L36.928 6.74H38.08L36.064 15.5H34.828L33.208 8.672L31.588 15.5H30.376ZM39.6543 12.836C39.6783 13.252 39.7343 13.588 39.8223 13.844C39.9183 14.092 40.0503 14.284 40.2183 14.42C40.3863 14.548 40.5863 14.636 40.8183 14.684C41.0583 14.724 41.3303 14.744 41.6343 14.744C41.9143 14.744 42.1743 14.732 42.4143 14.708C42.6543 14.684 42.8863 14.656 43.1103 14.624V15.344C42.8703 15.44 42.5943 15.512 42.2823 15.56C41.9783 15.616 41.6623 15.644 41.3343 15.644C40.3343 15.644 39.6183 15.388 39.1863 14.876C38.7623 14.356 38.5503 13.584 38.5503 12.56C38.5503 11.456 38.7663 10.652 39.1983 10.148C39.6383 9.636 40.2703 9.38 41.0943 9.38C41.5183 9.38 41.8783 9.448 42.1743 9.584C42.4703 9.712 42.7103 9.908 42.8943 10.172C43.0783 10.428 43.2103 10.744 43.2903 11.12C43.3703 11.496 43.4103 11.928 43.4103 12.416V12.836H39.6543ZM42.3543 12.056C42.3543 11.424 42.2583 10.968 42.0663 10.688C41.8823 10.4 41.5543 10.256 41.0823 10.256C40.5703 10.256 40.2103 10.412 40.0023 10.724C39.7943 11.028 39.6743 11.472 39.6423 12.056H42.3543ZM44.9427 15.5V6.74H46.0467V10.1C46.2147 9.916 46.4347 9.752 46.7067 9.608C46.9867 9.456 47.3667 9.38 47.8467 9.38C48.6467 9.38 49.2387 9.652 49.6227 10.196C50.0067 10.74 50.1987 11.496 50.1987 12.464C50.1987 13.512 49.9827 14.304 49.5507 14.84C49.1267 15.376 48.5067 15.644 47.6907 15.644C47.2347 15.644 46.8707 15.572 46.5987 15.428C46.3347 15.284 46.1107 15.096 45.9267 14.864L45.8427 15.5H44.9427ZM46.0227 12.944C46.0227 13.28 46.0627 13.56 46.1427 13.784C46.2227 14.008 46.3307 14.192 46.4667 14.336C46.6107 14.472 46.7747 14.572 46.9587 14.636C47.1507 14.692 47.3547 14.72 47.5707 14.72C48.0587 14.72 48.4267 14.556 48.6747 14.228C48.9307 13.9 49.0587 13.332 49.0587 12.524C49.0587 12.092 49.0227 11.736 48.9507 11.456C48.8867 11.168 48.7907 10.94 48.6627 10.772C48.5347 10.604 48.3747 10.484 48.1827 10.412C47.9987 10.34 47.7907 10.304 47.5587 10.304C47.3347 10.304 47.1267 10.332 46.9347 10.388C46.7507 10.444 46.5907 10.54 46.4547 10.676C46.3187 10.804 46.2107 10.98 46.1307 11.204C46.0587 11.42 46.0227 11.692 46.0227 12.02V12.944ZM54.1271 14.36C54.4711 14.424 54.8431 14.48 55.2431 14.528C55.6431 14.576 56.0231 14.6 56.3831 14.6C56.6791 14.6 56.9431 14.584 57.1751 14.552C57.4071 14.512 57.6031 14.436 57.7631 14.324C57.9231 14.212 58.0431 14.056 58.1231 13.856C58.2111 13.648 58.2551 13.38 58.2551 13.052C58.2551 12.796 58.2271 12.588 58.1711 12.428C58.1151 12.26 58.0191 12.124 57.8831 12.02C57.7551 11.916 57.5831 11.832 57.3671 11.768C57.1511 11.696 56.8871 11.624 56.5751 11.552L56.2151 11.468C55.8951 11.396 55.5991 11.308 55.3271 11.204C55.0631 11.092 54.8351 10.948 54.6431 10.772C54.4511 10.588 54.2991 10.364 54.1871 10.1C54.0831 9.836 54.0311 9.508 54.0311 9.116C54.0311 8.292 54.2711 7.668 54.7511 7.244C55.2391 6.82 55.9551 6.608 56.8991 6.608C57.3391 6.608 57.7471 6.648 58.1231 6.728C58.5071 6.808 58.8431 6.904 59.1311 7.016V7.82C58.8351 7.78 58.4951 7.736 58.1111 7.688C57.7351 7.64 57.3671 7.616 57.0071 7.616C56.7351 7.616 56.4871 7.632 56.2631 7.664C56.0391 7.696 55.8431 7.764 55.6751 7.868C55.5151 7.964 55.3911 8.104 55.3031 8.288C55.2151 8.472 55.1711 8.712 55.1711 9.008C55.1711 9.264 55.2031 9.476 55.2671 9.644C55.3391 9.804 55.4431 9.936 55.5791 10.04C55.7231 10.144 55.8951 10.232 56.0951 10.304C56.3031 10.368 56.5471 10.428 56.8271 10.484L57.2111 10.568C57.5791 10.648 57.8991 10.748 58.1711 10.868C58.4511 10.98 58.6831 11.128 58.8671 11.312C59.0511 11.496 59.1871 11.724 59.2751 11.996C59.3711 12.268 59.4191 12.6 59.4191 12.992C59.4191 13.464 59.3511 13.868 59.2151 14.204C59.0871 14.54 58.8991 14.816 58.6511 15.032C58.4031 15.24 58.0991 15.392 57.7391 15.488C57.3791 15.584 56.9711 15.632 56.5151 15.632C56.0031 15.632 55.5471 15.584 55.1471 15.488C54.7471 15.384 54.4071 15.276 54.1271 15.164V14.36ZM62.3096 13.52C62.3096 14.016 62.4056 14.348 62.5976 14.516C62.7896 14.676 63.0776 14.756 63.4616 14.756C63.7496 14.756 64.0096 14.744 64.2416 14.72V15.44C64.0736 15.488 63.8896 15.528 63.6896 15.56C63.4896 15.6 63.2776 15.62 63.0536 15.62C62.4056 15.62 61.9336 15.46 61.6376 15.14C61.3496 14.82 61.2056 14.296 61.2056 13.568V10.376H60.1376V9.74L61.2056 9.536V7.7H62.3096V9.524H64.1336V10.376H62.3096V13.52ZM66.6991 14.24C66.8351 14.416 66.9951 14.54 67.1791 14.612C67.3711 14.684 67.5951 14.72 67.8511 14.72C68.0991 14.72 68.3151 14.684 68.4991 14.612C68.6911 14.54 68.8471 14.42 68.9671 14.252C69.0951 14.076 69.1911 13.848 69.2551 13.568C69.3191 13.288 69.3511 12.936 69.3511 12.512C69.3511 12.096 69.3191 11.748 69.2551 11.468C69.1911 11.18 69.0911 10.952 68.9551 10.784C68.8271 10.608 68.6671 10.484 68.4751 10.412C68.2831 10.34 68.0631 10.304 67.8151 10.304C67.5671 10.304 67.3471 10.34 67.1551 10.412C66.9711 10.484 66.8151 10.604 66.6871 10.772C66.5671 10.94 66.4751 11.168 66.4111 11.456C66.3471 11.736 66.3151 12.084 66.3151 12.5C66.3151 12.924 66.3471 13.276 66.4111 13.556C66.4751 13.836 66.5711 14.064 66.6991 14.24ZM67.8271 15.644C66.9311 15.644 66.2671 15.384 65.8351 14.864C65.4031 14.344 65.1871 13.564 65.1871 12.524C65.1871 11.476 65.4031 10.692 65.8351 10.172C66.2751 9.644 66.9471 9.38 67.8511 9.38C68.7471 9.38 69.4111 9.64 69.8431 10.16C70.2751 10.68 70.4911 11.46 70.4911 12.5C70.4911 13.548 70.2711 14.336 69.8311 14.864C69.3991 15.384 68.7311 15.644 67.8271 15.644ZM72.0247 15.5V9.524H72.9127L73.0327 10.28C73.4407 9.712 74.0447 9.428 74.8447 9.428C74.9727 9.428 75.1047 9.44 75.2407 9.464V10.376C75.1767 10.368 75.1167 10.364 75.0607 10.364C75.0047 10.364 74.9487 10.364 74.8927 10.364C74.3007 10.364 73.8567 10.504 73.5607 10.784C73.2727 11.064 73.1287 11.516 73.1287 12.14V15.5H72.0247ZM76.431 15.5V9.524H77.535V15.5H76.431ZM76.995 8.3C76.763 8.3 76.591 8.24 76.479 8.12C76.367 8 76.311 7.832 76.311 7.616C76.311 7.144 76.539 6.908 76.995 6.908C77.227 6.908 77.395 6.968 77.499 7.088C77.611 7.208 77.667 7.376 77.667 7.592C77.667 8.064 77.443 8.3 76.995 8.3ZM80.1778 12.836C80.2018 13.252 80.2578 13.588 80.3458 13.844C80.4418 14.092 80.5738 14.284 80.7418 14.42C80.9098 14.548 81.1098 14.636 81.3418 14.684C81.5818 14.724 81.8538 14.744 82.1578 14.744C82.4378 14.744 82.6978 14.732 82.9378 14.708C83.1778 14.684 83.4098 14.656 83.6338 14.624V15.344C83.3938 15.44 83.1178 15.512 82.8058 15.56C82.5018 15.616 82.1858 15.644 81.8578 15.644C80.8578 15.644 80.1418 15.388 79.7098 14.876C79.2858 14.356 79.0738 13.584 79.0738 12.56C79.0738 11.456 79.2898 10.652 79.7218 10.148C80.1618 9.636 80.7938 9.38 81.6178 9.38C82.0418 9.38 82.4018 9.448 82.6978 9.584C82.9938 9.712 83.2338 9.908 83.4178 10.172C83.6018 10.428 83.7338 10.744 83.8138 11.12C83.8938 11.496 83.9338 11.928 83.9338 12.416V12.836H80.1778ZM82.8778 12.056C82.8778 11.424 82.7818 10.968 82.5898 10.688C82.4058 10.4 82.0778 10.256 81.6058 10.256C81.0938 10.256 80.7338 10.412 80.5258 10.724C80.3178 11.028 80.1978 11.472 80.1658 12.056H82.8778ZM85.2741 14.612C85.5141 14.644 85.7901 14.672 86.1021 14.696C86.4221 14.72 86.7341 14.732 87.0381 14.732C87.2781 14.732 87.4861 14.724 87.6621 14.708C87.8461 14.684 87.9941 14.64 88.1061 14.576C88.2181 14.504 88.3021 14.408 88.3581 14.288C88.4141 14.168 88.4421 14.012 88.4421 13.82C88.4421 13.66 88.4221 13.532 88.3821 13.436C88.3421 13.332 88.2741 13.248 88.1781 13.184C88.0901 13.12 87.9661 13.072 87.8061 13.04C87.6541 13 87.4621 12.964 87.2301 12.932L86.8341 12.872C86.6181 12.84 86.4101 12.792 86.2101 12.728C86.0101 12.656 85.8341 12.56 85.6821 12.44C85.5381 12.312 85.4181 12.148 85.3221 11.948C85.2341 11.74 85.1901 11.48 85.1901 11.168C85.1901 10.848 85.2421 10.576 85.3461 10.352C85.4501 10.128 85.5981 9.944 85.7901 9.8C85.9821 9.656 86.2101 9.552 86.4741 9.488C86.7461 9.424 87.0461 9.392 87.3741 9.392C87.7341 9.392 88.0621 9.42 88.3581 9.476C88.6621 9.524 88.9501 9.592 89.2221 9.68V10.388C88.9901 10.364 88.7301 10.34 88.4421 10.316C88.1621 10.292 87.8701 10.28 87.5661 10.28C87.3581 10.28 87.1701 10.288 87.0021 10.304C86.8341 10.32 86.6901 10.36 86.5701 10.424C86.4501 10.48 86.3541 10.564 86.2821 10.676C86.2181 10.78 86.1861 10.928 86.1861 11.12C86.1861 11.272 86.2061 11.396 86.2461 11.492C86.2941 11.58 86.3621 11.656 86.4501 11.72C86.5461 11.776 86.6661 11.82 86.8101 11.852C86.9541 11.884 87.1301 11.916 87.3381 11.948L87.6621 11.996C87.9421 12.036 88.1941 12.092 88.4181 12.164C88.6421 12.236 88.8301 12.34 88.9821 12.476C89.1421 12.604 89.2621 12.772 89.3421 12.98C89.4301 13.188 89.4741 13.452 89.4741 13.772C89.4741 14.436 89.2861 14.912 88.9101 15.2C88.5341 15.488 88.0141 15.632 87.3501 15.632C87.1501 15.632 86.9501 15.62 86.7501 15.596C86.5501 15.58 86.3581 15.556 86.1741 15.524C85.9901 15.492 85.8181 15.46 85.6581 15.428C85.5061 15.388 85.3781 15.352 85.2741 15.32V14.612Z" fill="white"/> </svg`;
3023
3024/* Função para criar formatar object*/
3025const createStoryObject = (objectContent) => {
3026 const hasCover = Boolean(
3027 objectContent.contentFields[COVER_INDEX].nestedContentFields[
3028 COVER_HAS_COVER_INDEX
3029 ].contentFieldValue.data
3030 );
3031 return {
3032 category: objectContent.taxonomyCategoryBriefs[0].taxonomyCategoryName,
3033 publisherLogoSrc:
3034 objectContent.contentFields[PUBLISHER_LOGO_INDEX].contentFieldValue.data,
3035 posterPortraitSrc:
3036 objectContent.contentFields[POSTER_PORTRAIT_INDEX].contentFieldValue.data,
3037 publisher:
3038 objectContent.contentFields[PUBLISHER_INDEX].contentFieldValue.data,
3039 friendlyUrlPath: objectContent.friendlyUrlPath,
3040 cover: {
3041 image: Boolean(
3042 objectContent.contentFields[COVER_INDEX].nestedContentFields[
3043 COVER_HAS_COVER_INDEX
3044 ].contentFieldValue.data
3045 ),
3046 title:
3047 objectContent.contentFields[COVER_INDEX].nestedContentFields[
3048 COVER_TITLE_INDEX
3049 ].contentFieldValue.data,
3050 description:
3051 objectContent.contentFields[COVER_INDEX].nestedContentFields[
3052 COVER_TEXT_INDEX
3053 ].contentFieldValue.data,
3054 imageUrl:
3055 objectContent.contentFields[COVER_INDEX].nestedContentFields[
3056 COVER_IMAGE_INDEX
3057 ].contentFieldValue.image?.contentUrl || null,
3058 imageAlt:
3059 objectContent.contentFields[COVER_INDEX].nestedContentFields[
3060 COVER_IMAGE_INDEX
3061 ].contentFieldValue.image?.description || null,
3062 },
3063 stories: objectContent.contentFields
3064 .slice(STORIES_INDEX)
3065 .map((contentField) => {
3066 return {
3067 title:
3068 contentField.nestedContentFields[STORY_TITLE_INDEX]
3069 ?.contentFieldValue?.data ?? null,
3070 description:
3071 contentField.nestedContentFields[STORY_TEXT_INDEX]?.contentFieldValue
3072 .data ?? null,
3073 colorTheme:
3074 contentField.nestedContentFields[STORY_COLOR_THEME_INDEX]
3075 ?.contentFieldValue?.value ?? null,
3076 imageUrl:
3077 contentField.nestedContentFields[STORY_IMAGE_INDEX]
3078 ?.contentFieldValue?.image?.contentUrl ?? null,
3079 imageAlt:
3080 contentField.nestedContentFields[STORY_IMAGE_INDEX]
3081 ?.contentFieldValue?.image?.description ?? null,
3082 };
3083 }),
3084 };
3085};
3086
3087/* Renderiza os cards */
3088const storyCardFrom = (storyData) => {
3089 const storyCard = document.createElement("div");
3090 storyCard.classList.add("ws-item");
3091
3092 let displayPageUrl;
3093 if (`${themeDisplay.getURLPortal()}`.includes('webserver')) {
3094 displayPageUrl = `${themeDisplay.getURLPortal()}/web/nossa-energia/w/` + storyData.friendlyUrlPath;
3095 } else {
3096 displayPageUrl = `${themeDisplay.getURLPortal()}/w/` + storyData.friendlyUrlPath;
3097 }
3098
3099 storyCard.addEventListener("click", (e) => {
3100 window.location.href = displayPageUrl;
3101 });
3102
3103 const image = document.createElement("img");
3104 image.classList.add("ws-image");
3105 image.src = storyData.cover.imageUrl
3106 ? storyData.cover.imageUrl
3107 : storyData.stories[0].imageUrl;
3108 image.alt = storyData.cover.imageAlt
3109 ? storyData.cover.imageAlt
3110 : storyData.stories[0].imageAlt;
3111
3112 storyCard.appendChild(image);
3113
3114 const overlay = document.createElement("div");
3115 overlay.classList.add("ws-overlay");
3116 storyCard.appendChild(overlay);
3117
3118 const label = document.createElement("span");
3119 label.classList.add("ws-label");
3120 label.dataset.category = storyData.category;
3121 label.classList.add((storyData.category || "Categoria").toLowerCase().replace(" ", '-'));
3122 label.textContent = storyData.category || "Categoria";
3123 storyCard.appendChild(label);
3124
3125 const content = document.createElement("div");
3126 content.classList.add("ws-content");
3127
3128 const title = document.createElement("h5");
3129 title.classList.add("h5")
3130 title.textContent = storyData.cover.title || "Título do Card";
3131 content.appendChild(title);
3132
3133 const details = document.createElement("div");
3134 details.classList.add("ws-details");
3135
3136 details.innerHTML = DETAILS_SVG || `<svg>...</svg>`;
3137 content.appendChild(details);
3138
3139 storyCard.appendChild(content);
3140
3141 return storyCard;
3142};
3143
3144/* Renderiza cores */
3145
3146const getCategoriesColorsStyles = async () => {
3147 //
3148 const urlToFetchToGetWebStoriesCategoriesColor = `/o/headless-admin-taxonomy/v1.0/taxonomy-vocabularies/31841266/taxonomy-categories?fields=name%2CtaxonomyCategoryProperties`;
3149
3150 return fetch(urlToFetchToGetWebStoriesCategoriesColor, {
3151 method: "GET",
3152 headers: {
3153 accept: "application/json",
3154 "x-csrf-token": Liferay.authToken,
3155 },
3156 })
3157 .then((response) => {
3158 if (response.status === 200) {
3159 return response.json();
3160 } else {
3161 throw new Error("Erro interno. Por favor tente mais tarde.");
3162 }
3163 })
3164 .then((data) => {
3165 const styleTag = document.createElement('style');
3166 styleTag.id= 'webstories-carousel-labels';
3167
3168 let styleContent = ``;
3169
3170 data.items.forEach(item => {
3171 let textColor = item.taxonomyCategoryProperties.find(taxonomtProp => taxonomtProp.key === "Cor do Texto")?.value;
3172 let textHighContrastColor = item.taxonomyCategoryProperties.find(taxonomtProp => taxonomtProp.key === "Cor do Texto em Alto Contraste")?.value;
3173
3174 if (textColor != undefined) {
3175 styleContent = styleContent + `
3176 .ws-carousel .ws-carousel-body .ws-container .ws-item .ws-label[data-category="` + item.name + `"] {
3177 color: #` + textColor + `;
3178 }
3179 `
3180 }
3181
3182 if (textHighContrastColor != undefined) {
3183 styleContent = styleContent + `
3184 body.high-contrast .ws-carousel .ws-carousel-body .ws-container .ws-item .ws-label[data-category="` + item.name + `"] {
3185 color: #` + textHighContrastColor + `;
3186 }
3187 `
3188 }
3189 });
3190
3191 styleTag.textContent = styleContent;
3192
3193 document.head.appendChild(styleTag);
3194 });
3195};
3196
3197getCategoriesColorsStyles();
3198
3199/* Renderiza os itens */
3200const renderItems = (carouselId, webStoriesObjects) => {
3201 const carouselElement = document.querySelector(`#` + carouselId);
3202 const carouselContainer = carouselElement.querySelector(`.ws-container`);
3203 const carouselBody = carouselElement.querySelector(".ws-carousel-body");
3204 const navButtons = carouselElement.querySelector(".nav-buttons");
3205 const leftArrow = navButtons.querySelector(".left-arrow");
3206 const rightArrow = navButtons.querySelector(".right-arrow");
3207
3208 // Adiciona Cards
3209 webStoriesObjects.forEach((storyObject, index) => {
3210 const storyCard = storyCardFrom(storyObject);
3211 storyCard.dataset.index = index;
3212 carouselContainer.appendChild(storyCard);
3213 });
3214
3215 // Altera o Layout
3216 function updateLayout() {
3217 if (webStoriesObjects.length < 3) {
3218 if (window.matchMedia("(min-width: 769px)").matches) {
3219 carouselContainer.style.justifyContent = "center";
3220 navButtons.style.display = "none";
3221 } else {
3222 carouselContainer.style.justifyContent = "flex-start";
3223 navButtons.style.display = "flex";
3224 }
3225 } else {
3226 carouselContainer.style.justifyContent = "";
3227 carouselContainer.style.gap = window.matchMedia("(max-width: 768px)")
3228 .matches
3229 ? "32px"
3230 : "16px";
3231 navButtons.style.display = "";
3232 }
3233 }
3234 updateLayout();
3235 window.addEventListener("resize", updateLayout);
3236
3237 // Configura Scroll das setas
3238 leftArrow.addEventListener("click", () => {
3239 const items = carouselBody.querySelectorAll(".ws-item");
3240 const gap = window.matchMedia("(max-width: 768px)").matches ? 32 : 16;
3241 const pageSize = items[0].offsetWidth + gap;
3242 const currentScroll = carouselBody.scrollLeft;
3243 const currentPageReal = carouselBody.scrollLeft / pageSize;
3244 const currentPage = parseInt(currentPageReal);
3245 const rest = currentPage - currentPageReal;
3246 const nextPage = rest !== 0 ? currentPage : currentPage - 1;
3247 carouselBody.scrollLeft = nextPage * pageSize;
3248 });
3249
3250 rightArrow.addEventListener("click", () => {
3251 const gap = window.matchMedia("(max-width: 768px)").matches ? 32 : 16;
3252 const items = carouselBody.querySelectorAll(".ws-item");
3253 carouselBody.scrollLeft += items[0].offsetWidth + gap;
3254 });
3255
3256 const updateArrows = () => {
3257 const scrollLeft = carouselBody.scrollLeft;
3258 const maxScrollLeft = carouselBody.scrollWidth - carouselBody.clientWidth;
3259
3260 // Regra 1: A seta esquerda fica cinza se scrollLeft for 0
3261 if (scrollLeft === 0) {
3262 leftArrow.classList.remove("active");
3263 leftArrow.classList.add("inactive");
3264 } else {
3265 leftArrow.classList.remove("inactive");
3266 leftArrow.classList.add("active");
3267 }
3268
3269 // Regra 2: A seta direita fica cinza se o scroll for máximo
3270 if (scrollLeft >= maxScrollLeft) {
3271 rightArrow.classList.remove("active");
3272 rightArrow.classList.add("inactive");
3273 } else {
3274 rightArrow.classList.remove("inactive");
3275 rightArrow.classList.add("active");
3276 }
3277 };
3278
3279 carouselBody.addEventListener("scroll", updateArrows);
3280};
3281
3282/* Fetch Things */
3283async function getWebStoriesDataSectionFromNews(webContentId) {
3284 const ID_INDEX = 0;
3285 const WEB_STORIES_STRUCTURED_CONTENT_INDEX_START_AT = 2;
3286 const urlToFetchToGetWebStoriesGroup =
3287 `/o/headless-delivery/v1.0/structured-contents/` +
3288 webContentId +
3289 `?fields=contentFields`;
3290
3291 return fetch(urlToFetchToGetWebStoriesGroup, {
3292 method: "GET",
3293 headers: {
3294 accept: "application/json",
3295 "x-csrf-token": Liferay.authToken,
3296 },
3297 })
3298 .then((response) => {
3299 if (response.status === 200) {
3300 return response.json();
3301 } else {
3302 throw new Error("Erro interno. Por favor tente mais tarde.");
3303 }
3304 })
3305 .then((data) => {
3306 const webStoriesGroups = Array.from(data.contentFields).filter(
3307 (contentField) => contentField.label === "Web Stories"
3308 );
3309
3310 const webStoriesDataMapped = webStoriesGroups.map((webStoryGroup) => {
3311 const webStoryGroupId =
3312 webStoryGroup.nestedContentFields[ID_INDEX].contentFieldValue.data;
3313 const webStoriesStrucutredContentNodes =
3314 webStoryGroup.nestedContentFields.slice(
3315 WEB_STORIES_STRUCTURED_CONTENT_INDEX_START_AT
3316 );
3317 const webStoriesIds = Array.from(webStoriesStrucutredContentNodes).map(
3318 (webStoryNode) => {
3319 const webStoryId =
3320 webStoryNode.contentFieldValue.structuredContentLink.id;
3321 return {
3322 webStoryId: webStoryId,
3323 };
3324 }
3325 );
3326 return {
3327 webStoryGroupId: webStoryGroupId,
3328 webStoriesIds: webStoriesIds,
3329 };
3330 });
3331
3332 return webStoriesDataMapped;
3333 })
3334 .then((webStoriesDataMapped) => {
3335 // Mapeia os dados recebidos
3336 return Promise.all(
3337 webStoriesDataMapped.map(async (group) => {
3338 const updatedWebStoriesIds = await Promise.all(
3339 group.webStoriesIds.map(async (story) => {
3340 // Faz o fetch para obter os dados do webStoryId
3341 const response = await fetch(
3342 `/o/headless-delivery/v1.0/structured-contents/` +
3343 story.webStoryId,
3344 {
3345 method: "GET",
3346 headers: {
3347 accept: "application/json",
3348 "x-csrf-token": Liferay.authToken,
3349 },
3350 }
3351 );
3352 if (!response.ok) {
3353 throw new Error(
3354 `Erro ao buscar dados para webStoryId` + story.webStoryId
3355 );
3356 }
3357 const webStoryData = await response.json();
3358 return { webStoryData: webStoryData };
3359 })
3360 );
3361
3362 // Retorna o objeto transformado
3363 return {
3364 webStoryGroupId: group.webStoryGroupId,
3365 webStoriesData: updatedWebStoriesIds,
3366 };
3367 })
3368 );
3369 })
3370 .then((webStoriesDataFetched) => {
3371 return webStoriesDataFetched.map((data) => {
3372 return {
3373 webStoryGroupId: data.webStoryGroupId,
3374 webStoryObjects: data.webStoriesData.map((data) =>
3375 createStoryObject(data.webStoryData)
3376 ),
3377 };
3378 });
3379 })
3380 .catch((error) => {
3381 console.error("Erro ao buscar coleção: ", error);
3382 });
3383}
3384
3385async function getWebStoriesData(webStoriesIds) {
3386 // Mapeia os IDs para criar um array de promessas
3387 const fetchPromises = webStoriesIds.map((webStoryId) => {
3388 //const urlToFetch = `/o/headless-delivery/v1.0/structured-contents/` + webStoryId + `?fields=contentFields`;
3389 const urlToFetch =
3390 `/o/headless-delivery/v1.0/structured-contents/` +
3391 webStoryId +
3392 `?fields=contentFields%2CtaxonomyCategoryBriefs`;
3393 return fetch(urlToFetch, {
3394 method: "GET",
3395 headers: {
3396 accept: "application/json",
3397 "x-csrf-token": Liferay.authToken,
3398 },
3399 }).then((response) => {
3400 if (!response.ok) {
3401 throw new Error(`Erro ao buscar ID`);
3402 }
3403 return response.json(); // Transforma a resposta em JSON
3404 });
3405 });
3406
3407 // Aguarda todas as promessas e preserva a ordem
3408 try {
3409 const results = await Promise.all(fetchPromises);
3410 return results; // Retorna os resultados em ordem
3411 } catch (error) {
3412 console.error("Erro ao buscar Web Stories:", error);
3413 throw error; // Relança o erro para tratamento posterior
3414 }
3415}
3416
3417<#noparse>
3418const scriptForStoryInNews = (storyData, containerId) => {
3419
3420 storyData.stories = storyData.stories.filter(story => story.imageUrl !== null)
3421
3422 const storiesContainer = document.getElementById(`stories-container-${containerId}`);
3423 const prevArrow = storiesContainer.querySelector('.nav-area.prev svg.arrow');
3424 const nextArrow = storiesContainer.querySelector('.nav-area.next svg.arrow');
3425 const restartIcon = storiesContainer.querySelector('.nav-area.next svg.restart-icon');
3426 const progressBars = storiesContainer.querySelector('.progress-bars');
3427 const pauseBtn = storiesContainer.querySelector('.pause-btn');
3428 const shareBtn = storiesContainer.querySelector('.share-btn');
3429
3430 let currentStoryIndex = 0;
3431 let progressTimeout;
3432 let touchStartX = 0;
3433 let touchEndX = 0;
3434 let isPaused = false;
3435 let viewedStories = new Set();
3436 let progressStartTime = 0;
3437 let remainingTime = 8000;
3438
3439 // Tagueamento com Google Analytics
3440 const trackStoryPageView = (pageId) => {
3441 gtag("event", `web_story_page_view_${pageId}`, {
3442 story_title: document.title,
3443 canonical_url: window.location.href,
3444 source_url: document.referrer
3445 });
3446 }
3447
3448 // Cria slides dos stories
3449 function createStorySlides() {
3450 // Cria barras de progresso
3451 storyData.stories.forEach((story, index) => {
3452 const progressContainer = document.createElement('div');
3453 progressContainer.className = 'progress-bar';
3454 progressContainer.dataset.index = index;
3455
3456 const progress = document.createElement('div');
3457 progress.className = 'story-progress';
3458 progressContainer.appendChild(progress);
3459
3460 progressBars.appendChild(progressContainer);
3461 });
3462
3463 // Cria slides
3464 storyData.stories.forEach((story, index) => {
3465 const slide = document.createElement('div');
3466 slide.className = `story-slide ${index === 0 ? 'active' : ''}`;
3467 slide.dataset.index = index;
3468
3469 let imageHtml = '';
3470 if (story.imageUrl) {
3471 imageHtml = `<img src="${story.imageUrl}" alt="${story.imageAlt || ''}" class="story-image" loading="lazy">`;
3472 }
3473
3474 slide.innerHTML = `
3475 ${imageHtml}
3476 <div class="story-content">
3477 <div class="content-wrapper">
3478 ${story.title && (
3479 `<div class="story-title ${story.colorTheme}">
3480 <p class="title-text">${story.title}</p>
3481 <div class="mischievous">—</div>
3482 </div>`
3483 )}
3484 ${story.description && `<div class="story-description description-text ${story.colorTheme}">${story.description}</div>`}
3485 </div>
3486 </div>
3487 `;
3488 storiesContainer.insertBefore(slide, storiesContainer.querySelector('.nav-area-container'));
3489 });
3490
3491 updateArrows();
3492 updateProgressBars();
3493 startProgressBar();
3494 }
3495
3496 // Atualiza o estado das setas de navegação
3497 function updateArrows() {
3498 // Seta anterior
3499 if (currentStoryIndex === 0) {
3500 prevArrow.classList.add('disabled');
3501 } else {
3502 prevArrow.classList.remove('disabled');
3503 }
3504
3505 // Próxima seta
3506 if (currentStoryIndex === storyData.stories.length - 1) {
3507 nextArrow.classList.add('hidden');
3508 restartIcon.classList.remove('hidden');
3509 } else {
3510 nextArrow.classList.remove('hidden');
3511 restartIcon.classList.add('hidden');
3512 }
3513 }
3514
3515 // Atualiza as barras de progresso conforme navegação
3516 function updateProgressBars() {
3517 const allProgressBars = storiesContainer.querySelectorAll('.progress-bar .story-progress');
3518
3519 allProgressBars.forEach((bar, index) => {
3520 bar.classList.remove('completed', 'active');
3521 bar.style.width = '0%';
3522 bar.style.animation = 'none';
3523
3524 if (index < currentStoryIndex) {
3525 // Stories já vistos - barra completa
3526 bar.classList.add('completed');
3527 bar.style.width = '100%';
3528 } else if (index === currentStoryIndex) {
3529 // Story atual - barra em progresso
3530 bar.classList.add('active');
3531 } else {
3532 // Stories não vistos - barra vazia
3533 bar.style.width = '0%';
3534 }
3535 });
3536 }
3537
3538 function nextStory() {
3539 if (currentStoryIndex < storyData.stories.length - 1) {
3540 viewedStories.add(currentStoryIndex);
3541 goToStory(currentStoryIndex + 1);
3542 }
3543 }
3544
3545 function prevStory() {
3546 if (currentStoryIndex > 0) {
3547 viewedStories.delete(currentStoryIndex);
3548 goToStory(currentStoryIndex - 1);
3549 }
3550 }
3551
3552 function goToStory(index) {
3553 // Pausa a animação atual
3554 clearTimeout(progressTimeout);
3555
3556 storiesContainer.querySelector('.story-slide.active').classList.remove('active');
3557 currentStoryIndex = index;
3558 storiesContainer.querySelector(`.story-slide[data-index="${index}"]`).classList.add('active');
3559
3560 updateArrows();
3561 updateProgressBars();
3562
3563 isPaused = false;
3564 pauseBtn.classList.replace('play', 'pause');
3565 startProgressBar();
3566 }
3567
3568 function startProgressBar() {
3569 const currentProgressBar = storiesContainer.querySelector(`.progress-bar[data-index="${currentStoryIndex}"] .story-progress`);
3570
3571 // Resetar e iniciar animação
3572 currentProgressBar.style.animation = 'none';
3573 currentProgressBar.offsetHeight; // Trigger reflow
3574 currentProgressBar.style.animation = 'progress 8s linear forwards';
3575
3576 progressStartTime = Date.now();
3577
3578 progressTimeout = setTimeout(() => {
3579 nextStory();
3580 }, remainingTime);
3581 }
3582
3583 // Pausar/continuar story
3584 function togglePause() {
3585 isPaused = !isPaused;
3586
3587 const currentProgressBar = storiesContainer.querySelector(`.progress-bar[data-index="${currentStoryIndex}"] .story-progress`);
3588
3589 if (isPaused) {
3590 // Pausar
3591 currentProgressBar.style.animationPlayState = 'paused';
3592 clearTimeout(progressTimeout);
3593
3594 // Calcular tempo restante
3595 const elapsed = Date.now() - progressStartTime;
3596 remainingTime = Math.max(0, 8000 - elapsed);
3597
3598 pauseBtn.classList.remove('pause');
3599 pauseBtn.classList.add('play');
3600 } else {
3601 // Retomar
3602 currentProgressBar.style.animationPlayState = 'running';
3603 pauseBtn.classList.remove('play');
3604 pauseBtn.classList.add('pause');
3605
3606 // Reiniciar com tempo restante
3607 progressStartTime = Date.now();
3608 progressTimeout = setTimeout(() => {
3609 nextStory();
3610 }, remainingTime);
3611 }
3612 }
3613
3614 function shareStory() {
3615 const currentStory = storyData.stories[currentStoryIndex];
3616 const baseUrl = window.location.origin;
3617 let displayPageUrl;
3618 if (baseUrl.includes('webserver')) {
3619 displayPageUrl = `${baseUrl}/web/nossa-energia/w/${storyData.friendlyUrlPath}`;
3620 } else {
3621 displayPageUrl = `${baseUrl}/w/${storyData.friendlyUrlPath}`;
3622 }
3623
3624 const shareData = {
3625 title: currentStory.title || 'Story',
3626 text: currentStory.description ? currentStory.description.replace(/<[^>]*>/g, '') : '',
3627 url: displayPageUrl
3628 };
3629
3630 if (navigator.share) {
3631 navigator.share(shareData)
3632 .then(() => console.log('Compartilhado com sucesso'))
3633 .catch((error) => console.log('Erro ao compartilhar:', error));
3634 } else {
3635 // Fallback para navegadores que não suportam a API de compartilhamento
3636 alert('Compartilhar: ' + shareData.title + '\n' + shareData.text + '\n' + shareData.url);
3637 }
3638 }
3639
3640 // Event Listeners
3641 prevArrow.addEventListener('click', (e) => {
3642 e.stopPropagation();
3643 prevStory();
3644 });
3645
3646 nextArrow.addEventListener('click', (e) => {
3647 e.stopPropagation();
3648 nextStory();
3649 });
3650
3651 restartIcon.addEventListener('click', (e) => {
3652 e.stopPropagation();
3653 goToStory(0);
3654 });
3655
3656 pauseBtn.addEventListener('click', e => {
3657 e.stopPropagation();
3658 togglePause();
3659 });
3660
3661 shareBtn.addEventListener('click', e => {
3662 e.stopPropagation();
3663 shareStory();
3664 });
3665
3666 // Navegação por clique na tela
3667 storiesContainer.addEventListener('click', (e) => {
3668 const containerWidth = storiesContainer.offsetWidth;
3669 const clickX = e.clientX - storiesContainer.getBoundingClientRect().left;
3670
3671 // Se clicou na metade esquerda
3672 if (clickX < containerWidth / 2) {
3673 prevStory();
3674 }
3675 // Se clicou na metade direita
3676 else if (clickX > containerWidth / 2) {
3677 nextStory();
3678 }
3679 });
3680
3681 // Inicializar
3682 createStorySlides();
3683
3684 // Envia evento de click em links
3685 storiesContainer.addEventListener('click', e => {
3686 if (e.target.classList.contains('a')) {
3687 gtag("event", `web_story_link_click_${storyData.friendlyUrlPath}`);
3688 }
3689 });
3690
3691 const lastPage = storiesContainer.querySelector(".story-slide:last-of-type");
3692
3693 // Observa a mudança das páginas do story
3694 const observer = new MutationObserver((mutationsList) => {
3695 mutationsList.forEach((mutation) => {
3696 if (mutation.type === "attributes" && mutation.attributeName === "active") {
3697 const target = mutation.target;
3698 if (target.tagName.toLowerCase() === "story-slide" && target.hasAttribute("active")) {
3699 trackStoryPageView(target.getAttribute('data-index'));
3700 target === lastPage && gtag("event", 'web_story_complete');
3701 }
3702 }
3703 });
3704 });
3705
3706 const activePage = storiesContainer.querySelector('.story-slide.active');
3707 if (activePage && activePage.getAttribute('data-index') === '0') {
3708 trackStoryPageView(0);
3709 }
3710
3711 const pages = storiesContainer.querySelectorAll(".story-slide");
3712 pages.forEach(page => {
3713 observer.observe(page, { attributes: true, attributeFilter: ["active"] });
3714 });
3715}
3716</#noparse>
3717
3718async function fetchAndLogWebStories() {
3719 const webStoriesCarouselDataList = await getWebStoriesDataSectionFromNews(
3720 "${newsJournalArticle.getResourcePrimKey()}"
3721 );
3722
3723 webStoriesCarouselDataList.forEach((webStoriesCarouselData) => {
3724 const onlyOneWebstory = webStoriesCarouselData.webStoryObjects.length === 1;
3725
3726 if (onlyOneWebstory) {
3727 // renderiza um único story com navegação dentro da notícia
3728 const carouselElement = document.querySelector(`#` + webStoriesCarouselData.webStoryGroupId);
3729 carouselElement.style.alignItems = 'center';
3730 <#noparse>
3731 carouselElement.innerHTML =
3732 ` <div class="stories-container" id="stories-container-${webStoriesCarouselData.webStoryGroupId}">
3733 <div class="header-container">
3734 <div class="story-header">
3735 <div class="progress-bars"></div>
3736 </div>
3737 <div class="action-buttons">
3738 <button class="action-btn pause pause-btn"></button>
3739 <button class="action-btn share share-btn"></button>
3740 </div>
3741 </div>
3742
3743 <!-- Os stories serão inseridas aqui via JavaScript -->
3744
3745 <div class="nav-area-container">
3746 <div class="nav-area prev">
3747 <svg class="arrow disabled" width="32" height="32" viewBox="0 0 34 33" fill="none"
3748 xmlns="http://www.w3.org/2000/svg">
3749 <g>
3750 <path
3751 d="M1 16.5C1 7.66344 8.16344 0.5 17 0.5C25.8366 0.5 33 7.66344 33 16.5C33 25.3366 25.8366 32.5 17 32.5C8.16344 32.5 1 25.3366 1 16.5Z"
3752 stroke="#959595" />
3753 <path d="M19 21.5L14 16.5L19 11.5" stroke="#525252" stroke-width="1.5" stroke-linecap="round"
3754 stroke-linejoin="round" />
3755 </g>
3756 </svg>
3757 </div>
3758 <div class="nav-area next">
3759 <svg class="arrow" width="32" height="32" viewBox="0 0 34 33" fill="none" xmlns="http://www.w3.org/2000/svg">
3760 <path
3761 d="M1 16.5C1 7.66344 8.16344 0.5 17 0.5C25.8366 0.5 33 7.66344 33 16.5C33 25.3366 25.8366 32.5 17 32.5C8.16344 32.5 1 25.3366 1 16.5Z"
3762 stroke="#008542" />
3763 <path d="M15 11.5L20 16.5L15 21.5" stroke="#008542" stroke-width="1.5" stroke-linecap="round"
3764 stroke-linejoin="round" />
3765 </svg>
3766 <svg class="restart-icon hidden" width="32" height="32" viewBox="0 0 34 33" fill="none" xmlns="http://www.w3.org/2000/svg">
3767 <path
3768 d="M1 16.5C1 7.66344 8.16344 0.5 17 0.5C25.8366 0.5 33 7.66344 33 16.5C33 25.3366 25.8366 32.5 17 32.5C8.16344 32.5 1 25.3366 1 16.5Z"
3769 stroke="#008542" />
3770 <path
3771 d="M13.9875 14.7313H10.9875M10.9875 14.7313V11.7313M10.9875 14.7313L13.1125 12.6125C13.8816 11.8429 14.8616 11.3186 15.9286 11.106C16.9956 10.8934 18.1017 11.0021 19.1069 11.4182C20.1122 11.8344 20.9714 12.5393 21.576 13.4439C22.1805 14.3485 22.5032 15.412 22.5032 16.5C22.5032 17.588 22.1805 18.6515 21.576 19.5561C20.9714 20.4607 20.1122 21.1656 19.1069 21.5818C18.1017 21.9979 16.9956 22.1066 15.9286 21.894C14.8616 21.6814 13.8816 21.1571 13.1125 20.3875"
3772 stroke="#008542" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round" />
3773 </svg>
3774 </div>
3775 </div>
3776 </div>
3777 `;
3778 </#noparse>
3779 const singleWebstoryData = webStoriesCarouselData.webStoryObjects[0];
3780 scriptForStoryInNews(singleWebstoryData, webStoriesCarouselData.webStoryGroupId);
3781 } else {
3782 // Carrossel
3783 renderItems(
3784 webStoriesCarouselData.webStoryGroupId,
3785 webStoriesCarouselData.webStoryObjects
3786 );
3787 }
3788 });
3789}
3790
3791fetchAndLogWebStories();
3792
3793</script>
3794
3795 <script>
3796 <#assign configureLinkTab = "configureLinkTab_" + randomNumber(5)>
3797
3798 function ${configureLinkTab}() {
3799 const root = document.querySelector(".ptb-news__read-news");
3800 const newsContentElement = root.querySelector(".news-content div:first-child");
3801 const pList = newsContentElement.querySelectorAll("p");
3802 pList.forEach((pElement) => {
3803 const cont = pElement.innerHTML.trim();
3804 if (cont == "" || cont == " ") {
3805 newsContentElement?.removeChild(pElement);
3806 }
3807 });
3808 }
3809
3810 ${configureLinkTab}();
3811
3812 <#if typeOfNews?? && typeOfNews?has_content && typeOfNews == "Infográfico" >
3813
3814 function resizeMediaInfographic() {
3815 if (window.innerWidth > 1024) {
3816 const contents = document.querySelectorAll(".ptb-news__read-news .news-content p");
3817 contents.forEach((content) => {
3818 content.querySelector("img") && (content.style.gridColumn = "2 / 12");
3819 });
3820 }
3821 else {
3822 const contents = document.querySelectorAll(".ptb-news__read-news .news-content p");
3823 contents.forEach((content) => {
3824 content.querySelector("img") && (content.style.gridColumn = "");
3825 });
3826
3827 }
3828 }
3829 resizeMediaInfographic();
3830 </#if>
3831
3832
3833
3834 document.addEventListener("DOMContentLoaded", () => {
3835 const headers = document.querySelectorAll(".ptb-news__read-news .news-content h1, .ptb-news__read-news .news-content h2, .ptb-news__read-news .news-content h3, .ptb-news__read-news .news-content h4");
3836
3837 headers.forEach((header) => {
3838
3839 const currentLevel = parseInt(header.tagName.charAt(1));
3840
3841 if (currentLevel >= 1 && currentLevel <= 5) {
3842
3843 const newLevel = currentLevel + 1;
3844 const newTagName = "h" + newLevel;
3845
3846 // Criar a nova tag e transferir o conteúdo
3847 const newHeader = document.createElement(newTagName);
3848 newHeader.innerHTML = header.innerHTML;
3849
3850 // Substituir a tag antiga pela nova
3851 header.parentNode.replaceChild(newHeader, header);
3852 }
3853 });
3854
3855 <#assign typeOfNews = getFirstCategoryOfVocabulary(assetEntry, typeOfNewsVocabulary) />
3856
3857 <#if typeOfNews?? && typeOfNews?has_content && typeOfNews == "Infográfico" >
3858 resizeMediaInfographic();
3859 window.addEventListener("resize", resizeMediaInfographic);
3860 </#if>
3861 });
3862
3863 AUI().ready(()=>{
3864 const audiosContainer = document.querySelectorAll(".ptb-news__read-news .news-content .audio-content");
3865 const audioTemplate = document.querySelector(".ptb-news__read-news .news-content .audio-template");
3866
3867 audiosContainer.forEach((audioContainer)=>{
3868
3869 const audio = audioContainer.querySelector("audio");
3870 const audioInterface = audioTemplate.cloneNode(true);
3871
3872 const sondwave = audioInterface.querySelector(".audio-sondwave");
3873 const linesDesktop = audioInterface.querySelectorAll(".audio-sondwave .audio-sondwave-desktop line");
3874 const linesMobile = audioInterface.querySelectorAll(".audio-sondwave .audio-sondwave-mobile line");
3875
3876 const playPauseButtonAudioInterface = audioInterface.querySelector(".audio-button-play");
3877
3878 playPauseButtonAudioInterface.addEventListener("click", ()=>{
3879 if(audioInterface.classList.contains("audio-play")) {
3880 audioInterface.classList.replace("audio-play", "audio-pause");
3881 audio.pause();
3882 }
3883 else {
3884
3885 audiosContainer.forEach((audioContainer)=>{
3886 const otherAudio = audioContainer.querySelector("audio");
3887 const otherAudioInterface = audioContainer.querySelector(".audio-button-play");
3888 !otherAudio.paused && otherAudioInterface.click();
3889 });
3890
3891 audioInterface.classList.replace("audio-pause", "audio-play");
3892 audio.play();
3893 }
3894 });
3895
3896 const audioMuteButton = audioInterface.querySelector(".audio-button-mute");
3897
3898 audioMuteButton.addEventListener("click", ()=>{
3899 if(audioInterface.classList.contains("audio-unmuted")) {
3900 audioInterface.classList.replace("audio-unmuted", "audio-muted");
3901 audio.muted = true;
3902 }
3903 else {
3904 audioInterface.classList.replace("audio-muted", "audio-unmuted");
3905 audio.muted = false;
3906 }
3907 });
3908
3909 const audioTime = audioInterface.querySelector(".audio-time");
3910 audioTime.textContent = Math.floor(audio.duration / 60) + ":" + Math.floor(audio.duration % 60);
3911
3912
3913 audio.addEventListener("timeupdate", ()=>{
3914 let minutes = Math.floor((audio.duration - audio.currentTime) / 60);
3915 let seconds = Math.floor((audio.duration - audio.currentTime) % 60);
3916
3917 minutes = minutes < 10? "0" + minutes : minutes;
3918 seconds = seconds < 10? "0" + seconds : seconds;
3919
3920 audioTime.textContent = minutes + ":" + seconds;
3921
3922 const progress = (audio.currentTime / audio.duration) * 100;
3923
3924 linesDesktop.forEach(function(line, index) {
3925 const lineProgress = (index / linesDesktop.length) * 100;
3926 if (progress >= lineProgress) {
3927 !line.classList.contains("line-active") && line.classList.add("line-active");
3928 } else {
3929 line.classList.contains("line-active") && line.classList.remove("line-active");
3930 }
3931 });
3932
3933 linesMobile.forEach(function(line, index) {
3934 const lineProgress = (index / linesMobile.length) * 100;
3935 if (progress >= lineProgress) {
3936 !line.classList.contains("line-active") && line.classList.add("line-active");
3937 } else {
3938 line.classList.contains("line-active") && line.classList.remove("line-active");
3939 }
3940 });
3941 });
3942
3943
3944 sondwave.addEventListener("click", (event)=>{
3945 const distanceLeft = (event.clientX - sondwave.getBoundingClientRect().left)/sondwave.offsetWidth;
3946 audio.currentTime = audio.duration * distanceLeft;
3947 });
3948
3949 audioInterface.style.display = "";
3950 audioContainer.appendChild(audioInterface);
3951 });
3952
3953 });
3954 </script>
3955</#macro>
3956
3957<#macro renderShareAndCopyNews>
3958 <#-- <div class="share_news_container">-->
3959 <div class="social-media-container">
3960
3961 <#assign emailMsg = "Veja o conteúdo do post no link ">
3962 <#if locale == "en_US">
3963 <#assign emailMsg = "See the content of the post in the link ">
3964 </#if>
3965 <a class="social-media-share" href="mailto:?subject=${newsInfo.mainHeadlineOfTheNews}&body=${emailMsg}${newsInfo.url}"
3966 target="_blank">
3967 <svg class="email" width="37" height="36" viewBox="0 0 37 36" fill="none"
3968 xmlns="http://www.w3.org/2000/svg">
3969 <circle cx="18.5" cy="18" r="17.5" fill="white" stroke="#E1E1E1"/>
3970 <path d="M24.9231 12H11.0769C10.9239 12 10.7772 12.0579 10.669 12.1611C10.5608 12.2642 10.5 12.4041 10.5 12.55V21.9C10.5 22.1917 10.6216 22.4715 10.838 22.6778C11.0543 22.8841 11.3478 23 11.6538 23H24.3462C24.6522 23 24.9457 22.8841 25.162 22.6778C25.3784 22.4715 25.5 22.1917 25.5 21.9V12.55C25.5 12.4041 25.4392 12.2642 25.331 12.1611C25.2228 12.0579 25.0761 12 24.9231 12ZM24.3462 21.9H11.6538V13.8012L17.6106 19.0056C17.7169 19.0984 17.8559 19.1498 18 19.1498C18.1441 19.1498 18.2831 19.0984 18.3894 19.0056L24.3462 13.8012V21.9Z"
3971 fill="#008542"/>
3972 </svg>
3973 <span >send e-mail</span>
3974 </a>
3975
3976 <a class="social-media-share" href="https://www.facebook.com/sharer/sharer.php?u=${newsInfo.url}" target="_blank">
3977 <svg class="facebook" width="37" height="36" viewBox="0 0 37 36" fill="none"
3978 xmlns="http://www.w3.org/2000/svg">
3979 <circle cx="18.5" cy="18" r="17.5" fill="white" stroke="#E1E1E1"/>
3980 <path d="M17.5417 24H20.0341V18.1855H21.9697L22.2879 15.875H20.0341V14.2754C20.0341 13.9199 20.0871 13.6406 20.2462 13.4629C20.4053 13.2598 20.75 13.1582 21.2273 13.1582H22.5V11.1016C22.0227 11.0508 21.3864 11 20.6439 11C19.6894 11 18.947 11.2793 18.3902 11.8125C17.8068 12.3457 17.5417 13.082 17.5417 14.0469V15.875H15.5V18.1855H17.5417V24Z"
3981 fill="#008542"/>
3982 </svg>
3983 <span >Facebook</span>
3984 </a>
3985
3986 <#assign mobileShareButtonId = "mobile-share-" + randomNumber(5)>
3987 <div class="mobile-share" id="${mobileShareButtonId}">
3988 <svg width="37" height="36" viewBox="0 0 37 36" fill="none" xmlns="http://www.w3.org/2000/svg">
3989 <circle cx="18.5" cy="18" r="17.5" fill="white" stroke="#E1E1E1"/>
3990 <path d="M13.8923 20.5914C15.2136 20.5914 16.2847 19.5151 16.2847 18.1875C16.2847 16.8599 15.2136 15.7837 13.8923 15.7837C12.5711 15.7837 11.5 16.8599 11.5 18.1875C11.5 19.5151 12.5711 20.5914 13.8923 20.5914Z"
3991 fill="#008542" stroke="#008542" stroke-linecap="round" stroke-linejoin="round"/>
3992 <path d="M22.2654 26.0001C23.5866 26.0001 24.6577 24.9238 24.6577 23.5962C24.6577 22.2686 23.5866 21.1924 22.2654 21.1924C20.9441 21.1924 19.873 22.2686 19.873 23.5962C19.873 24.9238 20.9441 26.0001 22.2654 26.0001Z"
3993 fill="#008542" stroke="#008542" stroke-linecap="round" stroke-linejoin="round"/>
3994 <path d="M22.2654 15.1827C23.5866 15.1827 24.6577 14.1064 24.6577 12.7788C24.6577 11.4512 23.5866 10.375 22.2654 10.375C20.9441 10.375 19.873 11.4512 19.873 12.7788C19.873 14.1064 20.9441 15.1827 22.2654 15.1827Z"
3995 fill="#008542" stroke="#008542" stroke-linecap="round" stroke-linejoin="round"/>
3996 <path d="M20.2546 14.0784L15.9036 16.8879" stroke="#008542" stroke-linecap="round"
3997 stroke-linejoin="round"/>
3998 <path d="M15.9036 19.4871L20.2546 22.2966" stroke="#008542" stroke-linecap="round"
3999 stroke-linejoin="round"/>
4000 </svg>
4001 </div>
4002
4003 <a class="social-media-share" href="https://twitter.com/intent/tweet?url=${newsInfo.url}" target="_blank" data-size="large">
4004 <svg class="twitter" width="37" height="36" viewBox="0 0 37 36" fill="none"
4005 xmlns="http://www.w3.org/2000/svg">
4006 <circle cx="18.5" cy="18" r="17.5" fill="white" stroke="#E1E1E1"/>
4007 <path d="M22.7542 12H24.7809L20.3542 17.0933 25.5809 24H21.4742L18.2741 19.8133 14.5941 24H12.5674L17.3141 18.56 12.3008 12H16.5141L19.4208 15.84 22.7542 12ZM22.0342 22.7733H23.1542L15.9008 13.1467H14.6741L22.0342 22.7733Z" fill="#008542"/>
4008 </svg>
4009 <span >twitter</span>
4010 </a>
4011
4012 <a class="social-media-share" href="https://api.whatsapp.com/send?text=${newsInfo.url}" data-action="share/whatsapp/share"
4013 target="_blank">
4014 <svg class="whatsapp" width="37" height="36" viewBox="0 0 37 36" fill="none"
4015 xmlns="http://www.w3.org/2000/svg">
4016 <circle cx="18.5" cy="18" r="17.5" fill="white" stroke="#E1E1E1"/>
4017 <path d="M12.5482 21.3241C11.6166 19.7525 11.2908 17.8949 11.6318 16.1C11.9729 14.3052 12.9573 12.6965 14.4003 11.5761C15.8434 10.4556 17.6457 9.90042 19.4691 10.0147C21.2925 10.129 23.0114 10.9049 24.3033 12.1967C25.5951 13.4886 26.371 15.2075 26.4853 17.0309C26.5996 18.8543 26.0444 20.6566 24.9239 22.0997C23.8035 23.5427 22.1948 24.5271 20.4 24.8682C18.6051 25.2092 16.7475 24.8834 15.1759 23.9518L12.5795 24.687C12.4731 24.7181 12.3603 24.72 12.2529 24.6925C12.1455 24.6651 12.0475 24.6092 11.9692 24.5308C11.8908 24.4525 11.8349 24.3545 11.8075 24.2471C11.78 24.1397 11.7819 24.0269 11.813 23.9205L12.5482 21.3241Z"
4018 fill="#008542"/>
4019 <path d="M20.6917 21C20.0094 21.0017 19.3335 20.8686 18.7029 20.6083C18.0722 20.348 17.4992 19.9656 17.0168 19.4832C16.5344 19.0008 16.152 18.4278 15.8917 17.7971C15.6314 17.1665 15.4983 16.4906 15.5 15.8083C15.5017 15.3281 15.6937 14.8682 16.0338 14.5293C16.374 14.1903 16.8346 14 17.3148 14C17.394 13.9994 17.472 14.0201 17.5404 14.06C17.6089 14.1 17.6653 14.1576 17.7037 14.2269L18.462 15.5491C18.5071 15.6295 18.5303 15.7203 18.5291 15.8124C18.528 15.9046 18.5026 15.9948 18.4556 16.0741L17.8463 17.0917C18.1584 17.7859 18.7141 18.3416 19.4083 18.6537L20.4259 18.0444C20.5052 17.9974 20.5954 17.972 20.6876 17.9709C20.7797 17.9697 20.8705 17.9929 20.9509 18.038L22.2731 18.7963C22.3424 18.8347 22.4 18.8911 22.44 18.9596C22.4799 19.028 22.5006 19.106 22.5 19.1852C22.4983 19.6649 22.3074 20.1245 21.9689 20.4643C21.6303 20.8041 21.1713 20.9966 20.6917 21Z"
4020 fill="white"/>
4021 </svg>
4022 <span >Share to WhatsApp </span>
4023 </a>
4024
4025 <div class="copy-text-container">
4026 <svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
4027 <path d="M10.5 10.5H13.5V2.5H5.5V5.5" stroke="#008542" stroke-linecap="round"
4028 stroke-linejoin="round"/>
4029 <path d="M10.5 5.5H2.5V13.5H10.5V5.5Z" stroke="#008542" stroke-linecap="round"
4030 stroke-linejoin="round"/>
4031 </svg>
4032
4033 <#if locale == "pt_BR">
4034 <p class="text">Copiar texto <span class="copy-text-title-news"> ${newsInfo.mainHeadlineOfTheNews} </span> </p>
4035 <#else >
4036 <p class="text">Copy text <span class="copy-text-title-news"> ${newsInfo.mainHeadlineOfTheNews} </span> </p>
4037 </#if>
4038 </div>
4039
4040 </div>
4041
4042 <#if locale == "pt_BR">
4043 <span class="copy-message">Texto copiado!</span>
4044 <#else >
4045 <span class="copy-message">Text copied!</span>
4046 </#if>
4047 <#-- </div>-->
4048</#macro>
4049
4050<#-- ################################################################################################################## -->
4051
4052<#-- ############# Site de Crise - Notícia - Links do conteúdo da notícia ############################################# -->
4053<#macro renderLinks newsInfo>
4054 <#if newsInfo.links?size != 0>
4055 <#--videos "escondidos" que serão unidos a .ptb-news__read-content -->
4056
4057 <div class="ptb-news__links-container d-none ">
4058 <div id="ptb-news__links-identifiers">
4059 <#assign separator = "">
4060 <#list newsInfo.links as link>
4061 ${link.id};
4062 <#assign separator = ";">
4063 </#list>
4064 </div>
4065 <#list newsInfo.links as link>
4066 <#assign link_index = link?index>
4067 <#assign linkUrl = "#">
4068 <#assign target = "_blank">
4069 <#assign linkClass = "">
4070
4071 <div id="ptb-news__link-container-${link_index}">
4072 <#if link.externalLink?has_content>
4073 <#assign linkUrl = link.externalLink>
4074 <#assign target = "_blank">
4075 <#assign linkClass = "external-link">
4076 <#elseif link.pageLink?has_content>
4077 <#assign linkUrl = link.pageLink>
4078 <#assign target = "_self">
4079 <#assign linkClass = "internal-page-link">
4080 <#elseif link.file.mimeType?has_content>
4081 <#assign linkUrl = link.file.url>
4082 <#assign target = "_blank">
4083 <#assign linkClass = "file-link">
4084 </#if>
4085
4086 <#-- PDF icon -->
4087 <#if link.iconType == "Opção78730408" >
4088 <svg width="24" height="24" viewBox="0 0 24 24" fill="none"
4089 xmlns="http://www.w3.org/2000/svg">
4090 <path d="M3.752 15.974H4.664C4.912 15.974 5.124 15.954 5.3 15.914C5.476 15.874 5.62 15.806 5.732 15.71C5.852 15.606 5.94 15.466 5.996 15.29C6.052 15.114 6.08 14.894 6.08 14.63C6.08 14.11 5.968 13.758 5.744 13.574C5.528 13.39 5.168 13.298 4.664 13.298H3.752V15.974ZM2 20.654V11.894H4.784C5.856 11.894 6.632 12.122 7.112 12.578C7.6 13.026 7.844 13.698 7.844 14.594C7.844 15.474 7.604 16.158 7.124 16.646C6.652 17.134 5.872 17.378 4.784 17.378H3.752V20.654H2Z"
4091 fill="#008542"/>
4092 <path d="M10.8402 19.142H11.9442C12.2962 19.142 12.6042 19.102 12.8682 19.022C13.1322 18.942 13.3482 18.798 13.5162 18.59C13.6922 18.374 13.8242 18.082 13.9122 17.714C14.0002 17.338 14.0442 16.854 14.0442 16.262C14.0442 15.678 14.0002 15.202 13.9122 14.834C13.8322 14.458 13.7042 14.166 13.5282 13.958C13.3602 13.75 13.1442 13.606 12.8802 13.526C12.6242 13.446 12.3202 13.406 11.9682 13.406H10.8402V19.142ZM9.16016 20.654V11.894H12.1002C12.7642 11.894 13.3322 11.982 13.8042 12.158C14.2762 12.326 14.6602 12.59 14.9562 12.95C15.2602 13.302 15.4802 13.75 15.6162 14.294C15.7602 14.83 15.8322 15.47 15.8322 16.214C15.8322 17.726 15.5362 18.846 14.9442 19.574C14.3522 20.294 13.3882 20.654 12.0522 20.654H9.16016Z"
4093 fill="#008542"/>
4094 <path d="M17.2695 20.654V11.894H22.2735V13.358H18.9735V15.59H21.9015V17.054H18.9735V20.654H17.2695Z"
4095 fill="#008542"/>
4096 <path d="M6.08984 8.24516V1.60376C6.08984 1.44364 6.15211 1.29007 6.26294 1.17684C6.37377 1.06361 6.52408 1 6.68082 1H13.7725M13.7725 1L17.9094 5.22634M13.7725 1L13.7725 5.22634H17.9094M17.9094 5.22634V8.24516"
4097 stroke="#008542" stroke-width="1.5" stroke-linecap="round"
4098 stroke-linejoin="round"/>
4099 </svg>
4100
4101 <#-- JPG icon -->
4102 <#elseif link.iconType == "Opção89889679" >
4103 <svg width="24" height="24" viewBox="0 0 24 24" fill="none"
4104 xmlns="http://www.w3.org/2000/svg">
4105 <path d="M2 19.1657C2.248 19.1977 2.504 19.2257 2.768 19.2497C3.032 19.2657 3.284 19.2737 3.524 19.2737C3.844 19.2737 4.112 19.2497 4.328 19.2017C4.544 19.1537 4.72 19.0657 4.856 18.9377C4.992 18.8017 5.088 18.6257 5.144 18.4097C5.208 18.1857 5.24 17.8977 5.24 17.5457V11.8937H6.992V17.5457C6.992 18.6817 6.756 19.5057 6.284 20.0177C5.82 20.5297 5.128 20.7857 4.208 20.7857C3.984 20.7857 3.764 20.7737 3.548 20.7497C3.34 20.7257 3.14 20.6937 2.948 20.6537C2.756 20.6137 2.58 20.5697 2.42 20.5217C2.26 20.4737 2.12 20.4257 2 20.3777V19.1657Z"
4106 fill="#008542"/>
4107 <path d="M10.4203 15.9737H11.3323C11.5803 15.9737 11.7923 15.9537 11.9683 15.9137C12.1443 15.8737 12.2883 15.8057 12.4003 15.7097C12.5203 15.6057 12.6083 15.4657 12.6643 15.2897C12.7203 15.1137 12.7483 14.8937 12.7483 14.6297C12.7483 14.1097 12.6363 13.7577 12.4123 13.5737C12.1963 13.3897 11.8363 13.2977 11.3323 13.2977H10.4203V15.9737ZM8.66834 20.6537V11.8937H11.4523C12.5243 11.8937 13.3003 12.1217 13.7803 12.5777C14.2683 13.0257 14.5123 13.6977 14.5123 14.5937C14.5123 15.4737 14.2723 16.1577 13.7923 16.6457C13.3203 17.1337 12.5403 17.3777 11.4523 17.3777H10.4203V20.6537H8.66834Z"
4108 fill="#008542"/>
4109 <path d="M22.0085 20.2697C21.6405 20.4057 21.2085 20.5257 20.7125 20.6297C20.2245 20.7337 19.7165 20.7857 19.1885 20.7857C18.5005 20.7857 17.9245 20.6897 17.4605 20.4977C17.0045 20.2977 16.6365 20.0097 16.3565 19.6337C16.0845 19.2577 15.8885 18.7977 15.7685 18.2537C15.6485 17.7017 15.5885 17.0777 15.5885 16.3817C15.5885 15.6217 15.6565 14.9537 15.7925 14.3777C15.9285 13.8017 16.1445 13.3217 16.4405 12.9377C16.7365 12.5457 17.1205 12.2537 17.5925 12.0617C18.0645 11.8617 18.6405 11.7617 19.3205 11.7617C19.7845 11.7617 20.2125 11.8017 20.6045 11.8817C21.0045 11.9617 21.3605 12.0577 21.6725 12.1697V13.3937C21.5525 13.3857 21.4125 13.3737 21.2525 13.3577C21.0925 13.3337 20.9205 13.3137 20.7365 13.2977C20.5605 13.2817 20.3765 13.2697 20.1845 13.2617C20.0005 13.2457 19.8205 13.2377 19.6445 13.2377C19.2205 13.2377 18.8605 13.2857 18.5645 13.3817C18.2765 13.4697 18.0405 13.6297 17.8565 13.8617C17.6805 14.0857 17.5485 14.3937 17.4605 14.7857C17.3805 15.1777 17.3405 15.6737 17.3405 16.2737C17.3405 16.8417 17.3765 17.3217 17.4485 17.7137C17.5285 18.0977 17.6485 18.4097 17.8085 18.6497C17.9685 18.8897 18.1765 19.0617 18.4325 19.1657C18.6965 19.2697 19.0125 19.3217 19.3805 19.3217C19.6765 19.3217 20.0245 19.2857 20.4245 19.2137V17.1977H19.1045V15.8897H22.0085V20.2697Z"
4110 fill="#008542"/>
4111 <path d="M6.08984 8.24516V1.60376C6.08984 1.44364 6.15211 1.29007 6.26294 1.17684C6.37377 1.06361 6.52408 1 6.68082 1H13.7725M13.7725 1L17.9094 5.22634M13.7725 1L13.7725 5.22634H17.9094M17.9094 5.22634V8.24516"
4112 stroke="#008542" stroke-width="1.5" stroke-linecap="round"
4113 stroke-linejoin="round"/>
4114 </svg>
4115 <#-- DOC icon -->
4116 <#elseif link.iconType == "Opção15480314" >
4117 <svg width="24" height="24" viewBox="0 0 24 24" fill="none"
4118 xmlns="http://www.w3.org/2000/svg">
4119 <path d="M2.68 19.1417H3.784C4.136 19.1417 4.444 19.1017 4.708 19.0217C4.972 18.9417 5.188 18.7977 5.356 18.5897C5.532 18.3737 5.664 18.0817 5.752 17.7137C5.84 17.3377 5.884 16.8537 5.884 16.2617C5.884 15.6777 5.84 15.2017 5.752 14.8337C5.672 14.4577 5.544 14.1657 5.368 13.9577C5.2 13.7497 4.984 13.6057 4.72 13.5257C4.464 13.4457 4.16 13.4057 3.808 13.4057H2.68V19.1417ZM1 20.6537V11.8937H3.94C4.604 11.8937 5.172 11.9817 5.644 12.1577C6.116 12.3257 6.5 12.5897 6.796 12.9497C7.1 13.3017 7.32 13.7497 7.456 14.2937C7.6 14.8297 7.672 15.4697 7.672 16.2137C7.672 17.7257 7.376 18.8457 6.784 19.5737C6.192 20.2937 5.228 20.6537 3.892 20.6537H1Z"
4120 fill="#008542"/>
4121 <path d="M10.7894 20.4977C10.3334 20.3057 9.96138 20.0217 9.67338 19.6457C9.39338 19.2697 9.18937 18.8057 9.06137 18.2537C8.93337 17.6937 8.86938 17.0457 8.86938 16.3097C8.86938 15.5657 8.93337 14.9097 9.06137 14.3417C9.19737 13.7737 9.40938 13.2977 9.69738 12.9137C9.99338 12.5297 10.3694 12.2417 10.8254 12.0497C11.2894 11.8577 11.8494 11.7617 12.5054 11.7617C13.1694 11.7617 13.7294 11.8577 14.1854 12.0497C14.6414 12.2417 15.0094 12.5257 15.2894 12.9017C15.5774 13.2777 15.7854 13.7457 15.9134 14.3057C16.0414 14.8577 16.1054 15.5017 16.1054 16.2377C16.1054 16.9817 16.0374 17.6377 15.9014 18.2057C15.7734 18.7737 15.5614 19.2497 15.2654 19.6337C14.9774 20.0177 14.6014 20.3057 14.1374 20.4977C13.6814 20.6897 13.1254 20.7857 12.4694 20.7857C11.8054 20.7857 11.2454 20.6897 10.7894 20.4977ZM11.0894 18.6737C11.2414 18.9057 11.4334 19.0737 11.6654 19.1777C11.8974 19.2737 12.1694 19.3217 12.4814 19.3217C12.7934 19.3217 13.0654 19.2737 13.2974 19.1777C13.5294 19.0737 13.7214 18.9057 13.8734 18.6737C14.0254 18.4337 14.1374 18.1217 14.2094 17.7377C14.2814 17.3457 14.3174 16.8577 14.3174 16.2737C14.3174 15.6897 14.2814 15.2057 14.2094 14.8217C14.1374 14.4297 14.0254 14.1177 13.8734 13.8857C13.7294 13.6457 13.5414 13.4777 13.3094 13.3817C13.0774 13.2777 12.8054 13.2257 12.4934 13.2257C12.1814 13.2257 11.9094 13.2777 11.6774 13.3817C11.4454 13.4777 11.2534 13.6457 11.1014 13.8857C10.9494 14.1177 10.8374 14.4297 10.7654 14.8217C10.6934 15.2057 10.6574 15.6897 10.6574 16.2737C10.6574 16.8577 10.6934 17.3457 10.7654 17.7377C10.8374 18.1217 10.9454 18.4337 11.0894 18.6737Z"
4122 fill="#008542"/>
4123 <path d="M23.1389 20.3897C22.8349 20.5017 22.4989 20.5937 22.1309 20.6657C21.7709 20.7457 21.3629 20.7857 20.9069 20.7857C20.2189 20.7857 19.6429 20.6897 19.1789 20.4977C18.7229 20.3057 18.3549 20.0257 18.0749 19.6577C17.7949 19.2817 17.5949 18.8177 17.4749 18.2657C17.3629 17.7137 17.3069 17.0777 17.3069 16.3577C17.3069 15.5977 17.3709 14.9297 17.4989 14.3537C17.6269 13.7777 17.8309 13.2977 18.1109 12.9137C18.3909 12.5297 18.7589 12.2417 19.2149 12.0497C19.6709 11.8577 20.2229 11.7617 20.8709 11.7617C21.3029 11.7617 21.6989 11.8017 22.0589 11.8817C22.4269 11.9537 22.7629 12.0457 23.0669 12.1577V13.3817C22.8029 13.3497 22.4949 13.3177 22.1429 13.2857C21.7989 13.2537 21.4829 13.2377 21.1949 13.2377C20.8029 13.2377 20.4709 13.2857 20.1989 13.3817C19.9349 13.4697 19.7189 13.6297 19.5509 13.8617C19.3829 14.0857 19.2629 14.3937 19.1909 14.7857C19.1189 15.1697 19.0829 15.6617 19.0829 16.2617C19.0829 16.8617 19.1189 17.3617 19.1909 17.7617C19.2709 18.1537 19.3949 18.4657 19.5629 18.6977C19.7389 18.9217 19.9669 19.0817 20.2469 19.1777C20.5269 19.2657 20.8709 19.3097 21.2789 19.3097C21.5989 19.3097 21.9309 19.2937 22.2749 19.2617C22.6189 19.2217 22.9069 19.1897 23.1389 19.1657V20.3897Z"
4124 fill="#008542"/>
4125 <path d="M6.08984 8.24516V1.60376C6.08984 1.44364 6.15211 1.29007 6.26294 1.17684C6.37377 1.06361 6.52408 1 6.68082 1H13.7725M13.7725 1L17.9094 5.22634M13.7725 1L13.7725 5.22634H17.9094M17.9094 5.22634V8.24516"
4126 stroke="#008542" stroke-width="1.5" stroke-linecap="round"
4127 stroke-linejoin="round"/>
4128 </svg>
4129 <#-- External link icon -->
4130 <#elseif link.iconType == "Opção43823553" >
4131 <svg width="24" height="24" viewBox="0 0 32 32" fill="none"
4132 xmlns="http://www.w3.org/2000/svg">
4133 <path opacity="0.98"
4134 d="M25.5 15.5001V26.5001C25.5 26.7653 25.3946 27.0197 25.2071 27.2072C25.0196 27.3947 24.7652 27.5001 24.5 27.5001L5.5 27.5001C5.23479 27.5001 4.98043 27.3947 4.79289 27.2072C4.60536 27.0197 4.5 26.7653 4.5 26.5001L4.5 7.50009C4.5 7.23488 4.60536 6.98052 4.79289 6.79299C4.98043 6.60545 5.23478 6.50009 5.5 6.50009L17 6.50009M20.4742 4.7124H27.8988M27.8988 4.7124V12.137M27.8988 4.7124L14.5 18.0001"
4135 stroke="#008542" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
4136 </svg>
4137 <#-- Internal page link icon -->
4138 <#elseif link.iconType == "Opção64212757" >
4139 <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="#008542" viewBox="0 0 256 256">
4140 <path d="M137.54,186.36a8,8,0,0,1,0,11.31l-9.94,10A56,56,0,0,1,48.38,128.4L72.5,104.28A56,56,0,0,1,149.31,102a8,8,0,1,1-10.64,12,40,40,0,0,0-54.85,1.63L59.7,139.72a40,40,0,0,0,56.58,56.58l9.94-9.94A8,8,0,0,1,137.54,186.36Zm70.08-138a56.08,56.08,0,0,0-79.22,0l-9.94,9.95a8,8,0,0,0,11.32,11.31l9.94-9.94a40,40,0,0,1,56.58,56.58L172.18,140.4A40,40,0,0,1,117.33,142,8,8,0,1,0,106.69,154a56,56,0,0,0,76.81-2.26l24.12-24.12A56.08,56.08,0,0,0,207.62,48.38Z">
4141 </path>
4142 </svg>
4143 <#-- Download link icon -->
4144 <#elseif link.iconType == "Opção20766606" >
4145 <svg width="24" height="24" viewBox="0 0 32 32" fill="none"
4146 xmlns="http://www.w3.org/2000/svg">
4147 <path d="M10.75 13.75L16 19M16 19L21.25 13.75M16 19V5M27 19V26C27 26.2652 26.8946 26.5196 26.7071 26.7071C26.5196 26.8946 26.2652 27 26 27H6C5.73478 27 5.48043 26.8946 5.29289 26.7071C5.10536 26.5196 5 26.2652 5 26V19"
4148 stroke="#008542" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
4149 </svg>
4150 </#if>
4151<#if link.title?? && link.title?has_content>
4152 <a href="${linkUrl}" class="link ${linkClass}" target="${target}">${link.title}</a>
4153 </#if>
4154 </div>
4155 </#list>
4156 </div>
4157
4158 <script>
4159 var newsContent_code = document.querySelector(".news-content").innerHTML;
4160
4161 var linksIdentifiers = document.querySelector("#ptb-news__links-identifiers").innerHTML.trim().split(";");
4162 linksIdentifiers.forEach((linkIdentifier, index) => {
4163 const linkIdentifierContent = document.querySelector("#ptb-news__link-container-" + index);
4164 if (linkIdentifierContent) {
4165 const tag = "#[" + linkIdentifier.trim() + "]";
4166 const splitContent = newsContent_code.split(tag);
4167 newsContent_code = splitContent.join(linkIdentifierContent.innerHTML);
4168 //linkIdentifierContent.parentNode.removeChild(linkIdentifierContent);
4169 }
4170 });
4171
4172
4173 var ptb_news__read_content = document.querySelector(".news-content");
4174 ptb_news__read_content.innerHTML = newsContent_code;
4175
4176 const links_ptb_news = document.querySelectorAll(".news-content a");
4177 links_ptb_news.forEach((link) => {
4178 link.classList.add("link-ptb-news");
4179 });
4180
4181 </script>
4182
4183 <style>
4184 .ptb-news__read-news .ptb-news__link a {
4185 font-family: var(--font-family-base);
4186 font-style: var(--font-style-normal, normal);
4187 font-weight: var(--font-weight-bold, 700);
4188 font-size: var(--font-size-xxs, 16px);
4189 line-height: var(--line-height-xl, 160%);
4190 text-decoration-line: var(--text-decoration-underline, underline);
4191 color: #008542;
4192 }
4193
4194 body.high-contrast-active .ptb-news__read-news .ptb-news__link a {
4195 color: #E4F7E8;
4196 }
4197
4198 .ptb-news__read-news .news-content .link {
4199 font-family: var(--font-family-base);
4200 font-style: var(--font-style-normal, normal);
4201 font-weight: var(--font-weight-bold, 700);
4202 font-size: var(--font-size-xs, 18px);
4203 line-height: var(--line-height-xl, 160%);
4204
4205 text-decoration-line: var(--text-decoration-underline, underline);
4206 color: #008542;
4207 }
4208
4209 body.high-contrast-active .ptb-news__read-news .news-content .link {
4210 color: #E4F7E8;
4211 }
4212
4213 body.high-contrast-active .ptb-news__read-news .news-content svg path {
4214 stroke: var(--color-neutral-500, #D7D7D7);
4215 fill: rgba(255, 255, 255, 0.32);
4216 }
4217
4218 .ptb-news__read-news .news-content .ptb-link__wrapper {
4219 display: flex;
4220 flex-direction: column;
4221 gap: 0;
4222 margin-top: -24px;
4223 }
4224
4225 .ptb-news__read-news .news-content .ptb-link__wrapper svg {
4226 margin-right: var(--space-sm, 16px);
4227 }
4228
4229 .ptb-news__read-news .news-content .ptb-link__wrapper .first {
4230 gap: 0 !important;
4231 }
4232
4233 @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) {
4234 .ptb-news__read-news .news-content .link {
4235 font-size: var(--font-size-xxs, 16px);
4236 }
4237 }
4238 </style>
4239 </#if>
4240</#macro>
4241
4242<#-- ################################################################################################################## -->
4243
4244<#-- ################################################################################################################## -->
4245
4246<#-- ############# Site de Crise - Notícia - Links do conteúdo da notícia ############################################# -->
4247<#macro renderCite>
4248 <div class="ptb-news__cite-container">
4249 <div class="ptb-news__cite-container-breakpoint breakpoint">
4250 <div class="ptb-news__cite-container-col col-1-12 md-col-1-8 sm-col-1-4">
4251 <div class="ptb-news__cite-title">
4252 <#if locale?lower_case == "pt_br">
4253 Notas
4254 <#else>
4255 Notes
4256 </#if>
4257 </div>
4258
4259 <div class="ptb-news__cites-elements">
4260 </div>
4261 </div>
4262 </div>
4263 </div>
4264
4265 <script>
4266 function positionCitesText(parentNodeCitesText) {
4267
4268 parentNodeCitesText.forEach((parentNodeCiteText)=>{
4269 if(window.innerWidth > 1024) {
4270 parentNodeCiteText.style.display="";
4271 parentNodeCiteText.style.gridColumnStart = "11";
4272 parentNodeCiteText.style.gridColumnEnd = "13";
4273 }
4274 else {
4275 parentNodeCiteText.style.display="none";
4276 parentNodeCiteText.style.gridColumnStart = "";
4277 parentNodeCiteText.style.gridColumnEnd = "";
4278 }
4279 });
4280 }
4281
4282 function addCitesTextMobile(citesText) {
4283 const citesContainer = document.querySelector(".ptb-news__read-news-post .ptb-news__cite-container .ptb-news__cite-container-col .ptb-news__cites-elements");
4284
4285 if(citesContainer.children.length === 0) {
4286 citesContainer && citesText.forEach((citeText)=>{
4287 citesContainer.appendChild(citeText.cloneNode(true));
4288 });
4289 }
4290 }
4291
4292 const citesText = document.querySelectorAll(".news-content cite");
4293
4294 if (citesText.length > 0) {
4295 const parentNodeCitesText = [...citesText].map((citeText)=>citeText.parentNode);
4296 positionCitesText(parentNodeCitesText);
4297 addCitesTextMobile(citesText);
4298 }
4299 else {
4300 const citesContainer = document.querySelector(".ptb-news__cite-container");
4301 citesContainer && (citesContainer.style.display="none");
4302 }
4303
4304 document.addEventListener('DOMContentLoaded', ()=>{
4305
4306 const citesText = document.querySelectorAll(".news-content cite");
4307
4308 if (citesText.length > 0) {
4309 const parentNodeCitesText = [...citesText].map((citeText)=>citeText.parentNode);
4310
4311 positionCitesText(parentNodeCitesText);
4312 addCitesTextMobile(citesText);
4313
4314 window.addEventListener('resize', ()=>{positionCitesText(parentNodeCitesText)});
4315 }
4316 else {
4317 const citesContainer = document.querySelector(".ptb-news__cite-container");
4318 citesContainer && (citesContainer.style.display="none");
4319 }
4320 });
4321
4322 </script>
4323
4324 <style>
4325
4326 .ptb-news__read-news-post cite {
4327 color: var(--color-neutral-800, #373737);
4328 font-family: var(--font-family-base);
4329 font-size: var(--font-size-xxxs, 14px) !important;
4330 font-style: var(--font-style-normal, normal);
4331 font-weight: var(--font-weight-regular, 400);
4332 line-height: var(--line-height-xl, 160%);
4333 }
4334
4335 .ptb-news__read-news-post cite a{
4336 font-size: var(--font-size-xxxs, 14px) !important;
4337 }
4338
4339 body.high-contrast-active .ptb-news__read-news-post cite {
4340 color: var(--text-primary-default, var(--color-neutral-100));
4341 }
4342
4343 .ptb-news__read-news-post .news-content cite,
4344 .ptb-news__read-news-post .ptb-news__cite-container cite {
4345 display: block;
4346 padding-left: var(--space-md);
4347 border-left: var(--border-width-hairline, 1px) solid var(--color-neutral-500, #D7D7D7);
4348 }
4349
4350 @media screen and (min-width: 1025px) {
4351 .ptb-news__read-news-post .ptb-news__cite-container {
4352 display: none;
4353 }
4354 }
4355
4356 @media screen and (max-width: 1025px) {
4357 .ptb-news__read-news .ptb-news__cite-container .link {
4358 text-decoration-line: var(--text-decoration-underline, underline);
4359 color: #008542;
4360 }
4361
4362 body.high-contrast-active .ptb-news__read-news .ptb-news__cite-container .link {
4363 color: #E4F7E8;
4364 }
4365
4366 body.high-contrast-active .ptb-news__read-news .ptb-news__cite-container svg path {
4367 stroke: var(--color-neutral-500, #D7D7D7);
4368 fill: rgba(255, 255, 255, 0.32);
4369 }
4370
4371 .ptb-news__read-news-post .ptb-news__cite-container {
4372 display: grid;
4373 background: var(--background-surface-level-03, #EEE);
4374 }
4375
4376 body.high-contrast-active .ptb-news__read-news-post .ptb-news__cite-container {
4377 background: var(--background-surface-level-03, #525252);
4378 }
4379
4380 .ptb-news__read-news-post .ptb-news__cite-container .ptb-news__cite-container-col {
4381 padding: var(--space-xxl) 0;
4382 display: flex;
4383 flex-direction: column;
4384 gap: var(--space-lg, 32px);
4385 }
4386
4387 .ptb-news__read-news-post .ptb-news__cite-container .ptb-news__cite-container-col .ptb-news__cites-elements {
4388 display: flex;
4389 flex-direction: column;
4390 gap: var(--space-lg, 32px);
4391 }
4392
4393 .ptb-news__read-news-post .ptb-news__cite-container .ptb-news__cite-container-col .ptb-news__cite-title {
4394 color: var(--color-neutral-800, #373737);
4395 font-size: var(--font-size-sm, 20px);
4396 font-style: var(--font-style-normal, normal);
4397 font-weight: var(--font-weight-bold, 700);
4398 line-height: var(--line-height-xl, 160%);
4399 }
4400
4401 body.high-contrast-active .ptb-news__read-news-post .ptb-news__cite-container .ptb-news__cite-container-col .ptb-news__cite-title {
4402 color: var(--text-primary-default, var(--color-neutral-100));
4403 }
4404 }
4405 </style>
4406
4407</#macro>
4408
4409<#-- ################################################################################################################## -->
4410
4411
4412<#-- ############# Site de Crise - Notícia - Galeria de imagens ####################################################### -->
4413<#macro renderGallery newsInfo>
4414 <#if newsInfo.galleryItems?size == 0>
4415 <#return />
4416 </#if>
4417
4418 <div class="gallery-breakpoint breakpoint">
4419 <div class="gallery col-3-11 md-col-1-8 sm-col-1-4">
4420
4421 <div class="title-container">
4422 <svg class="icon" viewBox="0 0 26 23" fill="none" xmlns="http://www.w3.org/2000/svg">
4423 <path d="M23 22H3C2.46957 22 1.96086 21.7893 1.58579 21.4142C1.21071 21.0391 1 20.5304 1 20V6C1 5.46957 1.21071 4.96086 1.58579 4.58579C1.96086 4.21071 2.46957 4 3 4H7L9 1H17L19 4H23C23.5304 4 24.0391 4.21071 24.4142 4.58579C24.7893 4.96086 25 5.46957 25 6V20C25 20.5304 24.7893 21.0391 24.4142 21.4142C24.0391 21.7893 23.5304 22 23 22Z"
4424 stroke="#525252" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
4425 <path d="M13 17C15.4853 17 17.5 14.9853 17.5 12.5C17.5 10.0147 15.4853 8 13 8C10.5147 8 8.5 10.0147 8.5 12.5C8.5 14.9853 10.5147 17 13 17Z"
4426 stroke="#525252" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
4427 </svg>
4428 <p class="title">
4429 <#if locale == "pt_BR"> Galeria de Imagens <#else > Image gallery </#if>
4430 </p>
4431 </div>
4432
4433 <div class="image-container">
4434 <#assign index = 0 />
4435 <#assign index = 0 />
4436 <#list newsInfo.galleryItems as gItem>
4437 <div class="modal-image-fragment" index="${index}">
4438 <div class="modal-image-container" index="${index}">
4439 <div class="modal-image-fragment" index="${index}">
4440 <div class="modal-image-container" index="${index}">
4441 <span class="click-image" ></span>
4442
4443 <div class="image-player-container">
4444 <span class="close-image">
4445 <svg width="44" height="44" viewBox="0 0 44 44" fill="none" xmlns="http://www.w3.org/2000/svg">
4446 <path d="M22 -9.61651e-07C34.1503 -4.30546e-07 44 9.84974 44 22C44 34.1503 34.1503 44 22 44C9.84973 44 -1.49276e-06 34.1503 -9.61651e-07 22C-4.30546e-07 9.84973 9.84974 -1.49276e-06 22 -9.61651e-07Z" fill="white"/>
4447 <path d="M26.5 26.5L17.5 17.5M17.5 26.5L26.5 17.5" stroke="#008542" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
4448 </svg>
4449 </span>
4450 <div class="image-player-session">
4451 <#-- Midias adaptativas de imagem para desktop e mobile -->
4452 <#assign fileDataRequest = restClient.get("/headless-delivery/v1.0/documents/${gItem.image.fileEntryId}") />
4453 <#assign urlAdaptativeMediaMobile = gItem.image.url/>
4454 <#assign urlAdaptativeMediaDesktop = gItem.image.url/>
4455
4456 <#if fileDataRequest?? && fileDataRequest.adaptedImages?? >
4457 <#assign dataAdaptativeMedia = fileDataRequest.adaptedImages />
4458 <#list dataAdaptativeMedia as data>
4459 <#if data.resolutionName == adaptativeMediaDesktopResolutionName>
4460 <#assign urlAdaptativeMediaDesktop = data.contentUrl/>
4461 </#if>
4462 <#if data.resolutionName == adaptativeMediaMobileResolutionName>
4463 <#assign urlAdaptativeMediaMobile = data.contentUrl/>
4464 </#if>
4465 </#list>
4466 </#if>
4467
4468 <picture >
4469 <source media="(max-width:767px)" srcset="${urlAdaptativeMediaMobile}" >
4470 <img width="274px" height="152px" loading="lazy" src="${urlAdaptativeMediaDesktop}" alt="${gItem.image.alt}"/>
4471 </picture>
4472 </div>
4473 </div>
4474 </div>
4475 </div>
4476 <#assign index = index + 1 />
4477 <#assign index = index + 1 />
4478 </#list>
4479 <div class="control-arrow left-arrow">
4480 <svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">
4481 <path d="M20 26L10 16L20 6" stroke="white" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
4482 </svg>
4483 </div>
4484 <div class="control-arrow right-arrow">
4485 <svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">
4486 <path d="M12 6L22 16L12 26" stroke="white" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
4487 </svg>
4488 </div>
4489 <div class="image-bullets">
4490 <#list 0..(newsInfo.galleryItems?size-1) as index>
4491 <div index="${index}" class="bullet"></div>
4492 </#list>
4493 </div>
4494 </div>
4495 <div class="control-arrow left-arrow">
4496 <svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">
4497 <path d="M20 26L10 16L20 6" stroke="white" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
4498 </svg>
4499 </div>
4500 <div class="control-arrow right-arrow">
4501 <svg width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">
4502 <path d="M12 6L22 16L12 26" stroke="white" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
4503 </svg>
4504 </div>
4505 <div class="image-bullets">
4506 <#list 0..(newsInfo.galleryItems?size-1) as index>
4507 <div index="${index}" class="bullet"></div>
4508 </#list>
4509 </div>
4510 </div>
4511 </div>
4512 </div>
4513
4514 <style>
4515
4516 .ptb-news__read-news .gallery {
4517 padding-top: 42px;
4518 }
4519
4520 .ptb-news__read-news .gallery * {
4521 margin: 0;
4522 padding: 0;
4523 }
4524
4525 .ptb-news__read-news .gallery {
4526 display: flex;
4527 gap: var(--space-xl, 40px);
4528 flex-direction: column;
4529 }
4530
4531 .ptb-news__read-news .gallery .control-arrow {
4532 position: fixed;
4533 height: 100%;
4534 align-items: center;
4535 display: flex;
4536 justify-content: center;
4537 display: none;
4538 z-index: 9999;
4539 }
4540
4541 .ptb-news__read-news .gallery .left-arrow {
4542 top: 0;
4543 left: 5vw;
4544 }
4545
4546 .ptb-news__read-news .gallery .right-arrow {
4547 top: 0;
4548 right: 5vw;
4549 }
4550
4551 .ptb-news__read-news .gallery .lefg-arrow svg {
4552 margin-left: 16px !important;
4553 }
4554
4555 .ptb-news__read-news .gallery .right-arrow svg {
4556 margin-right: 16px !important;
4557 }
4558
4559 .ptb-news__read-news .gallery .image-bullets {
4560 display: none;
4561 gap: var(--space-sm, 16px);
4562 position: fixed;
4563 left: 0;
4564 bottom: calc(10vh + 24px);
4565 width: 100vw;
4566 z-index: 9999;
4567 justify-content: center;
4568 }
4569
4570 .ptb-news__read-news .gallery .image-bullets .bullet {
4571 width: var(--size-xs, 16px);
4572 height: var(--size-xs, 16px);
4573 border-radius: 50%;
4574 border: 1px solid var(--color-neutral-100, #FFFFFF);
4575 z-index: 9999;
4576 }
4577
4578 .ptb-news__read-news .gallery .image-bullets .bullet.current-item {
4579 background: var(--color-neutral-100, #FFFFFF);
4580 }
4581
4582 .ptb-news__read-news .gallery .control-arrow {
4583 position: fixed;
4584 height: 100%;
4585 align-items: center;
4586 display: flex;
4587 justify-content: center;
4588 display: none;
4589 z-index: 9999;
4590 }
4591
4592 .ptb-news__read-news .gallery .left-arrow {
4593 top: 0;
4594 left: 5vw;
4595 }
4596
4597 .ptb-news__read-news .gallery .right-arrow {
4598 top: 0;
4599 right: 5vw;
4600 }
4601
4602 .ptb-news__read-news .gallery .lefg-arrow svg {
4603 margin-left: 16px !important;
4604 }
4605
4606 .ptb-news__read-news .gallery .right-arrow svg {
4607 margin-right: 16px !important;
4608 }
4609
4610 .ptb-news__read-news .gallery .image-bullets {
4611 display: none;
4612 gap: var(--space-sm, 16px);
4613 position: fixed;
4614 left: 0;
4615 bottom: calc(10vh + 24px);
4616 width: 100vw;
4617 z-index: 9999;
4618 justify-content: center;
4619 }
4620
4621 .ptb-news__read-news .gallery .image-bullets .bullet {
4622 width: var(--size-xs, 16px);
4623 height: var(--size-xs, 16px);
4624 border-radius: 50%;
4625 border: 1px solid var(--color-neutral-100, #FFFFFF);
4626 z-index: 9999;
4627 }
4628
4629 .ptb-news__read-news .gallery .image-bullets .bullet.current-item {
4630 background: var(--color-neutral-100, #FFFFFF);
4631 }
4632
4633 .ptb-news__read-news .gallery .title-container {
4634 display: flex;
4635 align-items: center;
4636 gap: var(--space-sm, 16px);
4637 }
4638
4639 .ptb-news__read-news .gallery .title-container svg {
4640 width: var(--size-md, 24px);
4641 height: 21px;
4642 }
4643
4644 .ptb-news__read-news .gallery .title-container .title {
4645 color: var(--color-neutral-800, #373737);
4646 font-family: var(--font-family-base);
4647 font-size: var(--font-size-lg);
4648 font-style: var(--font-style-normal);
4649 font-weight: var(--font-weight-bold);
4650 line-height: var(--line-height-md);
4651 }
4652
4653 body.high-contrast-active .ptb-news__read-news .gallery .title-container .title {
4654 color: var(--color-neutral-100);
4655 }
4656
4657 .ptb-news__read-news .gallery .image-container {
4658 display: flex;
4659 gap: var(--space-sm, 16px);
4660 flex-wrap: wrap;
4661 }
4662
4663 .ptb-news__read-news .gallery .image-container .modal-image-fragment {
4664 width: inherit;
4665 height: inherit;
4666 max-height: calc(100vw/2);
4667 padding: 0;
4668 margin: 0;
4669 overflow: hidden;
4670 }
4671
4672 .ptb-news__read-news .gallery .image-container .modal-image-fragment * {
4673 box-sizing: border-box;
4674 margin: 0;
4675 padding: 0;
4676 }
4677
4678 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container {
4679 width: 100%;
4680 height: inherit;
4681 display: flex;
4682 justify-content: center;
4683 align-items: center;
4684 cursor: pointer;
4685 position: relative;
4686 }
4687
4688 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container.image-playing {
4689 position: fixed;
4690 top: 0;
4691 left: 0;
4692 width: 100vw !important;
4693 height: 100vh !important;
4694 z-index: 9999 !important;
4695 background-color: rgba(0, 0, 0, 0.75);
4696 max-height: 100vh;
4697 }
4698
4699 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .click-image {
4700 height: 100%;
4701 width: 100%;
4702 position: absolute;
4703 z-index: 3;
4704 }
4705
4706 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container {
4707 width: 100%;
4708 height: 100%;
4709 }
4710
4711 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container.image-playing {
4712 position: relative;
4713 width: 90vw !important;
4714 height: 80vh !important;
4715 z-index: 9999 !important;
4716 background-color: rgba(0, 0, 0, 0.75);
4717 border-radius: var(--border-radius-card);
4718 }
4719
4720 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .close-image {
4721 display: none;
4722 position: absolute;
4723 top: 0;
4724 right: 0;
4725 transform: translate(100%, -100%);
4726 z-index: 99999;
4727 }
4728
4729 body.high-contrast-active .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .close-image path:nth-child(1) {
4730 fill: var(--background-Surface-level-01, #010101);
4731 }
4732
4733 body.high-contrast-active .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .close-image path:nth-child(2) {
4734 stroke: #E4F7E8;
4735 }
4736
4737 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .close-image.image-active {
4738 display: block;
4739 }
4740
4741 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .image-player-session {
4742 width: 100%;
4743 height: 100%;
4744 }
4745
4746 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container.image-playing .image-player-session {
4747 width: 90vw !important;
4748 height: 80vh !important;
4749 z-index: 9999 !important;
4750 background-color: rgba(0, 0, 0, 0.75);
4751 border-radius: var(--border-radius-card);
4752 overflow: hidden;
4753 }
4754
4755 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container .image-player-session img {
4756 object-fit: cover;
4757 }
4758
4759 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container.image-playing .image-player-session img {
4760 width: 100%;
4761 height: 100%;
4762 margin-left: 0 !important;
4763 max-height: 100vh;
4764 }
4765
4766 .ptb-news__read-news .gallery .image-container img {
4767 width: 274px;
4768 height: 152px;
4769 border-radius: var(--border-radius-md, 8px);
4770 cursor: pointer;
4771 }
4772
4773 @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) {
4774
4775 .ptb-news__read-news .gallery {
4776 padding-top: var(--space-xl, 40px);
4777 }
4778
4779 .ptb-news__read-news .gallery .image-container {
4780 gap: var(--space-xxs, 8px);
4781 }
4782
4783 .ptb-news__read-news .gallery .image-container img {
4784 width: 296px;
4785 height: 180px;
4786 }
4787
4788 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container.image-playing .image-player-container.image-playing {
4789 transform: rotate(90deg);
4790 transform-origin: center;
4791 width: 80vh !important;
4792 height: 90vw !important;
4793 }
4794
4795 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container.image-playing .image-player-container.image-playing img{
4796 cursor: pointer;
4797 }
4798
4799 .ptb-news__read-news .gallery .image-container .modal-image-fragment .modal-image-container .image-player-container.image-playing .image-player-session {
4800 width: 80vh !important;
4801 height: 90vw !important;
4802 }
4803
4804 .ptb-news__read-news .gallery .lefg-arrow svg {
4805 margin-left: 4px !important;
4806 }
4807
4808 .ptb-news__read-news .gallery .right-arrow svg {
4809 margin-right: 4px !important;
4810 }
4811
4812 .ptb-news__read-news .gallery .image-bullets {
4813 gap: 14px;
4814 }
4815
4816 .ptb-news__read-news .gallery .image-bullets .bullet {
4817 width: var(--size-xxs, 12px);
4818 height: var(--size-xxs, 12px);
4819 }
4820
4821 .ptb-news__read-news .gallery .lefg-arrow svg {
4822 margin-left: 4px !important;
4823 }
4824
4825 .ptb-news__read-news .gallery .right-arrow svg {
4826 margin-right: 4px !important;
4827 }
4828
4829 .ptb-news__read-news .gallery .image-bullets {
4830 gap: 14px;
4831 }
4832
4833 .ptb-news__read-news .gallery .image-bullets .bullet {
4834 width: var(--size-xxs, 12px);
4835 height: var(--size-xxs, 12px);
4836 }
4837 }
4838
4839 </style>
4840
4841 <script>
4842
4843
4844 const allModalImagesFragment = document.querySelectorAll(".ptb-news__read-news .gallery .modal-image-fragment");
4845 const totalItems = allModalImagesFragment.length;
4846 const bulletsContainer = document.querySelector(".ptb-news__read-news .gallery .image-bullets");
4847 const bullets = bulletsContainer.querySelectorAll(".bullet");
4848 let currentItem = 0;
4849 const nextImage = document.querySelector(".ptb-news__read-news .gallery .right-arrow");
4850 const previousImage = document.querySelector(".ptb-news__read-news .gallery .left-arrow");
4851
4852 const stopImage = (getImageClick, imagePlayerContainer, imageContainer, closeImage) => {
4853 getImageClick.classList.remove('image-playing');
4854 imagePlayerContainer.classList.remove('image-playing');
4855 imageContainer.classList.remove('image-playing');
4856
4857 const currentBullet = document.querySelector('.ptb-news__read-news .gallery .image-bullets .bullet[index="' + currentItem + '"]')
4858 currentBullet && currentBullet.classList.remove('current-item');
4859
4860 closeImage.classList.remove('image-active');
4861
4862 document.querySelector("body").style.overflow = 'initial';
4863 [nextImage, previousImage].forEach(item => {
4864 item.style.display = "none";
4865 });
4866 bulletsContainer.style.display = "none";
4867 }
4868
4869 const playImage = (index, getImageClick, imagePlayerContainer, imageContainer, closeImage) => {
4870 getImageClick.classList.add('image-playing');
4871 imagePlayerContainer.classList.add('image-playing');
4872 imageContainer.classList.add('image-playing');
4873 closeImage.classList.add('image-active');
4874
4875
4876 document.querySelector("body").style.overflow = 'hidden';
4877 [nextImage, previousImage].forEach(item => {
4878 item.style.display = "flex";
4879 });
4880 bulletsContainer.style.display = "flex";
4881 bullets[index].classList.add('current-item');
4882 }
4883
4884 const changeImage = (next) => {
4885 if(next == currentItem || next < 0 || next >= totalItems) return;
4886
4887 const getImageClick = allModalImagesFragment[currentItem].querySelector('.click-image');
4888 const imageContainer = allModalImagesFragment[currentItem].querySelector('.modal-image-container');
4889 const imagePlayerContainer = allModalImagesFragment[currentItem].querySelector('.image-player-container');
4890 const image = imagePlayerContainer.querySelector('img');
4891 const closeImage = imagePlayerContainer.querySelector('.close-image');
4892
4893 const currentBullet = document.querySelector('.ptb-news__read-news .gallery .image-bullets .bullet[index="' + currentItem + '"]')
4894 currentBullet.classList.remove('current-item');
4895
4896 stopImage(getImageClick, imagePlayerContainer, imageContainer, closeImage);
4897 allModalImagesFragment[next].querySelector('.click-image')?.click();
4898
4899 const nextBullet = document.querySelector('.ptb-news__read-news .gallery .image-bullets .bullet[index="' + next + '"]')
4900 nextBullet.classList.add('current-item');
4901 currentItem = next;
4902 }
4903
4904 nextImage.addEventListener('click', () => {
4905 changeImage(currentItem + 1);
4906 });
4907
4908 previousImage.addEventListener('click', () => {
4909 changeImage(currentItem - 1);
4910 });
4911
4912 bullets.forEach((bullet, bulletIndex) => {
4913 bullet.addEventListener('click', (_) => changeImage(bulletIndex)) ;
4914 });
4915
4916 allModalImagesFragment.forEach((modalImageFragment, index)=>{
4917 const totalItems = allModalImagesFragment.length;
4918 const bulletsContainer = document.querySelector(".ptb-news__read-news .gallery .image-bullets");
4919 const bullets = bulletsContainer.querySelectorAll(".bullet");
4920 let currentItem = 0;
4921 const nextImage = document.querySelector(".ptb-news__read-news .gallery .right-arrow");
4922 const previousImage = document.querySelector(".ptb-news__read-news .gallery .left-arrow");
4923
4924 const stopImage = (getImageClick, imagePlayerContainer, imageContainer, closeImage) => {
4925 getImageClick.classList.remove('image-playing');
4926 imagePlayerContainer.classList.remove('image-playing');
4927 imageContainer.classList.remove('image-playing');
4928
4929 const currentBullet = document.querySelector('.ptb-news__read-news .gallery .image-bullets .bullet[index="' + currentItem + '"]')
4930 currentBullet && currentBullet.classList.remove('current-item');
4931
4932 closeImage.classList.remove('image-active');
4933
4934 document.querySelector("body").style.overflow = 'initial';
4935 [nextImage, previousImage].forEach(item => {
4936 item.style.display = "none";
4937 });
4938 bulletsContainer.style.display = "none";
4939 }
4940
4941 const playImage = (index, getImageClick, imagePlayerContainer, imageContainer, closeImage) => {
4942 getImageClick.classList.add('image-playing');
4943 imagePlayerContainer.classList.add('image-playing');
4944 imageContainer.classList.add('image-playing');
4945 closeImage.classList.add('image-active');
4946
4947
4948 document.querySelector("body").style.overflow = 'hidden';
4949 [nextImage, previousImage].forEach(item => {
4950 item.style.display = "flex";
4951 });
4952 bulletsContainer.style.display = "flex";
4953 bullets[index].classList.add('current-item');
4954 }
4955
4956 const changeImage = (next) => {
4957 if(next == currentItem || next < 0 || next >= totalItems) return;
4958
4959 const getImageClick = allModalImagesFragment[currentItem].querySelector('.click-image');
4960 const imageContainer = allModalImagesFragment[currentItem].querySelector('.modal-image-container');
4961 const imagePlayerContainer = allModalImagesFragment[currentItem].querySelector('.image-player-container');
4962 const image = imagePlayerContainer.querySelector('img');
4963 const closeImage = imagePlayerContainer.querySelector('.close-image');
4964
4965 const currentBullet = document.querySelector('.ptb-news__read-news .gallery .image-bullets .bullet[index="' + currentItem + '"]')
4966 currentBullet.classList.remove('current-item');
4967
4968 stopImage(getImageClick, imagePlayerContainer, imageContainer, closeImage);
4969 allModalImagesFragment[next].querySelector('.click-image')?.click();
4970
4971 const nextBullet = document.querySelector('.ptb-news__read-news .gallery .image-bullets .bullet[index="' + next + '"]')
4972 nextBullet.classList.add('current-item');
4973 currentItem = next;
4974 }
4975
4976 nextImage.addEventListener('click', () => {
4977 changeImage(currentItem + 1);
4978 });
4979
4980 previousImage.addEventListener('click', () => {
4981 changeImage(currentItem - 1);
4982 });
4983
4984 bullets.forEach((bullet, bulletIndex) => {
4985 bullet.addEventListener('click', (_) => changeImage(bulletIndex)) ;
4986 });
4987
4988 allModalImagesFragment.forEach((modalImageFragment, index)=>{
4989 const getImageClick = modalImageFragment.querySelector('.click-image');
4990 const imageContainer = modalImageFragment.querySelector('.modal-image-container');
4991 const imagePlayerContainer = modalImageFragment.querySelector('.image-player-container');
4992
4993 const image = imagePlayerContainer.querySelector('img');
4994 const closeImage = imagePlayerContainer.querySelector('.close-image');
4995 const body = document.body;
4996
4997 const toTopButton = document.querySelector(".fragment_88038 .petro-button");
4998
4999 getImageClick.addEventListener('click', () => {
5000 if (document.body.classList.contains('has-edit-mode-menu')) {
5001 return;
5002 }
5003 currentItem = index;
5004 currentItem = index;
5005 if (imagePlayerContainer.classList.contains('image-playing')) {
5006 toTopButton && (toTopButton.style.zIndex = "");
5007 stopImage(getImageClick, imagePlayerContainer, imageContainer, closeImagegetImageClick, imagePlayerContainer, imageContainer, closeImage);
5008 } else {
5009 playImage(index, getImageClick, imagePlayerContainer, imageContainer, closeImageindex, getImageClick, imagePlayerContainer, imageContainer, closeImage);
5010 toTopButton && (toTopButton.style.zIndex = "1");
5011 }
5012 })
5013
5014 closeImage.addEventListener('click', () => {
5015 if (imagePlayerContainer.classList.contains('image-playing')) {
5016 toTopButton && (toTopButton.style.zIndex = "");
5017 stopImage(getImageClick, imagePlayerContainer, imageContainer, closeImage);
5018 const bulletToClose = document.querySelector('.ptb-news__read-news .gallery .image-bullets .bullet[index="' + index + '"]')
5019 bulletToClose?.classList.remove('current-item');
5020 }
5021 })
5022 });
5023 </script>
5024
5025</#macro>
5026
5027
5028<#-- ################################################################################################################## -->
5029
5030
5031
5032
5033
5034
5035
5036
5037
5038
5039
5040
5041
5042 <#-- ############# Site de Crise - Notícia - Galeria de imagens ####################################################### -->
5043<#macro renderQuotes newsInfo>
5044 <#if newsInfo.quotes?size != 0>
5045 <#--quotes "escondidas" que serão unidas a .ptb-news__read-content -->
5046
5047 <div class="ptb-news__quotes-container d-none ">
5048 <div id="ptb-news__quotes-identifiers">
5049 <#assign separator = "">
5050 <#list newsInfo.quotes as quote>
5051 ${quote.id};
5052 <#assign separator = ";">
5053 </#list>
5054 </div>
5055 <#list newsInfo.quotes as quote>
5056 <#assign quotes_index = quote?index>
5057 <div id="ptb-news__quotes-container-${quote_index}">
5058 <#assign noAuthorWrapper = !((quote.image.url?? && quote.image.url?has_content) || (quote.author?has_content)) />
5059 <div class="quote <#if noAuthorWrapper>no-author-wrapper</#if>">
5060 <div class="text-wrapper">
5061 <blockquote class="text">${quote.content}</blockquote >
5062 </div>
5063 <#if !noAuthorWrapper>
5064 <div class="author-wrapper">
5065 <#if quote.image.url?? && quote.image.url?has_content>
5066 <#assign imageUrl = "/o/adaptive-media/image/" + quote.image.fileEntryId +"/Thumbnail-300x300/image"/>
5067 <img src="${imageUrl}" loading="lazy" alt="${quote.image.alt}">
5068 </#if>
5069 <#if quote.author?? && quote?has_content>
5070 <p class="author">${quote.author}</p>
5071 </#if>
5072 </div>
5073 </#if>
5074 </div>
5075 </div>
5076 </#list>
5077 </div>
5078
5079 <script>
5080 var newsContent_code = document.querySelector(".news-content").innerHTML;
5081
5082 var quotesIdentifiers = document.querySelector("#ptb-news__quotes-identifiers").innerHTML.trim().split(";");
5083 quotesIdentifiers.forEach((quoteIdentifier, index) => {
5084 const quoteIdentifierContent = document.querySelector("#ptb-news__quotes-container-" + index);
5085 if (quoteIdentifierContent) {
5086 const tag = "#[" + quoteIdentifier.trim() + "]";
5087 const splitContent = newsContent_code.split(tag);
5088 newsContent_code = splitContent.join(quoteIdentifierContent.innerHTML);
5089 //linkIdentifierContent.parentNode.removeChild(linkIdentifierContent);
5090 }
5091 });
5092
5093
5094 var ptb_news__read_content = document.querySelector(".news-content");
5095 ptb_news__read_content.innerHTML = newsContent_code;
5096
5097 </script>
5098
5099 <style>
5100
5101 .ptb-news__read-news .quote {
5102 display: flex;
5103 flex-direction: column;
5104 gap: var(--space-md, 24px);
5105 }
5106
5107 .ptb-news__read-news .quote.no-author-wrapper{
5108 gap: 0;
5109 }
5110
5111 .ptb-news__read-news .quote .text-wrapper {
5112 padding-left: var(--space-xl, 40px);
5113 }
5114
5115 .ptb-news__read-news .quote .text-wrapper .text {
5116 font-style: var(--font-style-italic) !important;
5117 padding-left: var(--space-md, 24px);
5118 margin-bottom: 0;
5119 border-left: 1px solid var(--border-color-mid, #d7d7d7);
5120 font-size: var(--font-size-xxs, 16px);
5121 }
5122
5123 .ptb-news__read-news .quote .author-wrapper {
5124 display: flex;
5125 flex-direction: row;
5126 gap: var(--space-md, 24px);
5127 }
5128
5129 .ptb-news__read-news .news-content .quote .author-wrapper img {
5130 height: var(--size-xxxl, 56px);
5131 width: var(--size-xxxl, 56px);
5132 border-radius: 100px;
5133 border: var(--size-nano, 2px) solid var(--border-color-mid) !important;
5134 }
5135
5136 .ptb-news__read-news .news-content .quote .author-wrapper p {
5137 margin: 0;
5138 align-self: center;
5139 font-size: var(--font-size-xs, 18px);
5140 font-style: var(--font-style-normal, normal);
5141 font-weight: var(--font-weight-bold, 700);
5142 line-height: var(--line-height-xs, 100%);
5143 }
5144
5145 @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) {
5146 .ptb-news__read-news .quote .text-wrapper {
5147 padding-left: 0;
5148 }
5149
5150 .ptb-news__read-news .quote .text-wrapper .text {
5151 font-size: var(--font-size-xxxs, 14px);
5152 }
5153
5154 .ptb-news__read-news .news-content .quote .author-wrapper p {
5155 font-size: var(--font-size-xxs, 16px);
5156 }
5157 }
5158 </style>
5159 </#if>
5160</#macro>
5161
5162
5163
5164
5165<#-- ################################################################################################################## -->
5166
5167
5168
5169
5170
5171
5172
5173
5174<#-- ############# Site de Crise - Notícia - Extrair dados de Notícias ################################################ -->
5175<#--
5176Add elements from the sidebar to define your template. Type "${" to use the
5177autocomplete feature.
5178-->
5179<#function extractFeaturedNewsHeadline fieldList xmlArticle>
5180 <#return getFieldValue(fieldList, xmlArticle, "Título de destaque da notícia")>
5181</#function>
5182
5183<#function extractNewsSummary fieldList xmlArticle>
5184 <#return getFieldValue(fieldList, xmlArticle, "Resumo da notícia")>
5185</#function>
5186
5187<#function extractPublishDate journalArticle>
5188 <#assign lastPublishDate = journalArticle.getModifiedDate()>
5189 <#if journalArticle.getLastPublishDate()??>
5190 <#assign lastPublishDate = journalArticle.getLastPublishDate()>
5191 <#else>
5192 <#assign lastPublishDate = journalArticle.getModifiedDate()>
5193 </#if>
5194 <#return lastPublishDate />
5195</#function>
5196
5197<#-- Seção da imagem de destaque ---------------------------------------------------------------------->
5198<#function extractNewsMedia fieldList xmlArticle fileEntryService>
5199 <#-- Tentando pegar Imagem -->
5200 <#assign mediasGroup = getNodes(getIdFromFieldName(fieldList, "Mídia de destaque da notícia"), xmlArticle) />
5201 <#assign media = {} />
5202 <#list mediasGroup as mediaGroup >
5203 <#assign media = getMediaInfo(fieldList, mediaGroup, "Imagem Destaque", fileEntryService) />
5204 <#assign media = {"imageSrc": media.url, "imageAlt": media.alt, "fileEntryId" : media.fileEntryId} />
5205
5206 <#-- Se não tiver imagem, tentar pegar vídeo -->
5207 <#if !media.imageSrc?has_content>
5208 <#assign youtubeID = getFieldValue(fieldList, mediaGroup, "ID do vídeo do YouTube do vídeo de destaque") />
5209 <#if youtubeID?? && youtubeID?has_content>
5210 <#assign media = {"videoYotubeID": youtubeID} />
5211 <#else>
5212 <#-- Tentar pegar vídeo Interno -->
5213 <#assign internalVideo = getMediaInfo(fieldList, mediaGroup, "Fazer upload de um vídeo de destaque", fileEntryService) />
5214 <#if internalVideo?? && internalVideo?has_content>
5215 <#assign media = {"internalVideo": internalVideo} />
5216 </#if>
5217 </#if>
5218 </#if>
5219
5220 <#assign referenceMediasGroup = getNodes(getIdFromFieldName(fieldList, "Referências"), mediaGroup) />
5221 <#list referenceMediasGroup as referenciaMediaGroup >
5222 <#assign credits = getFieldValue(fieldList, referenceMediasGroup, "Crédito da mídia de destaque da notícia") />
5223 <#assign legend = getFieldValue(fieldList, referenceMediasGroup, "Legenda da mídia de destaque da notícia") />
5224 </#list>
5225
5226 <#assign media = media + {"credits": credits, "legend": legend} />
5227
5228 </#list>
5229
5230 <#return media>
5231</#function>
5232
5233
5234<#--------------------- Renderização de Lista de Cards ----------------------------------------------->
5235
5236<#-- Root Css -> Para poder instanciar dois elementos e não dar confusão no JS -->
5237<#assign rootCss = "card-news-list-container_" + randomNumber(4586) />
5238
5239<#attempt>
5240 <#assign ourEnergyStyles = [] />
5241 <#list ourEnergyVocabulary.getCategories() as ourEnergyCategory >
5242 <#assign shadowColorCategory = "" />
5243 <#if (assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor da Sombra")??)>
5244 <#assign categoryShadowColorByService = assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor da Sombra") />
5245 <#assign shadowColorCategory = categoryShadowColorByService.value />
5246 </#if>
5247
5248 <#assign backgroundColorCategory = "" />
5249 <#if (assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor de Fundo")??)>
5250 <#assign categoryBackgroundColorByService = assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor de Fundo") />
5251 <#assign backgroundColorCategory = categoryBackgroundColorByService.value />
5252 </#if>
5253
5254 <#assign textColorCategory = "" />
5255 <#if (assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor do Texto")??)>
5256 <#assign categoryTextColorByService = assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor do Texto") />
5257 <#assign textColorCategory = categoryTextColorByService.value />
5258 </#if>
5259
5260 <#assign textColorHighContrastCategory = "" />
5261 <#if (assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor do Texto em Alto Contraste")??)>
5262 <#assign categoryTextColorHighContrastByService = assetCategoryPropService.fetchCategoryProperty(ourEnergyCategory.getCategoryId(),"Cor do Texto em Alto Contraste") />
5263 <#assign textColorHighContrastCategory = categoryTextColorHighContrastByService.value />
5264 </#if>
5265
5266 <#assign ourEnergyStyles += [{"titleLocale": ourEnergyCategory.getTitle(locale),"shadowColor": shadowColorCategory, "backgroundColor": backgroundColorCategory, "textColor": textColorCategory, "textColorHighContrast": textColorHighContrastCategory}] />
5267 </#list>
5268
5269 <#recover>
5270 <#assign ourEnergyStyles = [] />
5271
5272</#attempt>
5273
5274<#-- Função para obter a primeira categoria associonada a um Vocabulário o qual está associado a um Jornal Article -->
5275<#function getFirstCategoryTitleLocaleOfVocabulary journalArticle vocabulary >
5276 <#attempt>
5277 <#assign categories = assetCategoryLocalService.getCategories("com.liferay.journal.model.JournalArticle", journalArticle.getClassPK()) />
5278
5279 <#list categories as category>
5280 <#if vocabulary.getVocabularyId() == category.getVocabularyId()>
5281 <#return category.getTitle(locale)>
5282 </#if>
5283 </#list>
5284
5285 <#return "">
5286
5287 <#recover>
5288 <#return "" />
5289
5290 </#attempt>
5291</#function>
5292
5293<#-- Função para obter os dados de um card no Web Content (Journal Article) -->
5294<#function getDataForCard entry >
5295 <#attempt>
5296 <#assign journalArticle = journalArticleLocalService.getLatestArticle(entry.getClassPK()) />
5297 <#assign ddmStructure = journalArticle.getDDMStructure() />
5298 <#assign fieldList = getFieldListByStructure(ddmStructure) />
5299 <#assign xmlArticle = journalArticle.getDocument().getRootElement() />
5300
5301 <#-- Tentando pegar Imagem -->
5302 <#assign mediasGroup = getNodes(getIdFromFieldName(fieldList, "Mídia de destaque da notícia"), xmlArticle) />
5303 <#assign media = "" />
5304 <#list mediasGroup as mediaGroup >
5305 <#assign media = getMediaInfo(fieldList, mediaGroup, "Imagem Destaque", fileEntryService) />
5306
5307 <#assign fileDataRequest = restClient.get("/headless-delivery/v1.0/documents/${media.fileEntryId}") />
5308
5309 <#assign urlAdaptativeMediaDesktop = ""/>
5310 <#assign urlAdaptativeMediaMobile = ""/>
5311 <#if media.url?? && media.url?has_content && fileDataRequest?? && fileDataRequest.adaptedImages?? >
5312 <#assign dataAdaptativeMedia = fileDataRequest.adaptedImages />
5313 <#list dataAdaptativeMedia as data>
5314 <#if data.resolutionName == adaptativeMediaDesktopResolutionName>
5315 <#assign urlAdaptativeMediaDesktop = data.contentUrl/>
5316 </#if>
5317 <#if data.resolutionName == adaptativeMediaMobileResolutionName>
5318 <#assign urlAdaptativeMediaMobile = data.contentUrl/>
5319 </#if>
5320 </#list>
5321 </#if>
5322 <#assign media = {"imageSrc": media.url, "imageAlt": media.alt, "imageFileEntryId": media.fileEntryId, "urlAdaptativeMedia": {"mobile": urlAdaptativeMediaMobile, "desktop": urlAdaptativeMediaDesktop}} />
5323
5324 <#-- Se não tiver imagem, tentar pegar vídeo -->
5325 <#if !media.imageSrc?? || !media.imageSrc?has_content>
5326 <#assign youtubeID = getFieldValue(fieldList, mediaGroup, "ID do vídeo do YouTube do vídeo de destaque") />
5327 <#if youtubeID?? && youtubeID?has_content>
5328 <#assign media = {"videoYotubeID": youtubeID} />
5329 <#else>
5330 <#-- Tentar pegar vídeo Interno -->
5331 <#assign internalVideo = getMediaInfo(fieldList, mediaGroup, "Fazer upload de um vídeo de destaque", fileEntryService) />
5332 <#if internalVideo?? && internalVideo?has_content>
5333 <#assign media = {"internalVideo": internalVideo} />
5334 </#if>
5335 </#if>
5336 </#if>
5337 </#list>
5338
5339 <#assign title = getFieldValue(fieldList, xmlArticle, "Título de destaque da notícia") />
5340
5341 <#assign timeRead = getFieldValue(fieldList, xmlArticle, "Tempo de Leitura") />
5342
5343 <#assign ourEnergyCategory = getFirstCategoryTitleLocaleOfVocabulary(entry, ourEnergyVocabulary) />
5344
5345 <#assign typeOfNews = getFirstCategoryTitleLocaleOfVocabulary(entry, typeOfNewsVocabulary) />
5346
5347 <#if themeDisplay.getPortalURL()?contains("webserver")>
5348 <#assign urlNews = themeDisplay.getPortalURL() + themeDisplay.getPathFriendlyURLPublic() + layout.getGroup().friendlyURL + "/w/" + journalArticle.getUrlTitle()>
5349 <#else>
5350 <#assign urlNews = themeDisplay.getPortalURL() + "/w/" + journalArticle.getUrlTitle()>
5351 </#if>
5352
5353 <#assign cardData = {"media": media, "title": title, "timeRead": timeRead, "ourEnergyCategory": ourEnergyCategory, "typeOfNews": typeOfNews, "urlNews": urlNews} />
5354
5355 <#return cardData>
5356
5357 <#recover>
5358 <#return {} />
5359 </#attempt>
5360
5361 <#-- cardData -> image: url, alt
5362 title
5363 timeRead
5364 ourEnergyCategory
5365 typeOfNews
5366 urlNews
5367 -->
5368</#function>
5369
5370
5371<#-- Macro para renderizar os arrows-->
5372<#macro renderArrows>
5373 <div class="card-news-list-arrows-breakpoint">
5374 <div class="card-news-list-arrows">
5375 <div class="card-news-arrow-left arrow-disable">
5376 <svg width="34" height="34" viewBox="0 0 34 34" fill="none" xmlns="http://www.w3.org/2000/svg">
5377 <path d="M1 17C1 8.16344 8.16344 1 17 1C25.8366 1 33 8.16344 33 17C33 25.8366 25.8366 33 17 33C8.16344 33 1 25.8366 1 17Z" stroke="#959595"/>
5378 <path d="M22.5 17H11.5M11.5 17L16 12.5M11.5 17L16 21.5" stroke="#525252" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
5379 </svg>
5380 </div>
5381 <div class="card-news-arrow-right">
5382 <svg width="34" height="34" viewBox="0 0 34 34" fill="none" xmlns="http://www.w3.org/2000/svg">
5383 <path d="M1 17C1 8.16344 8.16344 1 17 1C25.8366 1 33 8.16344 33 17C33 25.8366 25.8366 33 17 33C8.16344 33 1 25.8366 1 17Z" stroke="#008542"/>
5384 <path d="M11.5 17H22.5M22.5 17L18 12.5M22.5 17L18 21.5" stroke="#008542" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round"/>
5385 </svg>
5386
5387 </div>
5388 </div>
5389 </div>
5390
5391 <style>
5392
5393 .${rootCss} .card-news-list-arrows-breakpoint {
5394 position: relative;
5395 z-index: 1;
5396 width: 100%;
5397 }
5398
5399 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows {
5400 display: flex;
5401 align-items: flex-start;
5402 justify-self: flex-end;
5403 gap: var(--space-xxs, 8px);
5404 }
5405
5406 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left,
5407 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right {
5408 cursor: pointer;
5409 }
5410
5411 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left:not(.arrow-disable):hover path:nth-child(1),
5412 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right:not(.arrow-disable):hover path:nth-child(1) {
5413 fill: rgb(0, 133, 66);
5414 }
5415
5416 body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left:not(.arrow-disable):hover path:nth-child(1),
5417 body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right:not(.arrow-disable):hover path:nth-child(1) {
5418 fill: white;
5419 }
5420
5421 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left:not(.arrow-disable):hover path:nth-child(2),
5422 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right:not(.arrow-disable):hover path:nth-child(2) {
5423 stroke: #fff;
5424 }
5425
5426 body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left:not(.arrow-disable):hover path:nth-child(2),
5427 body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right:not(.arrow-disable):hover path:nth-child(2) {
5428 stroke: #010101;
5429 }
5430
5431 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left.arrow-disable,
5432 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right.arrow-disable {
5433 opacity: 0.4;
5434 cursor: auto;
5435 }
5436
5437 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left path,
5438 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right path {
5439 stroke: rgb(0, 133, 66);
5440 transition: all 300ms ease-in-out;
5441 }
5442
5443 body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left path,
5444 body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right path {
5445 stroke: rgba(228, 247, 232, 1);
5446 }
5447
5448 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left.arrow-disable path:nth-child(1),
5449 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right.arrow-disable path:nth-child(1) {
5450 stroke: rgb(149, 149, 149);
5451 }
5452
5453 body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left.arrow-disable path:nth-child(1),
5454 body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right.arrow-disable path:nth-child(1) {
5455 stroke: rgba(215, 215, 215, 1);
5456 }
5457
5458 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left.arrow-disable path:nth-child(2),
5459 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right.arrow-disable path:nth-child(2) {
5460 stroke: rgb(82, 82, 82);
5461 }
5462
5463 body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-left.arrow-disable path:nth-child(2),
5464 body.high-contrast-active .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows .card-news-arrow-right.arrow-disable path:nth-child(2) {
5465 stroke: rgba(149, 149, 149, 1);
5466 }
5467
5468 @media screen and (min-width: 1440px) {
5469 .${rootCss} .card-news-list-arrows-breakpoint {
5470 width: 100%;
5471 }
5472 }
5473
5474 @media screen and (max-width: ${MAX_MOBILE_WIDTH}px) {
5475
5476 .${rootCss} .card-news-list-arrows-breakpoint .card-news-list-arrows {
5477 justify-self: flex-start;
5478 margin-top: var(--space-lg);
5479 }
5480 }
5481
5482 </style>
5483
5484</#macro>
5485
5486
5487<#-- Macro para renderizar um Card -->
5488<#macro renderCard cardData>
5489 <#-- cardData -> image: url, alt
5490 title
5491 timeRead
5492 ourEnergyCategory
5493 typeOfNews
5494 urlNews
5495 -->
5496
5497 <div class="card-news-container">
5498 <a class="news-page-see-more-link card-news-link" href="${cardData.urlNews}"> Link da Notícia ${cardData.title} </a>
5499 <div class="card-news-thumb">
5500 <#assign noImage = "" />
5501 <#if cardData.media.imageSrc?? && cardData.media.imageSrc?has_content>
5502 <#assign imageSrcDesktop = cardData.media.imageSrc />
5503 <#assign imageSrcMobile = cardData.media.imageSrc />
5504 <#if cardData.media.urlAdaptativeMedia?? && cardData.media.urlAdaptativeMedia?has_content>
5505 <#assign imageSrcDesktop = cardData.media.urlAdaptativeMedia.desktop />
5506 <#assign imageSrcMobile = cardData.media.urlAdaptativeMedia.mobile />
5507 </#if>
5508 <picture >
5509 <source media="(max-width:767px)" srcset="${imageSrcMobile}">
5510 <img class="card-news-image" loading="lazy" src="${imageSrcDesktop}" alt="${cardData.media.imageAlt}"/>
5511 </picture>
5512 <#else>
5513 <#if cardData.media.videoYotubeID?? && cardData.media.videoYotubeID?has_content>
5514 <picture >
5515 <source media="(max-width:767px)" srcset="https://img.youtube.com/vi/${cardData.media.videoYotubeID}/mqdefault.jpg">
5516 <img class="card-news-image" loading="lazy" src="https://img.youtube.com/vi/${cardData.media.videoYotubeID}/maxresdefault.jpg" alt="YouTube Thumbnail"/>
5517 </picture>
5518 <#else>
5519 <#if (cardData.media.internalVideo?? && cardData.media.internalVideo.url?has_content) >
5520 <video class="card-news-image" loading="lazy">
5521 <source src="${cardData.media.internalVideo.url}">
5522 Your browser does not support the video tag.
5523 </video>
5524 <#else>
5525 <#assign noImage = "no-image" />
5526 </#if>
5527 </#if>
5528 <svg class="thumb-play-icon" width="32" height="32" viewBox="0 0 32 32" fill="none" xmlns="http://www.w3.org/2000/svg">
5529 <path d="M0 16C0 7.16344 7.16344 0 16 0C24.8366 0 32 7.16344 32 16C32 24.8366 24.8366 32 16 32C7.16344 32 0 24.8366 0 16Z" fill="white" fill-opacity="0.8"/>
5530 <path d="M22.2563 15.5744L13.2625 10.0744C13.1868 10.0277 13.1 10.0021 13.0111 10.0001C12.9221 9.99816 12.8343 10.02 12.7566 10.0633C12.6789 10.1066 12.6141 10.1698 12.569 10.2465C12.5239 10.3232 12.5001 10.4105 12.5 10.4994V21.4994C12.5001 21.5884 12.5239 21.6757 12.569 21.7524C12.6141 21.8291 12.6789 21.8923 12.7566 21.9356C12.8343 21.9789 12.9221 22.0007 13.0111 21.9988C13.1 21.9968 13.1868 21.9712 13.2625 21.9244L22.2563 16.4244C22.3301 16.3808 22.3913 16.3186 22.4338 16.2441C22.4763 16.1696 22.4987 16.0852 22.4987 15.9994C22.4987 15.9137 22.4763 15.8293 22.4338 15.7548C22.3913 15.6803 22.3301 15.6181 22.2563 15.5744Z" fill="#008542"/>
5531 </svg>
5532 </#if>
5533 </div>
5534
5535 <div class="card-news-category-container ${noImage}">
5536 <div data-category="${cardData.ourEnergyCategory}" class="card-news-category paragraph-micro-regular"> ${cardData.ourEnergyCategory} </div>
5537 </div>
5538
5539 <div class="card-news-text-content ${noImage}">
5540 <div class="card-news-title h5"> ${cardData.title} </div>
5541
5542 <div class="card-news-info">
5543 <div class="card-news-type">
5544 <#if getPostTypeImageUrl(POST_TYPES_CATEGORIES, (cardData.typeOfNews)!default(""))?? >
5545 <#assign postTypeIconUrl = getPostTypeImageUrl(POST_TYPES_CATEGORIES, (cardData.typeOfNews)!default("")) />
5546 <img src="${postTypeIconUrl}" loading="lazy" alt="post type icon" />
5547 <div class="card-news-type-text paragraph-micro-regular">${cardData.typeOfNews}</div>
5548 <#else/>
5549 <svg width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg">
5550 <path d="M6.25 7.5H13.75M6.25 10H13.75M6.25 12.5H13.75M3.125 3.75H16.875C17.2202 3.75 17.5 4.02982 17.5 4.375V15.625C17.5 15.9702 17.2202 16.25 16.875 16.25H3.125C2.77982 16.25 2.5 15.9702 2.5 15.625V4.375C2.5 4.02982 2.77982 3.75 3.125 3.75Z" stroke="#959595" stroke-linecap="round" stroke-linejoin="round"/>
5551 </svg>
5552 <div class="card-news-type-text paragraph-micro-regular">Artigo</div>
5553 </#if>
5554 </div>
5555
5556 <#if cardData.timeRead?? && cardData.timeRead?has_content>
5557 <div class="card-news-time-read">
5558 <svg class="card-news-icon-time-read" width="20" height="20" viewBox="0 0 20 20" fill="none" xmlns="http://www.w3.org/2000/svg">
5559 <path d="M10.5 5.625C10.5 5.34886 10.2761 5.125 10 5.125C9.72386 5.125 9.5 5.34886 9.5 5.625H10.5ZM10 10H9.5C9.5 10.2761 9.72386 10.5 10 10.5V10ZM14.375 10.5C14.6511 10.5 14.875 10.2761 14.875 10C14.875 9.72386 14.6511 9.5 14.375 9.5V10.5ZM17 10C17 13.866 13.866 17 10 17V18C14.4183 18 18 14.4183 18 10H17ZM10 17C6.13401 17 3 13.866 3 10H2C2 14.4183 5.58172 18 10 18V17ZM3 10C3 6.13401 6.13401 3 10 3V2C5.58172 2 2 5.58172 2 10H3ZM10 3C13.866 3 17 6.13401 17 10H18C18 5.58172 14.4183 2 10 2V3ZM9.5 5.625V10H10.5V5.625H9.5ZM10 10.5H14.375V9.5H10V10.5Z" fill="#959595"/>
5560 </svg>
5561
5562 <div class="card-news-time-read-text paragraph-micro-regular">${cardData.timeRead} min</div>
5563 </div>
5564 </#if>
5565 </div>
5566 </div>
5567 </div>
5568</#macro>
5569
5570<style>
5571 .${rootCss} .card-news-container {
5572 width: 300px;
5573 height: 370px;
5574 display: flex;
5575 flex-direction: column;
5576 flex-shrink: 0;
5577 align-items: flex-start;
5578 border-radius: var(--border-radius-lg);
5579 border: var(--border-width-hairline) solid var(--border-card-default, #EEE);
5580 background: var(--background-surface-level-01, #FFF);
5581 box-shadow: 0px 12px 60px -10px rgba(145, 147, 149, 0.12);
5582 overflow: hidden;
5583 scroll-snap-align: start;
5584 cursor: pointer;
5585 transition: border 300ms ease-in-out;
5586 text-decoration: none;
5587 position: relative;
5588 }
5589
5590 body.high-contrast-active .${rootCss} .card-news-container {
5591 border: var(--border-width-hairline) solid var(--border-card-default, #525252);
5592 background: var(--background-surface-level-01, #010101);
5593 }
5594
5595 .${rootCss} .card-news-container:hover {
5596 border: var(--border-width-hairline) solid rgb(0, 133, 66);
5597 }
5598
5599 body.high-contrast-active .${rootCss} .card-news-container:hover {
5600 border: var(--border-width-hairline) solid var(--border-card-default, #E4F7E8);
5601 }
5602
5603 .${rootCss} .card-news-container .card-news-link {
5604 position: absolute;
5605 top: 0;
5606 width: 100%;
5607 height: 100%;
5608 z-index: 1;
5609 opacity: 0;
5610 }
5611
5612 .${rootCss} .card-news-container .card-news-thumb {
5613 position: relative;
5614 }
5615
5616 .${rootCss} .card-news-container .card-news-image {
5617 width: 298px;
5618 height: 168px;
5619 object-fit: cover;
5620 }
5621
5622
5623 .${rootCss} .card-news-container .card-news-thumb .thumb-play-icon {
5624 position: absolute;
5625 left: 50%;
5626 top: 50%;
5627 transform: translate(-50%, -50%);
5628 }
5629
5630 body.high-contrast-active .${rootCss} .card-news-container .card-news-thumb .thumb-play-icon path:nth-child(1) {
5631 fill: black;
5632 }
5633
5634 body.high-contrast-active .${rootCss} .card-news-container .card-news-thumb .thumb-play-icon path:nth-child(2) {
5635 fill: white;
5636 }
5637
5638 .${rootCss} .card-news-container .card-news-category-container {
5639 position: relative;
5640 }
5641
5642 .${rootCss} .card-news-container .card-news-category-container .card-news-category {
5643 display: flex;
5644 justify-content: center;
5645 align-items: center;
5646 padding: var(--space-micro) var(--space-xs);
5647 position: absolute;
5648 z-index: 2;
5649 left: var(--space-md);
5650 top: -13px;
5651 border-radius: var(--border-radius-pill);
5652 background: linear-gradient(0deg, var(--background-surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 0%, var(--background-surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 100%), var(--default-sup-green-water, #006B65);
5653 box-shadow: 0px 2px 6px 0px rgba(0, 178, 169, 0.10);
5654 line-height: var(--line-height-lg, 144%);
5655 color: var(--default-sup-green-water, #006B65);
5656 white-space: nowrap;
5657 }
5658
5659 body.high-contrast-active .${rootCss} .card-news-container .card-news-category-container .card-news-category {
5660 background: linear-gradient(0deg, var(--background-surface-opacity-light-level-07, #373737) 0%, var(--background-surface-opacity-light-level-07, #373737) 100%), var(--default-sup-green-water, #99E0DD);
5661 color: var(--default-sup-green-water, #99E0DD);
5662 }
5663
5664 .${rootCss} .card-news-container .card-news-category-container.no-image .card-news-category {
5665 position: relative;
5666 top: 0;
5667 left: 0;
5668 margin-left: var(--space-md);
5669 margin-top: var(--space-md);
5670 }
5671
5672 .${rootCss} .card-news-container .card-news-text-content {
5673 display: flex;
5674 padding: var(--space-lg, 32px) var(--space-md, 24px) var(--space-md, 24px) var(--space-md, 24px);
5675 flex-direction: column;
5676 justify-content: space-between;
5677 align-items: flex-start;
5678 flex: 1 0 0;
5679 align-self: stretch;
5680 }
5681
5682 .${rootCss} .card-news-container .card-news-text-content.no-image {
5683 padding-top: var(--space-sm);
5684 }
5685
5686 .${rootCss} .card-news-container .card-news-text-content .card-news-title {
5687 display: -webkit-box;
5688 -webkit-box-orient: vertical;
5689 -webkit-line-clamp: 4;
5690 align-self: stretch;
5691 overflow: hidden;
5692 color: var(--text-primary-default, #373737);
5693 text-overflow: ellipsis;
5694 margin: 0;
5695 }
5696
5697 body.high-contrast-active .${rootCss} .card-news-container .card-news-text-content .card-news-title {
5698 color: var(--text-primary-default, #FFF);
5699 }
5700
5701 .${rootCss} .card-news-container .card-news-text-content .card-news-info {
5702 display: flex;
5703 align-items: center;
5704 align-content: center;
5705 gap: var(--space-sm, 16px);
5706 align-self: stretch;
5707 flex-wrap: wrap;
5708 }
5709
5710 .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-type,
5711 .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-time-read {
5712 display: flex;
5713 align-items: center;
5714 gap: var(--space-xxs, 8px);
5715 }
5716
5717 body.high-contrast-active .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-type path {
5718 stroke: #D7D7D7;
5719 }
5720
5721 .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-type .card-news-type-text,
5722 .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-time-read .card-news-time-read-text {
5723 color: var(--text-tertiary-default, #959595);
5724 line-height: var(--line-height-lg, 144%);
5725 }
5726
5727 body.high-contrast-active .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-type .card-news-type-text,
5728 body.high-contrast-active .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-time-read .card-news-time-read-text {
5729 color: var(--text-tertiary-default, #EEE);
5730 }
5731
5732 .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-time-read .card-news-icon-time-read {
5733 transform: translateY(-0.5px);
5734 }
5735
5736 body.high-contrast-active .${rootCss} .card-news-container .card-news-text-content .card-news-info .card-news-time-read .card-news-icon-time-read path {
5737 fill: #D7D7D7;
5738 }
5739</style>
5740
5741<#assign maxNumberOfCards = 9/>
5742<#assign className = "com.liferay.journal.model.JournalArticle" />
5743<#assign classNameId = PortalUtil.getClassNameId(className) />
5744${AssetEntryQuery.setClassNameIds([classNameId]) }
5745${AssetEntryQuery.setEnd(maxNumberOfCards)}
5746
5747<#assign entries = []/>
5748<#assign ourEnergyCategoriesIds = getAllCategoryIdOfVocabulary(assetEntry, ourEnergyVocabulary) />
5749<#list ourEnergyCategoriesIds as ourEnergyCategoryId>
5750 ${AssetEntryQuery.setAllCategoryIds([ourEnergyCategoryId])}
5751 <#assign ents = AssetEntryQueryService.getEntries(AssetEntryQuery) />
5752 <#assign entries = entries + ents />
5753</#list>
5754
5755
5756<#-- Renderizar Lista de cards -->
5757<#if entries?has_content>
5758 <div class="${rootCss}">
5759 <div class="list-of-news-title breakpoint">
5760 <div class="list-of-news-title-col col-1-12 md-col-1-8 sm-col-1-4">
5761 <div class="list-title fragment_85017">
5762 <div class="petro-title">
5763 <h2 id="title" class="display-sm" style="color: var(--color-neutral-800)">
5764 <#if locale?lower_case == "pt_br"> Leia também <#else> Read also </#if>
5765 </h2>
5766 <div class="yellow-bar-container">
5767 <div class="yellow-bar bar-display-sm" style="background-color: var(--color-secondary-medium)"></div>
5768 <@renderArrows />
5769 </div>
5770 </div>
5771 </div>
5772 </div>
5773 </div>
5774
5775 <div class="card-news-list-breakpoint breakpoint">
5776 <div class="card-news-list col-1-12 md-col-1-8 sm-col-1-4">
5777 <#if entries?size gt maxNumberOfCards>
5778 <#assign entries = entries[0..maxNumberOfCards] />
5779 </#if>
5780 <#list entries as entry>
5781 <#if assetEntry.getClassPK() != entry.getClassPK() >
5782 <#assign cardData = getDataForCard(entry) />
5783 <@renderCard cardData/>
5784 </#if>
5785 </#list>
5786 </div>
5787 </div>
5788 </div>
5789</#if>
5790
5791
5792<style>
5793 .portlet {
5794 margin: 0;
5795 }
5796
5797 .${rootCss} {
5798 padding: var(--space-giant, 80px) 0;
5799 background: var(--background-surface-level-01, #FFF);
5800 width: 100%;
5801 position: relative;
5802 font-family: var(--font-family-base, "Petrobras Sans");
5803 display: flex;
5804 flex-direction: column;
5805 gap: var(--space-lg);
5806 }
5807
5808 body.high-contrast-active .${rootCss} {
5809 background: var(--background-surface-level-01, #010101);
5810 }
5811
5812 .${rootCss} .list-of-news-title {
5813 position: relative;
5814 z-index: 1;
5815 }
5816
5817 .${rootCss} body.high-contrast-active .fragment_614685 .petro-title .yellow-bar {
5818 background-color: #FFEEB3 !important;
5819 }
5820
5821 .${rootCss} .petro-title > div:has(> .yellow-bar, > .card-news-list-arrows-breakpoint) {
5822 display: flex;
5823 }
5824
5825 .${rootCss} .card-news-list {
5826 display: flex;
5827 gap: var(--space-lg);
5828 overflow: auto;
5829 position: relative;
5830 z-index: 1;
5831 scroll-snap-type: x mandatory;
5832 scrollbar-width: none;
5833 }
5834
5835 .${rootCss} .card-news-list::-webkit-scrollbar {
5836 display: none;
5837 }
5838
5839 @media screen and (min-width: 1441px) {
5840 .${rootCss} .card-news-list-breakpoint {
5841 width: 100%;
5842 }
5843
5844 .${rootCss} .list-of-news-title {
5845 width: 100%;
5846 }
5847 }
5848
5849 @media screen and (max-width: 1024px) {
5850 .${rootCss} .fragment_614685 {
5851 padding: var(--space-xxl, 56px) 0;
5852 }
5853 }
5854
5855 @media screen and (max-width: 768px) {
5856 .${rootCss} .petro-title > div:has(> .yellow-bar, > .card-news-list-arrows-breakpoint) {
5857 flex-direction: column;
5858 }
5859 }
5860
5861
5862</style>
5863
5864<#list ourEnergyStyles as ourEnergyStyle>
5865 <style>
5866 .${rootCss} [data-category="${ourEnergyStyle.titleLocale}"] {
5867 background: linear-gradient(0deg, var(--background-surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 0%, var(--background-surface-opacity-light-level-07, rgba(255, 255, 255, 0.96)) 100%), #${ourEnergyStyle.backgroundColor} !important;
5868 box-shadow: 0px 2px 6px 0px #${ourEnergyStyle.shadowColor} !important;
5869 color: #${ourEnergyStyle.textColor} !important;
5870 }
5871
5872 body.high-contrast-active .${rootCss} [data-category="${ourEnergyStyle.titleLocale}"] {
5873 background: linear-gradient(0deg, var(--background-surface-opacity-light-level-07, rgba(55, 55, 55, 1)) 0%, var(--background-surface-opacity-light-level-07, rgba(55, 55, 55, 1)) 100%), #${ourEnergyStyle.backgroundColor} !important;
5874 color: #${ourEnergyStyle.textColorHighContrast} !important;
5875 }
5876
5877 </style>
5878</#list>
5879
5880<script>
5881
5882 function disableEnableArrow(arrow, scrollBar, maxDistance, direction)
5883 {
5884 if(direction === "left") {
5885 if (scrollBar.scrollLeft > 0) {
5886 arrow.classList.contains("arrow-disable") && arrow.classList.remove("arrow-disable");
5887 }
5888 else {
5889 !arrow.classList.contains("arrow-disable") && arrow.classList.add("arrow-disable");
5890 }
5891 }
5892 else if(direction === "right") {
5893 if (Math.ceil(scrollBar.scrollLeft + scrollBar.clientWidth) < maxDistance) {
5894 arrow.classList.contains("arrow-disable") && arrow.classList.remove("arrow-disable");
5895 }
5896 else {
5897 !arrow.classList.contains("arrow-disable") && arrow.classList.add("arrow-disable");
5898 }
5899 }
5900 }
5901
5902 function scrollCarousel()
5903 {
5904 const root = document.querySelector(".${rootCss}");
5905 if(root) {
5906 const scrollBar = root.querySelector(".${rootCss} .card-news-list");
5907 const gap = 32;// var(--space-lg);
5908 const stepLength = scrollBar.querySelector(".card-news-container").offsetWidth + gap;
5909 const arrowLeftBtn = root.querySelector(".card-news-arrow-left")
5910 const arrowRightBtn = root.querySelector(".card-news-arrow-right")
5911
5912 let maxDistance = scrollBar.scrollWidth;
5913
5914 arrowLeftBtn.addEventListener('click', () => {
5915 if (scrollBar.scrollLeft > 0) {
5916 scrollBar.scroll({
5917 left: scrollBar.scrollLeft - stepLength,
5918 behavior: "smooth",
5919 });
5920 }
5921 });
5922
5923 arrowRightBtn.addEventListener('click', () => {
5924 if (scrollBar.scrollLeft < maxDistance) {
5925 scrollBar.scroll({
5926 left: scrollBar.scrollLeft + stepLength,
5927 behavior: "smooth",
5928 });
5929 }
5930 });
5931
5932 scrollBar.addEventListener("scroll", ()=>{
5933 disableEnableArrow(arrowLeftBtn, scrollBar, maxDistance, "left");
5934 disableEnableArrow(arrowRightBtn, scrollBar, maxDistance, "right");
5935 });
5936
5937 disableEnableArrow(arrowLeftBtn, scrollBar, maxDistance, "left");
5938 disableEnableArrow(arrowRightBtn, scrollBar, maxDistance, "right");
5939
5940 }
5941 }
5942
5943 document.addEventListener('DOMContentLoaded', scrollCarousel);
5944
5945</script>
5946
5947<style>
5948
5949
5950.ptb-news__read-news .news-content .embed-responsive-youtube::before {
5951 padding-top: 0;
5952}
5953
5954.ptb-news__read-news .news-content .embed-responsive-liferay::before {
5955 padding-top: calc(9/16 *100% - 64px);
5956}
5957
5958.ptb-news__read-news .news-content .thumnail-play-button {
5959}
5960
5961.ptb-news__read-news .news-content .thumnail-play-button {
5962 position: relative;
5963 z-index: 100;
5964 height: 64px;
5965 width: 64px;
5966 background-repeat: no-repeat;
5967 top: calc(50%);
5968 left: calc(50% - 32px);
5969}
5970
5971
5972.ptb-news__read-news .news-content .thumnail-play-button-youtube {
5973 position: absolute;
5974 z-index: 100;
5975 height: 64px;
5976 width: 64px;
5977 background-repeat: no-repeat;
5978 top: calc(50% - 64px);
5979 left: calc(50% - 32px);
5980}
5981
5982.ptb-news__read-news .news-content .thumnail-play-button-liferay {
5983 position: relative;
5984 z-index: 100;
5985 height: 64px;
5986 width: 64px;
5987 top: calc(-50% + 32px);
5988 left: calc(50% - 32px);
5989 background-repeat: no-repeat;
5990}
5991
5992
5993 .ptb-news__read-news .news-content .embed-responsive-youtube img {
5994 width: 100%;
5995 height: 100%;
5996 }
5997
5998</style>
5999
6000 <script>
6001 <#assign createYoutubeThumbnails = "createYoutubeThumbnails_"+ randomNumber(5952) />
6002
6003 function ${createYoutubeThumbnails}(){
6004
6005 const newsContent = document.querySelector(".news-content");
6006
6007 const getYoutubeId = (youtubeUrl) => {
6008
6009 const url = new URL(youtubeUrl);
6010 const splittedPathName = url.pathname.split("/");
6011
6012 if (splittedPathName.length <= 0){
6013 return "";
6014 }
6015
6016 return splittedPathName[splittedPathName.length-1];
6017 };
6018
6019 window.addEventListener("resize", (event) => {
6020 const iframeList = newsContent.querySelectorAll('iframe');
6021 iframeList.forEach((iframe) => {
6022 const src = iframe.src;
6023 if (!src){
6024 return;
6025 }
6026
6027 const isYoutube = src.toLowerCase().includes("youtube");
6028 if (!isYoutube){
6029 return;
6030 }
6031
6032 const iframeParent = iframe.parentNode;
6033
6034 const thumbnail = iframeParent.querySelector("img");
6035 if (thumbnail){
6036 // thumbnail.style="width:" + iframe.width + "px; height: " + iframe.height + "px";
6037 }
6038 });
6039
6040 });
6041
6042 const iframeList = newsContent.querySelectorAll('iframe');
6043 iframeList.forEach((iframe) => {
6044 const src = iframe.src;
6045 if (!src){
6046 return;
6047 }
6048
6049 const isYoutube = src.toLowerCase().includes("youtube");
6050 if (!isYoutube){
6051 return;
6052 }
6053
6054 const iframeParent = iframe.parentNode;
6055
6056 const thumbnail = document.createElement("img");
6057 thumbnail.src = 'https://img.youtube.com/vi/' + getYoutubeId(src) +'/hqdefault.jpg';
6058 thumbnail.alt = "Youtube";
6059 thumbnail.loading = "lazy";
6060 //thumbnail.style="width:" + iframe.width + "px; height: " + iframe.height + "px";
6061
6062 const playButton = document.createElement("div");
6063 playButton.style = 'background-image: url("data:image/svg+xml,%3Csvg width=\'64\' height=\'64\' viewBox=\'0 0 64 64\' fill=\'none\' xmlns=\'http://www.w3.org/2000/svg\'%3E%3Cg clip-path=\'url(%23clip0_4118_27800)\'%3E%3Crect width=\'64\' height=\'64\' rx=\'32\' fill=\'white\'/%3E%3Cpath d=\'M39.22 32.52C39.591 32.2726 39.591 31.7274 39.22 31.48L28.9717 24.6478C28.5563 24.3709 28 24.6686 28 25.1678V38.8322C28 39.3314 28.5563 39.6291 28.9717 39.3522L39.22 32.52Z\' fill=\'%23008542\' stroke=\'%23008542\' stroke-width=\'2\' stroke-linecap=\'round\' stroke-linejoin=\'round\'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id=\'clip0_4118_27800\'%3E%3Crect width=\'64\' height=\'64\' rx=\'32\' fill=\'white\'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E%0A")';
6064 playButton.classList.add("thumnail-play-button-youtube");
6065 const children = iframeParent.children;
6066
6067 if (children.length > 0) {
6068 iframeParent.insertBefore(thumbnail, children.firstChild);
6069 iframeParent.insertBefore(playButton, thumbnail);
6070 iframe.classList.add("hide");
6071 iframeParent.classList.add("embed-responsive-youtube");
6072 }
6073
6074 playButton.addEventListener("click", () => {
6075 thumbnail.click();
6076 });
6077
6078 thumbnail.addEventListener("click", () => {
6079 thumbnail.classList.add("hide");
6080 playButton.classList.add("hide");
6081 iframe.classList.remove("hide");
6082 iframeParent.classList.remove("embed-responsive-youtube");
6083 const url = new URL(src);
6084 const searchParams = url.searchParams;
6085 searchParams.set("rel", "0");
6086 //searchParams.set("modestbranding", "0");
6087 //searchParams.set("mute", "0");
6088 //searchParams.set("color", "white");
6089 searchParams.set("controls", "1");
6090 //searchParams.set("playsinline", "1");
6091 //searchParams.set("enablejsapi", "1");
6092 searchParams.set("autoplay", "1");
6093 //searchParams.set("logo", "0");
6094 iframeParent.setAttribute("data-embed-id", url.toString());
6095 iframe.setAttribute("src", url.toString());
6096 });
6097 });
6098
6099 }
6100
6101 ${createYoutubeThumbnails}();
6102
6103 <#assign createLRThumbnails = "createLRThumbnails"+ randomNumber(5952) />
6104
6105 function ${createLRThumbnails}(){
6106
6107 const newsContent = document.querySelector(".news-content");
6108 const iframeList = newsContent.querySelectorAll("iframe[data-video-liferay]");
6109
6110 iframeList.forEach(iframe => {
6111
6112 const playButton = document.createElement("div");
6113 playButton.style = 'background-image: url("data:image/svg+xml,%3Csvg width=\'64\' height=\'64\' viewBox=\'0 0 64 64\' fill=\'none\' xmlns=\'http://www.w3.org/2000/svg\'%3E%3Cg clip-path=\'url(%23clip0_4118_27800)\'%3E%3Crect width=\'64\' height=\'64\' rx=\'32\' fill=\'white\'/%3E%3Cpath d=\'M39.22 32.52C39.591 32.2726 39.591 31.7274 39.22 31.48L28.9717 24.6478C28.5563 24.3709 28 24.6686 28 25.1678V38.8322C28 39.3314 28.5563 39.6291 28.9717 39.3522L39.22 32.52Z\' fill=\'%23008542\' stroke=\'%23008542\' stroke-width=\'2\' stroke-linecap=\'round\' stroke-linejoin=\'round\'/%3E%3C/g%3E%3Cdefs%3E%3CclipPath id=\'clip0_4118_27800\'%3E%3Crect width=\'64\' height=\'64\' rx=\'32\' fill=\'white\'/%3E%3C/clipPath%3E%3C/defs%3E%3C/svg%3E%0A")';
6114 playButton.classList.add("thumnail-play-button-liferay");
6115 const children = iframe.parentNode.children;
6116 if (children.length > 0) {
6117 iframe.parentNode.insertBefore(playButton, children.firstChild);
6118 }
6119
6120 iframe.addEventListener("load", () => {
6121 if (iframe.contentDocument){
6122 const video = iframe.contentDocument.body.querySelector("video");
6123 video.removeAttribute("controls");
6124 }
6125 });
6126
6127 iframe.parentNode.classList.add("embed-responsive-liferay");
6128
6129
6130 playButton.addEventListener("click", () => {
6131 playButton.classList.add("hide");
6132 playButton.classList.remove("thumnail-play-button-liferay");
6133 iframe.parentNode.classList.remove("embed-responsive-liferay");
6134 if (iframe.contentDocument){
6135 const video = iframe.contentDocument.body.querySelector("video");
6136 video.setAttribute("controls", "");
6137 video.play();
6138 }
6139 });
6140 });
6141 }
6142
6143 ${createLRThumbnails}();
6144
6145 document.querySelectorAll(".news-content img").forEach(img => img.loading = "lazy");
6146
6147 </script>
Escolha um Canal:
Navegue nas Seções:
Acessibilidade
Idioma:
Selecione um idioma: