Um inesperado erro ocorreu.
X
O uso deste material é autorizado apenas para fins editoriais.
Ok Cancel
X
Negócio
Petrobras projeta investimentos de mais de US$ 70 bi em E&P com demandas para a indústria naval
Mais recentes
Um erro ocorreu enquanto processava o modelo.
Java method "com.liferay.journal.model.impl.JournalArticleImpl.getDocument()" threw an exception when invoked on com.liferay.journal.model.impl.JournalArticleImpl object "{\"mvccVersion\": 1, \"ctCollectionId\": 0, \"uuid\": \"190dec18-2c86-18e8-8348-9fb54911d5c7\", \"id\": 17016457, \"resourcePrimKey\": 16999757, \"groupId\": 10623376, \"companyId\": 20099, \"userId\": 3899125, \"userName\": \"Danielle Miranda\", \"createDate\": \"Mon Apr 22 22:38:06 GMT 2024\", \"modifiedDate\": \"Wed Apr 24 13:49:19 GMT 2024\", \"externalReferenceCode\": \"c2ae4000-a255-e9dd-bead-af8e42657a72\", \"folderId\": 11449535, \"classNameId\": 0, \"classPK\": 0, \"treePath\": \"/10628776/11449535/\", \"articleId\": \"16999755\", \"version\": 1.1, \"urlTitle\": \"sustentabilidade/prates-diz-que-brasil-tem-responsabilidade-e-dever-de-liderar-a-transicao-energetica\", \"DDMStructureId\": 10628772, \"DDMTemplateKey\": \"\", \"defaultLanguageId\": \"pt_BR\", \"layoutUuid\": \"\", \"displayDate\": \"Mon Apr 22 22:33:00 GMT 2024\", \"expirationDate\": null, \"reviewDate\": null, \"indexable\": true, \"smallImage\": false, \"smallImageId\": 0, \"smallImageSource\": 1, \"smallImageURL\": \"\", \"lastPublishDate\": null, \"status\": 0, \"statusByUserId\": 11888211, \"statusByUserName\": \"Leonardo Bruno Pimenta Melo\", \"statusDate\": \"Wed Apr 24 13:49:19 GMT 2024\"}"; see cause exception in the Java stack trace. ---- FTL stack trace ("~" means nesting-related): - Failed at: #assign xmlArticle = journalArticle.g... [in template "20099#20135#10832147" in function "getCardData" at line 52, column 5] ----
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<#assign journalArticleService = serviceLocator.findService("com.liferay.journal.service.JournalArticleLocalService") />
8<#assign fileEntryService = staticUtil["com.liferay.document.library.kernel.service.DLFileEntryLocalServiceUtil"] />
9<#assign assetCategoryLocalService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetCategoryLocalService") />
10<#assign assetVocabularyService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetVocabularyService") />
11<#assign assetCategoryLocalService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetCategoryLocalService") />
12<#assign vocabularies = assetVocabularyService.getGroupVocabularies(groupId) />
13<#assign editoriaVocabulary = findVocabulary("Editorial", vocabularies) />
14
15
16
17<#function getFirstCategoryFromVocabulary entry vocabulary>
18 <#assign categories = assetCategoryLocalService.getCategories("com.liferay.journal.model.JournalArticle", entry.getClassPK()) />
19 <#list categories as category>
20 <#assign vocabulary = assetVocabularyService.getVocabulary(category.getVocabularyId()) />
21
22 <#if vocabulary.getVocabularyId() == category.getVocabularyId()>
23 <#return category>
24 </#if>
25 </#list>
26 <#return "">
27</#function>
28
29<#assign rootCss = "card-news_" + randomNumber(4586) />
30<#assign cardMap = {} />
31
32<#-- Função para obter os dados de um card no Web Content (Journal Article) -->
33<#function getCardData entry journalArticleLocalService fileEntryService cardMap>
34
35 <#assign editoria = getFirstCategoryFromVocabulary(entry, editoriaVocabulary) />
36 <#assign editoriaId = -1 />
37 <#if editoria?has_content>
38 <#assign editoriaId = editoria.getCategoryId() />
39 </#if>
40 <#if editoriaId == -1>
41 <#return {} />
42 </#if>
43 <#if cardMap[ editoriaId?string]??>
44 <#if cardMap[editoriaId?string]?size gt 7 >
45 <#return {} />
46 </#if>
47 </#if>
48
49 <#assign journalArticle = journalArticleLocalService.getLatestArticle(entry.getClassPK()) />
50 <#assign ddmStructure = journalArticle.getDDMStructure() />
51 <#assign fieldList = getFieldListByStructure(ddmStructure) />
52 <#assign xmlArticle = journalArticle.getDocument().getRootElement() />
53 <#assign ddmStructure = journalArticle.getDDMStructure() />
54
55 <#assign imagesGroup = getNodes(getIdFromFieldName(fieldList, "Imagem de destaque da notícia"), xmlArticle) />
56 <#assign image = "" />
57 <#list imagesGroup as imageGroup >
58 <#assign image = getMediaInfo(fieldList, imageGroup, "Imagem de destaque", fileEntryService) /> />
59 </#list>
60
61 <#assign title = getFieldValue(fieldList, xmlArticle, "Título de destaque da notícia") />
62
63 <#assign lastPublishDate = journalArticle.getDisplayDate()>
64 <#assign createDate = journalArticle.getCreateDate()>
65
66 <#assign editoria = getFirstCategoryFromVocabulary(entry, editoriaVocabulary) />
67 <#assign editoriaId = -1 />
68 <#if editoria?has_content>
69 <#assign editoriaId = editoria.getCategoryId() />
70 </#if>
71
72 <#assign review = getFieldValue(fieldList, xmlArticle, "Subtítulo") />
73
74 <#assign urlNews = "/">
75 <#if themeDisplay.getPortalURL()?contains("webserver")>
76 <#assign urlNews = themeDisplay.getPortalURL() + themeDisplay.getPathFriendlyURLPublic() + layout.getGroup().friendlyURL + "/w/" + journalArticle.getUrlTitle()>
77 <#else>
78 <#assign urlNews = "/w/" + journalArticle.getUrlTitle()>
79 </#if>
80
81 <#assign cardInfo = {"image": image,
82 "title": title,
83 "lastPublishDate": lastPublishDate,
84 "createDate" : createDate,
85 "editoriaId": editoriaId,
86 "urlNews": urlNews,
87 "review": review} />
88
89 <#if cardMap[editoriaId?string]??>
90 <#assign cardMap = cardMap + {editoriaId : cardMap[editoriaId?string] + [cardInfo]} />
91 <#else>
92 <#assign cardMap = cardMap + {editoriaId : [cardInfo]} />
93 </#if>
94
95 <#return cardInfo />
96
97</#function>
98
99
100<#macro renderCard cardData>
101 <#if !cardData["image"]??>
102 <#return />
103 </#if>
104
105 <div class="card ${rootCss}" category-id="${cardData.editoriaId}">
106 <#if cardData.image.url?has_content>
107 <img class="image" src="/o/adaptive-media/image/${cardData.image.fileEntryId}/Thumbnail-300x300/image" alt="${cardData.image.alt}"/>
108 </#if>
109 <div class="news-content">
110 <div class="head">
111 <p class="date">${formatDate(cardData.lastPublishDate)}</p>
112 <h2 class="title h4">${cardData.title}</h2>
113 <div class="bar"></div>
114 </div>
115 <div class="bottom-wrapper">
116 <div class="review-container">
117 ${cardData.review}
118 </div>
119 <div class="link-container">
120 <a class="link" href="${cardData.urlNews}" class="card-news-container">
121 <#if locale?lower_case == "pt_br"> Continuar lendo <#else> Keep reading </#if>
122 <span style="display: none">${randomNumber(10000)}</span> <#-- Devido ao ASESWEB -->
123 </a>
124 </div>
125 </div>
126 </div>
127 </div>
128
129</#macro>
130
131<#-- Renderizar Lista de cards -->
132<#if entries?has_content>
133 <#list entries as entry>
134 <#assign cardData = getCardData(entry journalArticleService fileEntryService cardMap) />
135 <@renderCard cardData/>
136 </#list>
137
138 <style>
139
140
141 .${rootCss} {
142 display: flex;
143 flex-direction: column;
144 width: 306px;
145 border-radius: 16px;
146 border: 1px solid var(--color-neutral-400, #EEE);
147 background: var(--color-neutral-100, #FFF);
148 margin: 0;
149 }
150
151 .${rootCss}:hover {
152 box-shadow: var(--box-shadow-neutral);
153 transition: box-shadow 300ms ease-in-out;
154 }
155
156 .${rootCss} .news-content {
157 padding: var(--space-md, 24px);
158 display: flex;
159 flex-direction: column;
160 height: 100%;
161 background: var(--color-background-card);
162 border-radius: 0 0 var(--border-radius-lg) var(--border-radius-lg);
163 }
164
165
166 .${rootCss} img {
167 background: lightgray 50% / cover no-repeat;
168 height: 170px;
169 width: 100%;
170 border-radius: 16px 16px 0 0;
171 /*transform: translateX(-1px);*/
172 object-fit: cover;
173 }
174
175 .${rootCss} .head {
176 display: flex;
177 flex-direction: column;
178 gap: var(--space-xxs, 8px);
179 }
180
181 .${rootCss} .head .date {
182 color: var(--color-neutral-800, #373737);
183 font-family: var(--font-family-base, "Petrobras Sans");
184 font-size: 14px;
185 font-style: normal;
186 font-weight: 400;
187 line-height: 160%; /* 19.2px */
188 }
189
190 .${rootCss} .head .title {
191 color: var(--color-neutral-800);
192 }
193
194 .${rootCss} .head .bar {
195 background-color: var(--color-secondary-solid-to-bright-200, #FDC82F);
196 height: 4px;
197 width: 20px;
198 margin: 12px 0 16px 0;
199 }
200
201 .${rootCss} .bottom-wrapper {
202 height: 100%;
203 display: flex;
204 flex-direction: column;
205 justify-content: space-between;
206 }
207
208 .${rootCss} .bottom-wrapper .review-container {
209 color: var(--color-neutral-800, #373737);
210 font-family: var(--font-family-base, "Petrobras Sans");
211 font-size: 16px;
212 font-style: normal;
213 font-weight: 400;
214 line-height: 160%; /* 22.4px */
215 }
216
217 .${rootCss} .bottom-wrapper .link-container {
218 flex: 0 1 auto;
219 }
220
221 .${rootCss} .bottom-wrapper .link-container .link {
222 color: var(--color-primary-solid-to-bright-200, var(--color-primary-medium));
223 font-family: var(--font-family-base, "Petrobras Sans");
224 font-size: 16px;
225 font-style: normal;
226 font-weight: 700;
227 line-height: 144%; /* 23.04px */
228 text-decoration-line: underline;
229 }
230
231 @media screen and (max-width: 1024px) {
232 .${rootCss} {
233 flex-direction: column;
234 /*gap: 16px;*/
235 min-width: 296px;
236 }
237
238 .${rootCss} img {
239 height: 140px;
240 }
241
242 .${rootCss} .head .date {
243 font-size: 12px;
244 }
245
246 .${rootCss} .head .title {}
247
248 .${rootCss} .head .bar {
249 width: 18px;
250 margin: 8px 0 16px 0;
251 }
252
253 .${rootCss} .review-container {
254 font-size: 14px;
255 }
256 }
257 </style>
258</#if>
Mais lidos
29/01/2024
Inscrições para concurso de nível técnico terminam na próxima quarta
Seleção terá reserva de 20% das vagas para PCD e 20% para negros. Provas serão realizadas em 40 cidades, incluindo capitais de todos os estados
30/01/2024
Petrobras apoia projetos de reciclagem no Rio e na Baixada Fluminense com capacidade de reaproveitar 600 toneladas de materiais por ano
Unidades da estatal destinam resíduos recicláveis para cooperativas de catadores e fomentam a capacitação dos trabalhadores
31/01/2024
Petrobras destaca transição energética e ativos rentáveis em imersão com investidores em NY
26/01/2024
Petrobras bate recordes no primeiro ano da atual gestão
26/01/2024
Petrobras conclui primeira perfuração de poço exploratório na Margem Equatorial
30/01/2024
Petrobras amplia testes para produção de diesel com conteúdo renovável
Além da Repar, que já comercializa o produto, mais três refinarias realizaram testes e estão aptas para a produção do Diesel R5
26/01/2024
Petrobras informa sobre Reservas Provadas em 2023
30/01/2024
Repar bate recordes históricos de produção e vendas
Produção de diesel da refinaria da Petrobras no Paraná foi de 5,7 bilhões de litros, batendo o recorde de 2014. A produção de gasolina atingiu 3,4 bilhões de litros, 3% a mais que recorde de 2012, e de asfalto foi de 453 mil toneladas, 0,5% superior ao recorde de 2010.
Navegue por editoria
Inovação
Institucional
Negócio
Sustentabilidade
Um erro ocorreu enquanto processava o modelo.
Java method "com.liferay.journal.model.impl.JournalArticleImpl.getDocument()" threw an exception when invoked on com.liferay.journal.model.impl.JournalArticleImpl object "{\"mvccVersion\": 1, \"ctCollectionId\": 0, \"uuid\": \"190dec18-2c86-18e8-8348-9fb54911d5c7\", \"id\": 17016457, \"resourcePrimKey\": 16999757, \"groupId\": 10623376, \"companyId\": 20099, \"userId\": 3899125, \"userName\": \"Danielle Miranda\", \"createDate\": \"Mon Apr 22 22:38:06 GMT 2024\", \"modifiedDate\": \"Wed Apr 24 13:49:19 GMT 2024\", \"externalReferenceCode\": \"c2ae4000-a255-e9dd-bead-af8e42657a72\", \"folderId\": 11449535, \"classNameId\": 0, \"classPK\": 0, \"treePath\": \"/10628776/11449535/\", \"articleId\": \"16999755\", \"version\": 1.1, \"urlTitle\": \"sustentabilidade/prates-diz-que-brasil-tem-responsabilidade-e-dever-de-liderar-a-transicao-energetica\", \"DDMStructureId\": 10628772, \"DDMTemplateKey\": \"\", \"defaultLanguageId\": \"pt_BR\", \"layoutUuid\": \"\", \"displayDate\": \"Mon Apr 22 22:33:00 GMT 2024\", \"expirationDate\": null, \"reviewDate\": null, \"indexable\": true, \"smallImage\": false, \"smallImageId\": 0, \"smallImageSource\": 1, \"smallImageURL\": \"\", \"lastPublishDate\": null, \"status\": 0, \"statusByUserId\": 11888211, \"statusByUserName\": \"Leonardo Bruno Pimenta Melo\", \"statusDate\": \"Wed Apr 24 13:49:19 GMT 2024\"}"; see cause exception in the Java stack trace. ---- FTL stack trace ("~" means nesting-related): - Failed at: #assign xmlArticle = journalArticle.g... [in template "20099#20135#11536932" in function "getCardData" at line 63, column 5] ----
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<#assign journalArticleService = serviceLocator.findService("com.liferay.journal.service.JournalArticleLocalService") />
8<#assign fileEntryService = staticUtil["com.liferay.document.library.kernel.service.DLFileEntryLocalServiceUtil"] />
9<#assign assetCategoryLocalService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetCategoryLocalService") />
10<#assign assetVocabularyService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetVocabularyService") />
11<#assign assetCategoryLocalService = serviceLocator.findService("com.liferay.asset.kernel.service.AssetCategoryLocalService") />
12<#assign vocabularies = assetVocabularyService.getGroupVocabularies(groupId) />
13<#assign editoriaVocabulary = findVocabulary("Editorial", vocabularies) />
14<#assign mediaVocabulary = findVocabulary("Multimidia", vocabularies) />
15
16<#-- Categoria para filtrar registros para idioma em inglês -->
17<#assign PAGE_ENGLISH_CATEGORY = 12780360 >
18
19<#assign assetEntryQuery = objectUtil('com.liferay.asset.kernel.service.persistence.AssetEntryQuery')>
20<#assign portalUtil = staticUtil["com.liferay.portal.kernel.util.PortalUtil"]>
21<#assign assetEntryLocalServiceUtil = objectUtil("com.liferay.asset.kernel.service.AssetEntryLocalServiceUtil").getService()>
22
23<#function getFirstCategoryFromVocabulary entry vocabulary>
24 <#assign categories = assetCategoryLocalService.getCategories("com.liferay.journal.model.JournalArticle", entry.getClassPK()) />
25 <#list categories as category>
26 <#assign vocabulary = assetVocabularyService.getVocabulary(category.getVocabularyId()) />
27
28 <#if vocabulary.getVocabularyId() == category.getVocabularyId()>
29 <#return category>
30 </#if>
31 </#list>
32 <#return "">
33</#function>
34
35<#assign rootCss = "card-news_" + randomNumber(4586) />
36<#assign cardMap = {} />
37
38<#-- Função para obter os dados de um card no Web Content (Journal Article) -->
39<#function getCardData entry journalArticleLocalService fileEntryService cardMap>
40
41 <#assign editoria = getFirstCategoryFromVocabulary(entry, editoriaVocabulary) />
42 <#assign editoriaId = -1 />
43 <#if editoria?has_content>
44 <#assign editoriaId = editoria.getCategoryId() />
45 </#if>
46 <#if editoriaId == -1>
47 <#return {} />
48 </#if>
49 <#if cardMap[ editoriaId?string]??>
50 <#if cardMap[editoriaId?string]?size gt 7 >
51 <#return {} />
52 </#if>
53 </#if>
54
55 <#assign journalArticle = journalArticleLocalService.getLatestArticle(entry.getClassPK()) />
56 <#assign structName = getStructName(journalArticle) />
57 <#if structName != "Agência de Notícias - Notícia">
58 <#return {}/>
59 </#if>
60
61 <#assign ddmStructure = journalArticle.getDDMStructure() />
62 <#assign fieldList = getFieldListByStructure(ddmStructure) />
63 <#assign xmlArticle = journalArticle.getDocument().getRootElement() />
64
65
66 <#assign imagesGroup = getNodes(getIdFromFieldName(fieldList, "Imagem de destaque da notícia"), xmlArticle) />
67 <#assign image = "" />
68 <#list imagesGroup as imageGroup >
69 <#assign image = getMediaInfo(fieldList, imageGroup, "Imagem de destaque", fileEntryService) /> />
70 </#list>
71
72 <#assign title = getFieldValue(fieldList, xmlArticle, "Título de destaque da notícia") />
73
74 <#assign lastPublishDate = journalArticle.getDisplayDate()>
75 <#assign createDate = journalArticle.getCreateDate()>
76
77 <#assign editoria = getFirstCategoryFromVocabulary(entry, editoriaVocabulary) />
78 <#assign editoriaId = -1 />
79 <#if editoria?has_content>
80 <#assign editoriaId = editoria.getCategoryId() />
81 </#if>
82
83 <#assign review = getFieldValue(fieldList, xmlArticle, "Subtítulo") />
84
85 <#assign urlNews = "/">
86 <#if themeDisplay.getPortalURL()?contains("webserver")>
87 <#assign urlNews = themeDisplay.getPortalURL() + themeDisplay.getPathFriendlyURLPublic() + layout.getGroup().friendlyURL + "/w/" + journalArticle.getUrlTitle()>
88 <#else>
89 <#assign urlNews = "/w/" + journalArticle.getUrlTitle()>
90 </#if>
91
92 <#assign cardInfo = {"image": image,
93 "title": title,
94 "lastPublishDate": lastPublishDate,
95 "createDate" : createDate,
96 "editoriaId": editoriaId,
97 "urlNews": urlNews,
98 "review": review} />
99
100 <#if cardMap[editoriaId?string]??>
101 <#assign cardMap = cardMap + {editoriaId : cardMap[editoriaId?string] + [cardInfo]} />
102 <#else>
103 <#assign cardMap = cardMap + {editoriaId : [cardInfo]} />
104 </#if>
105
106 <#return cardInfo />
107
108</#function>
109
110
111<#macro renderCard cardData>
112 <#if !cardData["image"]??>
113 <#return />
114 </#if>
115
116 <div class="card ${rootCss}" category-id="${cardData.editoriaId}">
117 <#if cardData.image.url?has_content>
118 <img class="image" src="/o/adaptive-media/image/${cardData.image.fileEntryId}/Thumbnail-300x300/image" alt="${cardData.image.alt}"/>
119 </#if>
120 <div class="news-content">
121 <div class="head">
122 <p class="date">${formatDate(cardData.lastPublishDate)}</p>
123 <h2 class="title h4">${cardData.title}</h2>
124 <div class="bar"></div>
125 </div>
126 <div class="bottom-wrapper">
127 <div class="review-container">
128 ${cardData.review}
129 </div>
130 <div class="link-container">
131 <a class="link" href="${cardData.urlNews}" class="card-news-container">
132 <#if locale?lower_case == "pt_br"> Continuar lendo <#else> Keep reading </#if>
133 <span style="display: none">${randomNumber(10000)}</span> <#-- Devido ao ASESWEB -->
134 </a>
135 </div>
136 </div>
137 </div>
138 </div>
139
140</#macro>
141
142
143
144<#function getAssetEntries portalUtil assetEntryLocalServiceUtil vocabulary>
145 <#attempt >
146 <#assign groupId = themeDisplay.getScopeGroupId()>
147 <#assign companyId = themeDisplay.getCompanyId()>
148 <#assign realUserId = themeDisplay.getDefaultUserId() />
149 <#assign className = "com.liferay.journal.model.JournalArticle">
150 <#assign classNameId = portalUtil.getClassNameId(className)>
151
152 <#assign assetEntryQuery = objectUtil('com.liferay.asset.kernel.service.persistence.AssetEntryQuery') />
153 ${assetEntryQuery.setClassNameIds([classNameId]) }
154 ${assetEntryQuery.setEnd(8)}
155 <#assign notAllCategoryIds = [] />
156 <#list mediaVocabulary.getCategories() as category>
157 <#assign notAllCategoryIds += [category.getCategoryId()] />
158 </#list>
159 ${assetEntryQuery.setNotAllCategoryIds(notAllCategoryIds)}
160
161 <#assign allAssets = []/>
162 <#list vocabulary.getCategories() as category>
163 <#if locale?lower_case == "pt_br">
164 ${assetEntryQuery.setAllCategoryIds([category.getCategoryId()])}
165 <#else>
166 ${assetEntryQuery.setAllCategoryIds([category.getCategoryId(), PAGE_ENGLISH_CATEGORY])}
167 </#if>
168 <#assign ents = assetEntryLocalServiceUtil.getEntries(assetEntryQuery) />
169 <#assign allAssets = allAssets + ents />
170 </#list>
171
172 <#return allAssets />
173 <#recover >
174 <#return [] />
175 </#attempt>
176</#function>
177
178
179
180<#assign allAssets = getAssetEntries(portalUtil, assetEntryLocalServiceUtil, editoriaVocabulary) />
181
182<#-- Renderizar Lista de cards -->
183<#if allAssets?has_content>
184
185 <#list allAssets?sort_by("publishDate")?reverse as assetEntry>
186 <#assign cardData = getCardData(assetEntry journalArticleService fileEntryService cardMap) />
187 <@renderCard cardData/>
188 </#list>
189
190 <style>
191 .${rootCss} {
192 display: flex;
193 flex-direction: column;
194 width: 306px;
195 border-radius: 16px;
196 border: 1px solid var(--color-neutral-400, #EEE);
197 background: var(--color-neutral-100, #FFF);
198 margin: 0;
199 }
200
201 .${rootCss}:hover {
202 box-shadow: var(--box-shadow-neutral);
203 transition: box-shadow 300ms ease-in-out;
204 }
205
206 .${rootCss} .news-content {
207 border-radius: 0 0 var(--border-radius-lg) var(--border-radius-lg);
208 background: var(--color-background-card);
209 padding: var(--space-md, 24px);
210 display: flex;
211 flex-direction: column;
212 height: 100%;
213 }
214
215 .${rootCss} img {
216 background: lightgray 50% / cover no-repeat;
217 height: 170px;
218 width: 100%;
219 border-radius: 16px 16px 0 0;
220 /*transform: translateX(-1px);*/
221 object-fit: cover;
222 }
223
224 .${rootCss} .head {
225 display: flex;
226 flex-direction: column;
227 gap: var(--space-xxs, 8px);
228 }
229
230 .${rootCss} .head .date {
231 color: var(--color-neutral-800, #373737);
232 font-family: var(--font-family-base, "Petrobras Sans");
233 font-size: 14px;
234 font-style: normal;
235 font-weight: 400;
236 line-height: 160%; /* 19.2px */
237 }
238
239 .${rootCss} .head .title {
240 color: var(--color-neutral-800);
241 }
242
243 .${rootCss} .head .bar {
244 background-color: var(--color-secondary-medium, #FDC82F);
245 height: 4px;
246 width: 20px;
247 margin: 12px 0 16px 0;
248 }
249
250 .${rootCss} .bottom-wrapper {
251 height: 100%;
252 display: flex;
253 flex-direction: column;
254 justify-content: space-between;
255 }
256
257 .${rootCss} .bottom-wrapper .review-container {
258 color: var(--color-neutral-800, #373737);
259 font-family: var(--font-family-base, "Petrobras Sans");
260 font-size: 16px;
261 font-style: normal;
262 font-weight: 400;
263 line-height: 160%; /* 22.4px */
264 }
265
266 .${rootCss} .bottom-wrapper .link-container {
267 flex: 0 1 auto;
268 }
269
270 .${rootCss} .bottom-wrapper .link-container .link {
271 color: var(--color-primary-solid-to-bright-200, var(--color-primary-medium));
272 font-family: var(--font-family-base, "Petrobras Sans");
273 font-size: 16px;
274 font-style: normal;
275 font-weight: 700;
276 line-height: 144%; /* 23.04px */
277 text-decoration-line: underline;
278 }
279
280
281 @media screen and (max-width: 1024px) {
282 .${rootCss} {
283 flex-direction: column;
284 gap: 16px;
285 min-width: 296px;
286 }
287
288 .${rootCss} img {
289 height: 140px;
290 }
291
292 .${rootCss} .head .date {
293 font-size: 12px;
294 }
295
296 .${rootCss} .head .title {
297 }
298
299 .${rootCss} .head .bar {
300 width: 18px;
301 margin: 8px 0 16px 0;
302 }
303
304 .${rootCss} .review-container {
305 font-size: 14px;
306 }
307 }
308 </style>
309</#if>
Navegue por conteúdo multimídia
Aprovados
Cadastro de Reserva
Documento
Foto
Mapa e Ilustração
Piauí
Vídeo
Áudio
Institucional
Download
Discurso da ministra da Cultura, Margareth Menezes, no lançamento da Seleção + ...
Publicado em 26/02/2024 às 13:09:00
Vídeo
Institucional
Download
Discurso do presidente da República, Luiz Inácio Lula da Silva, no lançament + ...
Publicado em 24/02/2024 às 01:32:00
Vídeo
Institucional
Download
Discurso do presidente da Petrobras, Jean Paul Prates, no lançamento da Sele + ...
Publicado em 24/02/2024 às 01:29:00
Vídeo
Institucional
Download
Seleção Petrobras Cultural-Novos Eixos - Gerente setorial de Patrocínio Cult + ...
Publicado em 23/02/2024 às 19:28:00
Vídeo
Utilize nossa busca para encontrar o que procura
Faça uma busca:
Buscar
Mais pesquisados
Preço dos combustíveis
Pré-Sal
Time Petrobras
SAC Petrobras
0800 728 9001
Acesso à Informação
Portal da Transparência- Assessoria de Imprensa
- Categorias
- Acesse também
© Copyright Petrobras 2024. Todos os direitos reservados.
Canais
Idioma
Acessibilidade
Busca
Um inesperado erro ocorreu.
Um inesperado erro ocorreu.
Faça uma busca:
Buscar
Mais pesquisados
Preço dos combustíveis
Pré-Sal
Time Petrobras
Um inesperado erro ocorreu.
Um inesperado erro ocorreu.