Skip to content

Commit

Permalink
UX improvements and refactoring
Browse files Browse the repository at this point in the history
* fixed dynamic links
* fixed some react errors
* ESSelector improved UX
* refactoring (using the dedicated icon components when possible)
  • Loading branch information
FlorianCassayre committed Sep 14, 2020
1 parent 43751bf commit 06aef67
Show file tree
Hide file tree
Showing 24 changed files with 112 additions and 53 deletions.
4 changes: 3 additions & 1 deletion src/lib/components/backoffice/MetadataTable/MetadataTable.js
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,9 @@ export default class MetadataTable extends Component {

return rows.map(row => (
<Table.Row key={row.name}>
<Table.Cell width={labelWidth}>{row.name}</Table.Cell>
<Table.Cell width={labelWidth}>
{row.icon} {row.name}
</Table.Cell>
<Table.Cell>
{typeof row.value == 'boolean'
? row.value
Expand Down
6 changes: 5 additions & 1 deletion src/lib/components/backoffice/UrlList/UrlList.js
Original file line number Diff line number Diff line change
Expand Up @@ -24,5 +24,9 @@ export class UrlList extends Component {
}

UrlList.propTypes = {
urls: PropTypes.array.isRequired,
urls: PropTypes.array,
};

UrlList.defaultProps = {
urls: null,
};
12 changes: 12 additions & 0 deletions src/lib/components/backoffice/icons/Icons.js
Original file line number Diff line number Diff line change
Expand Up @@ -66,3 +66,15 @@ export class ILLLibraryIcon extends Component {
return <Icon name="boxes" />;
}
}

export class InternalLocationIcon extends Component {
render() {
return <Icon name="map" />;
}
}

export class LibraryIcon extends Component {
render() {
return <Icon name="university" />;
}
}
2 changes: 1 addition & 1 deletion src/lib/forms/core/GroupField.js
Original file line number Diff line number Diff line change
Expand Up @@ -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,
};
Expand Down
4 changes: 4 additions & 0 deletions src/lib/forms/core/SelectorField.js
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,7 @@ export class SelectorField extends Component {
errorPath,
emptyHeader,
emptyDescription,
icon,
label,
required,
multiple,
Expand Down Expand Up @@ -121,6 +122,7 @@ export class SelectorField extends Component {
}
serializer={serializer}
placeholder={placeholderText}
icon={icon}
{...selectorProps}
/>
</Form.Field>
Expand All @@ -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,
Expand All @@ -161,4 +164,5 @@ SelectorField.defaultProps = {
renderSelection: null,
renderGroup: null,
label: '',
icon: null,
};
7 changes: 6 additions & 1 deletion src/lib/modules/Document/DocumentCard/DocumentCard.js
Original file line number Diff line number Diff line change
Expand Up @@ -37,13 +37,18 @@ class DocumentCard extends Component {
render() {
const { data } = this.props;
const { metadata } = data;
const url = FrontSiteRoutes.documentDetailsFor(metadata.pid);
return (
<Overridable id="DocumentCard.layout" {...this.props}>
<Card
link
centered
className="fs-book-card"
onClick={() => goTo(FrontSiteRoutes.documentDetailsFor(metadata.pid))}
href={url}
onClick={e => {
e.preventDefault();
goTo(url);
}}
data-test={metadata.pid}
>
<Card.Meta className="discrete">{metadata.document_type}</Card.Meta>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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 => {
Expand Down Expand Up @@ -70,7 +71,7 @@ export default class DocumentListEntry extends Component {
{document.metadata.eitems.total > 0 ? (
<List.Item>
<List.Content floated="right">
<Icon name="desktop" />
<EItemIcon />
</List.Content>
<List.Content>Has electronic items</List.Content>
</List.Item>
Expand Down
31 changes: 20 additions & 11 deletions src/lib/modules/ESSelector/ESSelector.js
Original file line number Diff line number Diff line change
@@ -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';
Expand Down Expand Up @@ -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 = (
<Label>
{icon}
{selection.title}
<Label.Detail>{selection.description}</Label.Detail>
<Icon name="delete" onClick={() => removeSelection(selection)} />
</Label>
);

return (
<List.Item key={selection.id}>
<List.Icon name="angle right" size="small" verticalAlign="middle" />
<List.Content onClick={() => removeSelection(selection)}>
<List.Header as="a">
<span className="extra">{selection.extra}</span>
{selection.title}
<Icon name="delete" />
</List.Header>
<List.Description as="a">{selection.description}</List.Description>
<List.Content>
{selection.extra ? (
<Popup content={selection.extra} trigger={label} />
) : (
label
)}
</List.Content>
</List.Item>
);
Expand All @@ -98,7 +105,7 @@ class ESSelector extends Component {

return (
<Container className="result-selections">
<List divided relaxed>
<List>
{selections.map(selection =>
renderSelection(selection, removeSelection)
)}
Expand Down Expand Up @@ -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,
Expand All @@ -195,6 +203,7 @@ ESSelector.defaultProps = {
delay: 250,
initialSelections: [],
minCharacters: 3,
icon: null,
onSelectionsUpdate: () => {},
emptySelectionInfoText: null,
selectionInfoText: null,
Expand Down
3 changes: 2 additions & 1 deletion src/lib/modules/Literature/LiteratureTags.js
Original file line number Diff line number Diff line change
Expand Up @@ -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);
Original file line number Diff line number Diff line change
Expand Up @@ -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() {
Expand All @@ -26,7 +27,7 @@ export class DocumentCard extends Component {
url={_get(data, 'metadata.cover_metadata.urls.medium')}
/>
) : (
<Icon name="clone outline" size="huge" color="grey" />
<SeriesIcon size="huge" color="grey" />
)}
<Card.Content>
<Card.Header as={Link} to={linkTo} target="_blank">
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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() {
Expand All @@ -16,7 +17,7 @@ export default class SeriesCard extends Component {
{actions}
{data.metadata.document_type || data.metadata.mode_of_issuance}
</Card.Meta>
<Icon name="clone outline" size="huge" color="grey" />
<SeriesIcon size="huge" color="grey" />
<Card.Content>
<Card.Header as={Link} to={linkTo} target="_blank">
{data.metadata.title}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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() {
Expand All @@ -29,7 +30,7 @@ export class RelationListEntry extends Component {
url={_get(record, 'metadata.cover_metadata.urls.medium')}
/>
) : (
<Icon name="clone outline" size="huge" color="grey" />
<SeriesIcon size="huge" color="grey" />
);
return (
<Item className="relation-list-entry">
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -189,7 +189,7 @@ export default class OrderDetails extends React.Component {

render() {
const { isLoading, error, data } = this.props;

const metadata = data.metadata || {};
return (
<div ref={this.headerRef}>
<Container fluid>
Expand All @@ -208,16 +208,16 @@ export default class OrderDetails extends React.Component {
<Grid.Column width={13}>
<Container className="spaced">
<Container className="spaced">
<OrderStatistics order={data.metadata} />
<OrderStatistics order={metadata} />
<br />
<OrderSteps order={data.metadata} />
<OrderSteps order={metadata} />
</Container>
<OrderPanels data={data.metadata} />
<OrderPanels data={metadata} />
</Container>
</Grid.Column>
<Grid.Column width={3}>
<Sticky context={this.menuRef} offset={150}>
<ActionMenu data={data.metadata} offset={-150} />
<ActionMenu data={metadata} offset={-150} />
</Sticky>
</Grid.Column>
</Grid>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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() {
Expand All @@ -24,6 +25,7 @@ export class OrderInfo extends Component {
errorPath="vendor_pid"
label="Vendor"
placeholder="Search for a vendor..."
icon={<AcquisitionVendorIcon />}
query={vendorApi.list}
serializer={serializeVendor}
/>
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -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 }) => {
Expand Down Expand Up @@ -44,6 +45,7 @@ export class OrderLines extends Component {
errorPath={`${arrayPath}.${indexPath}.document_pid`}
label="Document"
placeholder="Search for a document..."
icon={<DocumentIcon />}
query={documentApi.list}
serializer={serializeDocument}
/>
Expand Down Expand Up @@ -117,6 +119,7 @@ export class OrderLines extends Component {
errorPath={`${arrayPath}.${indexPath}.patron_pid`}
label="Patron"
placeholder="Search for a patron..."
icon={<PatronIcon />}
query={patronApi.list}
serializer={serializePatron}
width={10}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ export class DocumentBasicMetadata extends Component {
<Grid stretched columns="equal">
<Grid.Row className="no-padding ">
<Grid.Column width={8}>
<GroupField noBottomMargin widths="equal">
<GroupField widths="equal">
<StringField
label="Publication year"
fieldPath="publication_year"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import PropTypes from 'prop-types';
import React, { Component } from 'react';
import { Grid, Header, Segment } from 'semantic-ui-react';
import eitemSubmitSerializer from './eitemSubmitSerializer';
import { DocumentIcon } from '@components/backoffice/icons';

export class EItemForm extends Component {
prepareData = data => {
Expand Down Expand Up @@ -74,6 +75,7 @@ export class EItemForm extends Component {
errorPath="document_pid"
label="Document"
placeholder="Search for a document..."
icon={<DocumentIcon />}
query={documentApi.list}
serializer={serializeDocument}
/>
Expand Down Expand Up @@ -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,
};
Original file line number Diff line number Diff line change
Expand Up @@ -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() {
Expand All @@ -33,6 +35,7 @@ export class OrderInfo extends Component {
errorPath="document_pid"
label="Document"
placeholder="Search for a document..."
icon={<DocumentIcon />}
query={documentApi.list}
serializer={serializeDocument}
/>
Expand All @@ -46,6 +49,7 @@ export class OrderInfo extends Component {
errorPath="patron_pid"
label="Patron"
placeholder="Search for a patron..."
icon={<PatronIcon />}
query={patronApi.list}
serializer={serializePatron}
/>
Expand All @@ -59,6 +63,7 @@ export class OrderInfo extends Component {
errorPath="library_pid"
label="Library"
placeholder="Search for a library..."
icon={<LibraryIcon />}
query={libraryApi.list}
serializer={serializeLibrary}
/>
Expand Down
Loading

0 comments on commit 06aef67

Please sign in to comment.