clientjs/packages/dashboard-components/src/ui/DefinitionsCards.jsx
author ymh <ymh.work@gmail.com>
Mon, 17 Sep 2018 10:47:06 +0200
changeset 5 b26c9c44dd84
parent 0 5f4fcbc80b37
permissions -rw-r--r--
correct deploy scripts and deploy tests


import React from 'react';
import PropTypes from 'prop-types';

import { FormattedMessage } from 'react-intl';

import DefinitionBlock from './DefinitionBlock';

const DefinitionsCards = ({ annotations, metacategories, children }) => {
  const defBlocks = annotations.map(
    annotation => <DefinitionBlock key={`annotation-${annotation.id}`} annotation={annotation} metacategories={metacategories} />,
  );

  let noDefinitionContent = <FormattedMessage id="ui.definitionCards.noDefinition" defaultMessage="No definition yet" />;

  if (React.Children.count(children) > 0) {
    noDefinitionContent = children;
  }

  return (
    <div className="card-columns">
      { annotations.length === 0 ? noDefinitionContent : defBlocks }
    </div>
  );
};

DefinitionsCards.propTypes = {
  annotations: PropTypes.arrayOf(PropTypes.object),
  metacategories: PropTypes.arrayOf(PropTypes.object).isRequired,
  children: PropTypes.node,
};

DefinitionsCards.defaultProps = {
  annotations: [],
  children: null,
};

export default DefinitionsCards;