diff --git a/src/lib/components/backoffice/MetadataTable/MetadataTable.js b/src/lib/components/backoffice/MetadataTable/MetadataTable.js index 940218da4..f7c818b71 100644 --- a/src/lib/components/backoffice/MetadataTable/MetadataTable.js +++ b/src/lib/components/backoffice/MetadataTable/MetadataTable.js @@ -8,7 +8,9 @@ export default class MetadataTable extends Component { return rows.map(row => ( - {row.name} + + {row.icon} {row.name} + {typeof row.value == 'boolean' ? row.value diff --git a/src/lib/components/backoffice/UrlList/UrlList.js b/src/lib/components/backoffice/UrlList/UrlList.js index a954e8fd2..45e55d68e 100644 --- a/src/lib/components/backoffice/UrlList/UrlList.js +++ b/src/lib/components/backoffice/UrlList/UrlList.js @@ -24,5 +24,9 @@ export class UrlList extends Component { } UrlList.propTypes = { - urls: PropTypes.array.isRequired, + urls: PropTypes.array, +}; + +UrlList.defaultProps = { + urls: null, }; diff --git a/src/lib/components/backoffice/icons/Icons.js b/src/lib/components/backoffice/icons/Icons.js index 7438d53d6..f86577a83 100644 --- a/src/lib/components/backoffice/icons/Icons.js +++ b/src/lib/components/backoffice/icons/Icons.js @@ -66,3 +66,15 @@ export class ILLLibraryIcon extends Component { return ; } } + +export class InternalLocationIcon extends Component { + render() { + return ; + } +} + +export class LibraryIcon extends Component { + render() { + return ; + } +} diff --git a/src/lib/forms/core/GroupField.js b/src/lib/forms/core/GroupField.js index 941b5602c..7479b871a 100644 --- a/src/lib/forms/core/GroupField.js +++ b/src/lib/forms/core/GroupField.js @@ -62,7 +62,7 @@ export class GroupField extends React.Component { GroupField.propTypes = { border: PropTypes.bool, fieldPath: PropTypes.string, - action: PropTypes.func, + action: PropTypes.node, children: PropTypes.node, basic: PropTypes.bool, }; diff --git a/src/lib/forms/core/SelectorField.js b/src/lib/forms/core/SelectorField.js index bc03ee493..fb20a5f44 100644 --- a/src/lib/forms/core/SelectorField.js +++ b/src/lib/forms/core/SelectorField.js @@ -73,6 +73,7 @@ export class SelectorField extends Component { errorPath, emptyHeader, emptyDescription, + icon, label, required, multiple, @@ -121,6 +122,7 @@ export class SelectorField extends Component { } serializer={serializer} placeholder={placeholderText} + icon={icon} {...selectorProps} /> @@ -139,6 +141,7 @@ SelectorField.propTypes = { emptyHeader: PropTypes.string, errorPath: PropTypes.string.isRequired, fieldPath: PropTypes.string.isRequired, + icon: PropTypes.any, label: PropTypes.string, optimized: PropTypes.bool, serializer: PropTypes.func.isRequired, @@ -161,4 +164,5 @@ SelectorField.defaultProps = { renderSelection: null, renderGroup: null, label: '', + icon: null, }; diff --git a/src/lib/modules/Document/DocumentCard/DocumentCard.js b/src/lib/modules/Document/DocumentCard/DocumentCard.js index 0cbaa20cd..ed27d4b1d 100644 --- a/src/lib/modules/Document/DocumentCard/DocumentCard.js +++ b/src/lib/modules/Document/DocumentCard/DocumentCard.js @@ -37,13 +37,18 @@ class DocumentCard extends Component { render() { const { data } = this.props; const { metadata } = data; + const url = FrontSiteRoutes.documentDetailsFor(metadata.pid); return ( goTo(FrontSiteRoutes.documentDetailsFor(metadata.pid))} + href={url} + onClick={e => { + e.preventDefault(); + goTo(url); + }} data-test={metadata.pid} > {metadata.document_type} diff --git a/src/lib/modules/Document/backoffice/DocumentList/DocumentListEntry.js b/src/lib/modules/Document/backoffice/DocumentList/DocumentListEntry.js index 566a03a69..c790e5e4c 100644 --- a/src/lib/modules/Document/backoffice/DocumentList/DocumentListEntry.js +++ b/src/lib/modules/Document/backoffice/DocumentList/DocumentListEntry.js @@ -10,6 +10,7 @@ import React, { Component } from 'react'; import { Link } from 'react-router-dom'; import { Grid, Header, Icon, Item, List } from 'semantic-ui-react'; import DocumentCirculation from './DocumentCirculation'; +import { EItemIcon } from '@components/backoffice/icons'; export default class DocumentListEntry extends Component { renderMiddleColumn = document => { @@ -70,7 +71,7 @@ export default class DocumentListEntry extends Component { {document.metadata.eitems.total > 0 ? ( - + Has electronic items diff --git a/src/lib/modules/ESSelector/ESSelector.js b/src/lib/modules/ESSelector/ESSelector.js index 875db6b5b..5f5270d32 100644 --- a/src/lib/modules/ESSelector/ESSelector.js +++ b/src/lib/modules/ESSelector/ESSelector.js @@ -1,7 +1,7 @@ import React, { Component } from 'react'; import PropTypes from 'prop-types'; import Overridable from 'react-overridable'; -import { List, Container, Icon } from 'semantic-ui-react'; +import { List, Container, Icon, Label, Popup } from 'semantic-ui-react'; import _isEmpty from 'lodash/isEmpty'; import { HitsSearch } from './HitsSearch'; import find from 'lodash/find'; @@ -74,19 +74,26 @@ class ESSelector extends Component { }; renderSelection = (selection, removeSelection) => { - const { renderSelection } = this.props; + const { renderSelection, icon } = this.props; if (renderSelection) return renderSelection; + const label = ( + + ); + return ( - - removeSelection(selection)}> - - {selection.extra} - {selection.title} - - - {selection.description} + + {selection.extra ? ( + + ) : ( + label + )} ); @@ -98,7 +105,7 @@ class ESSelector extends Component { return ( - + {selections.map(selection => renderSelection(selection, removeSelection) )} @@ -186,6 +193,7 @@ ESSelector.propTypes = { serializer: PropTypes.func, id: PropTypes.string, name: PropTypes.string, + icon: PropTypes.any, selectionInfoText: PropTypes.string, emptySelectionInfoText: PropTypes.string, focus: PropTypes.bool, @@ -195,6 +203,7 @@ ESSelector.defaultProps = { delay: 250, initialSelections: [], minCharacters: 3, + icon: null, onSelectionsUpdate: () => {}, emptySelectionInfoText: null, selectionInfoText: null, diff --git a/src/lib/modules/Literature/LiteratureTags.js b/src/lib/modules/Literature/LiteratureTags.js index dff9e5293..36c18c245 100644 --- a/src/lib/modules/Literature/LiteratureTags.js +++ b/src/lib/modules/Literature/LiteratureTags.js @@ -40,11 +40,12 @@ class LiteratureTags extends Component { LiteratureTags.propTypes = { tags: PropTypes.array, - isBackOffice: PropTypes.bool.isRequired, + isBackOffice: PropTypes.bool, }; LiteratureTags.defaultProps = { tags: [], + isBackOffice: true, }; export default Overridable.component('LiteratureTags', LiteratureTags); diff --git a/src/lib/modules/Relations/backoffice/components/RelationCard/DocumentCard.js b/src/lib/modules/Relations/backoffice/components/RelationCard/DocumentCard.js index 9eb2b8fa3..a7c3b8535 100644 --- a/src/lib/modules/Relations/backoffice/components/RelationCard/DocumentCard.js +++ b/src/lib/modules/Relations/backoffice/components/RelationCard/DocumentCard.js @@ -8,7 +8,8 @@ import _isEmpty from 'lodash/isEmpty'; import PropTypes from 'prop-types'; import React, { Component } from 'react'; import { Link } from 'react-router-dom'; -import { Card, Icon } from 'semantic-ui-react'; +import { Card } from 'semantic-ui-react'; +import { SeriesIcon } from '@components/backoffice/icons'; export class DocumentCard extends Component { render() { @@ -26,7 +27,7 @@ export class DocumentCard extends Component { url={_get(data, 'metadata.cover_metadata.urls.medium')} /> ) : ( - + )} diff --git a/src/lib/modules/Relations/backoffice/components/RelationCard/SeriesCard.js b/src/lib/modules/Relations/backoffice/components/RelationCard/SeriesCard.js index b4b3a1ac7..939877c16 100644 --- a/src/lib/modules/Relations/backoffice/components/RelationCard/SeriesCard.js +++ b/src/lib/modules/Relations/backoffice/components/RelationCard/SeriesCard.js @@ -3,8 +3,9 @@ import { BackOfficeRoutes } from '@routes/urls'; import React, { Component } from 'react'; import PropTypes from 'prop-types'; import { Link } from 'react-router-dom'; -import { Card, Icon } from 'semantic-ui-react'; +import { Card } from 'semantic-ui-react'; import _isEmpty from 'lodash/isEmpty'; +import { SeriesIcon } from '@components/backoffice/icons'; export default class SeriesCard extends Component { render() { @@ -16,7 +17,7 @@ export default class SeriesCard extends Component { {actions} {data.metadata.document_type || data.metadata.mode_of_issuance} - + {data.metadata.title} diff --git a/src/lib/modules/Relations/backoffice/components/RelationListEntry.js b/src/lib/modules/Relations/backoffice/components/RelationListEntry.js index b90fd5b7a..1a22d6ae9 100644 --- a/src/lib/modules/Relations/backoffice/components/RelationListEntry.js +++ b/src/lib/modules/Relations/backoffice/components/RelationListEntry.js @@ -9,7 +9,8 @@ import _get from 'lodash/get'; import PropTypes from 'prop-types'; import React, { Component } from 'react'; import { Link } from 'react-router-dom'; -import { Grid, Icon, Item } from 'semantic-ui-react'; +import { Grid, Item } from 'semantic-ui-react'; +import { SeriesIcon } from '@components/backoffice/icons'; export class RelationListEntry extends Component { render() { @@ -29,7 +30,7 @@ export class RelationListEntry extends Component { url={_get(record, 'metadata.cover_metadata.urls.medium')} /> ) : ( - + ); return ( diff --git a/src/lib/pages/backoffice/Acquisition/Order/OrderDetails/OrderDetails.js b/src/lib/pages/backoffice/Acquisition/Order/OrderDetails/OrderDetails.js index ece7691b4..73ced82e2 100644 --- a/src/lib/pages/backoffice/Acquisition/Order/OrderDetails/OrderDetails.js +++ b/src/lib/pages/backoffice/Acquisition/Order/OrderDetails/OrderDetails.js @@ -189,7 +189,7 @@ export default class OrderDetails extends React.Component { render() { const { isLoading, error, data } = this.props; - + const metadata = data.metadata || {}; return (
@@ -208,16 +208,16 @@ export default class OrderDetails extends React.Component { - +
- +
- +
- + diff --git a/src/lib/pages/backoffice/Acquisition/Order/OrderEditor/OrderForm/OrderInfo.js b/src/lib/pages/backoffice/Acquisition/Order/OrderEditor/OrderForm/OrderInfo.js index 0a2c90987..3de22b8a9 100644 --- a/src/lib/pages/backoffice/Acquisition/Order/OrderEditor/OrderForm/OrderInfo.js +++ b/src/lib/pages/backoffice/Acquisition/Order/OrderEditor/OrderForm/OrderInfo.js @@ -10,6 +10,7 @@ import { TextField } from '@forms/core/TextField'; import { serializeVendor } from '@modules/ESSelector/serializer'; import PropTypes from 'prop-types'; import React, { Component } from 'react'; +import { AcquisitionVendorIcon } from '@components/backoffice/icons'; export class OrderInfo extends Component { render() { @@ -24,6 +25,7 @@ export class OrderInfo extends Component { errorPath="vendor_pid" label="Vendor" placeholder="Search for a vendor..." + icon={} query={vendorApi.list} serializer={serializeVendor} /> diff --git a/src/lib/pages/backoffice/Acquisition/Order/OrderEditor/OrderForm/OrderLines.js b/src/lib/pages/backoffice/Acquisition/Order/OrderEditor/OrderForm/OrderLines.js index 13922da33..e80ce91f3 100644 --- a/src/lib/pages/backoffice/Acquisition/Order/OrderEditor/OrderForm/OrderLines.js +++ b/src/lib/pages/backoffice/Acquisition/Order/OrderEditor/OrderForm/OrderLines.js @@ -17,6 +17,7 @@ import { import PropTypes from 'prop-types'; import React, { Component } from 'react'; import { Segment, Divider, Grid } from 'semantic-ui-react'; +import { DocumentIcon, PatronIcon } from '@components/backoffice/icons'; export class OrderLines extends Component { renderArrayItem = ({ arrayPath, indexPath, ...arrayHelpers }) => { @@ -44,6 +45,7 @@ export class OrderLines extends Component { errorPath={`${arrayPath}.${indexPath}.document_pid`} label="Document" placeholder="Search for a document..." + icon={} query={documentApi.list} serializer={serializeDocument} /> @@ -117,6 +119,7 @@ export class OrderLines extends Component { errorPath={`${arrayPath}.${indexPath}.patron_pid`} label="Patron" placeholder="Search for a patron..." + icon={} query={patronApi.list} serializer={serializePatron} width={10} diff --git a/src/lib/pages/backoffice/Document/DocumentForms/DocumentEditor/DocumentForm/DocumentBasicMetadata.js b/src/lib/pages/backoffice/Document/DocumentForms/DocumentEditor/DocumentForm/DocumentBasicMetadata.js index c99e7aae7..7ac1c9bde 100644 --- a/src/lib/pages/backoffice/Document/DocumentForms/DocumentEditor/DocumentForm/DocumentBasicMetadata.js +++ b/src/lib/pages/backoffice/Document/DocumentForms/DocumentEditor/DocumentForm/DocumentBasicMetadata.js @@ -21,7 +21,7 @@ export class DocumentBasicMetadata extends Component { - + { @@ -74,6 +75,7 @@ export class EItemForm extends Component { errorPath="document_pid" label="Document" placeholder="Search for a document..." + icon={} query={documentApi.list} serializer={serializeDocument} /> @@ -135,11 +137,12 @@ EItemForm.propTypes = { data: PropTypes.object, successSubmitMessage: PropTypes.string, title: PropTypes.string, - pid: PropTypes.string.isRequired, + pid: PropTypes.string, }; EItemForm.defaultProps = { data: null, successSubmitMessage: null, title: null, + pid: null, }; diff --git a/src/lib/pages/backoffice/ILL/BorrowingRequest/BorrowingRequestEditor/BorrowingRequestForm/OrderInfo.js b/src/lib/pages/backoffice/ILL/BorrowingRequest/BorrowingRequestEditor/BorrowingRequestForm/OrderInfo.js index ed6a1e691..26fa30a53 100644 --- a/src/lib/pages/backoffice/ILL/BorrowingRequest/BorrowingRequestEditor/BorrowingRequestForm/OrderInfo.js +++ b/src/lib/pages/backoffice/ILL/BorrowingRequest/BorrowingRequestEditor/BorrowingRequestForm/OrderInfo.js @@ -17,6 +17,8 @@ import { import PropTypes from 'prop-types'; import React, { Component } from 'react'; import { Grid } from 'semantic-ui-react'; +import { DocumentIcon, PatronIcon } from '@components/backoffice/icons'; +import { LibraryIcon } from '@components/backoffice/icons/Icons'; export class OrderInfo extends Component { render() { @@ -33,6 +35,7 @@ export class OrderInfo extends Component { errorPath="document_pid" label="Document" placeholder="Search for a document..." + icon={} query={documentApi.list} serializer={serializeDocument} /> @@ -46,6 +49,7 @@ export class OrderInfo extends Component { errorPath="patron_pid" label="Patron" placeholder="Search for a patron..." + icon={} query={patronApi.list} serializer={serializePatron} /> @@ -59,6 +63,7 @@ export class OrderInfo extends Component { errorPath="library_pid" label="Library" placeholder="Search for a library..." + icon={} query={libraryApi.list} serializer={serializeLibrary} /> diff --git a/src/lib/pages/backoffice/Item/ItemDetails/ItemCirculation/ItemCirculation.js b/src/lib/pages/backoffice/Item/ItemDetails/ItemCirculation/ItemCirculation.js index 0f5cd9df4..2502f288f 100644 --- a/src/lib/pages/backoffice/Item/ItemDetails/ItemCirculation/ItemCirculation.js +++ b/src/lib/pages/backoffice/Item/ItemDetails/ItemCirculation/ItemCirculation.js @@ -15,6 +15,11 @@ import { Message, Segment, } from 'semantic-ui-react'; +import { + InternalLocationIcon, + LibraryIcon, + PatronIcon, +} from '@components/backoffice/icons/Icons'; class ItemStatusMessageOnLoan extends Component { render() { @@ -24,7 +29,7 @@ class ItemStatusMessageOnLoan extends Component { { name: ( <> - Patron{' '} + Patron{' '} ), value: ( @@ -189,7 +194,7 @@ export default class ItemCirculation extends Component { to={BackOfficeRoutes.locationsList} size="small" > - + {metadata.internal_location.name} @@ -206,7 +211,7 @@ export default class ItemCirculation extends Component { to={BackOfficeRoutes.locationsList} size="small" > - + {metadata.internal_location.location.name} Location diff --git a/src/lib/pages/backoffice/Item/ItemForms/ItemEditor/ItemForm/ItemForm.js b/src/lib/pages/backoffice/Item/ItemForms/ItemEditor/ItemForm/ItemForm.js index 987ff8723..d4ae93447 100644 --- a/src/lib/pages/backoffice/Item/ItemForms/ItemEditor/ItemForm/ItemForm.js +++ b/src/lib/pages/backoffice/Item/ItemForms/ItemEditor/ItemForm/ItemForm.js @@ -24,6 +24,8 @@ import PropTypes from 'prop-types'; import React, { Component } from 'react'; import itemSubmitSerializer from './itemSubmitSerializer'; import { Segment, Header } from 'semantic-ui-react'; +import { DocumentIcon } from '@components/backoffice/icons'; +import { InternalLocationIcon } from '@components/backoffice/icons/Icons'; export class ItemForm extends Component { constructor(props) { @@ -160,6 +162,7 @@ export class ItemForm extends Component { errorPath="document_pid" label="Document" placeholder="Search for a document..." + icon={} query={documentApi.list} serializer={serializeDocument} width={8} @@ -182,6 +185,7 @@ export class ItemForm extends Component { errorPath="internal_location_pid" label="Internal location" placeholder="Search for an internal location..." + icon={} query={internalLocationApi.list} serializer={serializeInternalLocation} width={8} @@ -276,11 +280,12 @@ ItemForm.propTypes = { data: PropTypes.object, successSubmitMessage: PropTypes.string, title: PropTypes.string, - pid: PropTypes.string.isRequired, + pid: PropTypes.string, }; ItemForm.defaultProps = { data: null, successSubmitMessage: null, title: null, + pid: null, }; diff --git a/src/lib/pages/backoffice/Loan/LoanDetails/LoanMetadata/LoanMetadata.js b/src/lib/pages/backoffice/Loan/LoanDetails/LoanMetadata/LoanMetadata.js index 746dd467b..e908c7cc1 100644 --- a/src/lib/pages/backoffice/Loan/LoanDetails/LoanMetadata/LoanMetadata.js +++ b/src/lib/pages/backoffice/Loan/LoanDetails/LoanMetadata/LoanMetadata.js @@ -52,12 +52,8 @@ export class LoanMetadata extends Component { ), }, { - name: ( - <> - - Document - - ), + name: 'Document', + icon: , value: ( - - Physical copy - - ), + name: 'Physical copy', + icon: , value: data.metadata.item_pid ? ( {data.metadata.item_pid && data.metadata.item_pid.type === 'illbid' @@ -84,12 +76,8 @@ export class LoanMetadata extends Component { ), }, { - name: ( - <> - - Patron - - ), + name: 'Patron', + icon: , value: ( {data.metadata.patron.name} diff --git a/src/lib/pages/backoffice/Location/LocationForms/InternalLocationEditor/components/InternalLocationForm/InternalLocationForm.js b/src/lib/pages/backoffice/Location/LocationForms/InternalLocationEditor/components/InternalLocationForm/InternalLocationForm.js index 728883efc..89bd0fb21 100644 --- a/src/lib/pages/backoffice/Location/LocationForms/InternalLocationEditor/components/InternalLocationForm/InternalLocationForm.js +++ b/src/lib/pages/backoffice/Location/LocationForms/InternalLocationEditor/components/InternalLocationForm/InternalLocationForm.js @@ -14,6 +14,7 @@ import pick from 'lodash/pick'; import PropTypes from 'prop-types'; import React, { Component } from 'react'; import { Header, Segment } from 'semantic-ui-react'; +import { InternalLocationIcon } from '@components/backoffice/icons/Icons'; export class InternalLocationForm extends Component { prepareData = data => { @@ -81,6 +82,7 @@ export class InternalLocationForm extends Component { errorPath="location_pid" label="Location" placeholder="Search for a location..." + icon={} query={locationApi.list} serializer={serializeLocation} width={8} diff --git a/src/lib/pages/frontsite/Home/Sections/SectionServices.js b/src/lib/pages/frontsite/Home/Sections/SectionServices.js index dac57f61f..5627b7710 100644 --- a/src/lib/pages/frontsite/Home/Sections/SectionServices.js +++ b/src/lib/pages/frontsite/Home/Sections/SectionServices.js @@ -1,5 +1,6 @@ import React, { Component } from 'react'; import { Button, Card, Container, Header, Icon } from 'semantic-ui-react'; +import { ILLLibraryIcon } from '@components/backoffice/icons'; export class SectionServices extends Component { render() { @@ -32,7 +33,7 @@ export class SectionServices extends Component { - Acquisition + Acquisition If you think the library should buy literature, please let diff --git a/src/semantic-ui/site/elements/container.overrides b/src/semantic-ui/site/elements/container.overrides index ecf00fcbe..acae91da7 100644 --- a/src/semantic-ui/site/elements/container.overrides +++ b/src/semantic-ui/site/elements/container.overrides @@ -262,5 +262,9 @@ Container Overrides - REACT-INVENIO-APP-ILS &.details-header { padding-bottom: 1em; } + + &.result-selections { + margin-top: .5em; + } } }