design-comuni-plone-theme
Version:
Volto Theme for Italia design guidelines
136 lines (124 loc) • 3.92 kB
JSX
/**
* DocumentoView view component.
* @module components/theme/View/DocumentoView
*/
import React, { createRef } from 'react';
import PropTypes from 'prop-types';
import {
DocumentoDescrizione,
DocumentoDocumenti,
DocumentoPlaceholderAfterContent,
DocumentoPlaceholderAfterRelatedItems,
DocumentoUfficioResponsabile,
DocumentoAreaResponsabile,
DocumentoAccedereServizio,
DocumentoDocAllegati,
DocumentoUlterioriInformazioni,
ContentImage,
PageHeader,
RelatedItems,
RelatedItemInEvidence,
SkipToMainContent,
ContentTypeViewSections,
useSideMenu,
} from 'design-comuni-plone-theme/components/ItaliaTheme/View';
import { defineMessages, useIntl } from 'react-intl';
const messages = defineMessages({
sideMenuIndex: {
id: 'sideMenuIndex',
defaultMessage: 'Indice della pagina',
},
documentContent: {
id: 'documentContent',
defaultMessage: 'Contenuto del documento',
},
});
export const DocumentoViewSectionsOrder = [
{
/* HEADER IMAGE */
component: ContentImage,
props: { position: 'documentBody' },
},
{ /* DESCRIZIONE*/ component: DocumentoDescrizione },
{ /* DOCUMENTI */ component: DocumentoDocumenti },
{ /* UFFICIO RESPONSABILE */ component: DocumentoUfficioResponsabile },
{ /* AREA RESPONSABILE */ component: DocumentoAreaResponsabile },
{ /* ACCEDERE AL SERVIZIO */ component: DocumentoAccedereServizio },
{ /* ULTERIORI INFORMAZIONI */ component: DocumentoUlterioriInformazioni },
{ /* DOCUMENTI ALLEGATI */ component: DocumentoDocAllegati },
];
/**
* DocumentoView view component class.
* @function DocumentoView
* @params {object} content Content object.
* @returns {string} Markup of the component.
*/
const DocumentoView = ({ content, location }) => {
let documentBody = createRef();
const intl = useIntl();
const { sideMenuElements, SideMenu } = useSideMenu(content, documentBody);
//const userLogged = useSelector((state) => state.userSession);
return (
<>
<div className="container px-4 my-4 documento-view">
<SkipToMainContent />
<PageHeader
content={content}
readingtime={null}
showtassonomiaargomenti={true}
/>
{/* HEADER IMAGE */}
<ContentImage content={content} position="afterHeader" />
<div className="row row-column-border border-light row-column-menu-left">
<aside
className="col-lg-4"
aria-label={intl.formatMessage(messages.sideMenuIndex)}
>
{__CLIENT__ && (
<SideMenu data={sideMenuElements} content_uid={content?.UID} />
)}
</aside>
<section
ref={documentBody}
id="main-content-section"
className="col-lg-8 it-page-sections-container border-light"
role="region"
aria-label={intl.formatMessage(messages.documentContent)}
>
{/* SEZIONI */}
<ContentTypeViewSections
content={content}
defaultSections={DocumentoViewSectionsOrder}
/>
</section>
</div>
</div>
<DocumentoPlaceholderAfterContent content={content} />
<RelatedItems content={content} />
<RelatedItemInEvidence content={content} />
<DocumentoPlaceholderAfterRelatedItems content={content} />
</>
);
};
/**
* Property types.
* @property {Object} propTypes Property types.
* @static
*/
DocumentoView.propTypes = {
content: PropTypes.shape({
title: PropTypes.string.isRequired,
description: PropTypes.string,
image: PropTypes.object,
image_caption: PropTypes.string,
items: PropTypes.array,
modified: PropTypes.string,
tassonomia_argomenti: PropTypes.arrayOf(
PropTypes.shape({
title: PropTypes.string,
token: PropTypes.string,
}),
),
}).isRequired,
};
export default DocumentoView;