0.2.7 • Published 3 months ago

@source-data/render-rev v0.2.7

Weekly downloads
-
License
MIT
Repository
-
Last release
3 months ago

\

Visualizing the peer review process.

render-rev is a Web Components-based Javascript package that fetches data about the peer review process of a preprint and displays it in the form of a timeline. The timeline contains the most important points of the process such as reviews and author replies:

An example image of how render-rev displays the peer review process as a timeline.

If available, the full text of peer reviews and author replies can be viewed in a built-in reader:

An example image of how render-rev displays the full text of reviews and responses.

render-rev was built by EMBO's Open Science Implementation Group for EMBO Press. The project was funded by the Wellcome Trust (Learned Society Curation Award 221510/Z/20/Z).

DocMaps

All data about the review process is fetched from the Early Evidence Base (EEB) API in the DocMaps format.

The DocMaps framework is used at EMBO Press to describe the peer review process that a scientific article went through. Given the DOI of an article, the EEB service returns a list of DocMap objects that each describe a single round of the peer review process.

A DocMap consists of one or more ordered steps. Each step has inputs, and actions that were taken during the step, outputs, and assertions about the article that hold after this step.

As an example, a round of reviews with 3 peer reviews and a reply by the article authors could consist of two steps: 1. Step: reviews

  • input: the article under review
  • actions: 3 referees each writing a review
  • outputs: the 3 reviews
  • assertion: that the article is peer-reviewed
  1. Step: author reply
    • inputs: the 3 reviews from the previous step
    • action: the article authors writing a reply to the reviews
    • output: an author reply
    • assertion: that the article authors have replied to the reviews

The DocMaps documentation can be found at https://docmaps.knowledgefutures.org/pub/sgkf1pqa/release/7

Installation

npm i render-rev

Usage

Importing the render-rev package automatically register the <render-rev> custom element. Use this element and pass it the DOI of the preprint you want to display:

<script type="module">
  import '@source-data/render-rev';
</script>

<render-rev doi="10.1101/2020.07.20.212886"></render-rev>

Customization

To customize the look of the rendered review process, or to pass in data from an external source, use the .configure() method of the element:

<render-rev id="render-rev-0"></render-rev>

<script type="module">
  import '@source-data/render-rev';
  const renderRevElement = document.getElementById('render-rev-0');
  renderRevElement.configure({
    doi: '10.1101/2020.07.20.212886',
    display: {
      publisherName: name => name.toUpperCase(),
    }
  });
</script>

Configuration Options

  • debug: Passing a truthy value activates detailed logging during DocMaps parsing.
  • docmaps: Pass in an array of DocMaps that represent the review process of a preprint. Overrides both the configuration option and the custom element attribute named doi.
  • docmapsUrl: A callable that receives a DOI and returns a URL that returns an array of DocMaps in JSON format. Defaults to a function that returns https://eeb.embo.org/api/v2/docmaps/${doi}.
  • doi: Display the review process of the preprint with this DOI. Overrides the value passed to the doi custom element attribute.
  • display: Pass in an object to configure how the review process is displayed with one of the following keys:
    • formatDate: A callable that receives a Date object and returns a string representation of this date. Dates passed to this function are displayed in the timeline and above the full-text of reviews and responses in the highlight viewer. By default dates are formatted as <Name of month abbreviated> <Day of month>, <Year>, e.g. Feb 24, 2020.
    • itemDescriptions: An object with item types as keys and strings as values that will be displayed on the right side of the timeline. By default the following descriptions are used:
      {
        itemDescriptions: {
          'journal-publication': 'Published',
          'preprint-posted': 'Preprint',
          'response': 'Reply',
          'review-article': 'Review',
          'reviews': 'Peer Review',
        }
      }
    • publisherLogo: A callable that receives the name of a publisher and returns a URL to the icon that should be displayed next to the publisher's name, or a falsy value if no icon should be displayed. By default some publisher logos are included, e.g. for bioRxiv, EMBO Press journals, or eLife. Example:
      {
        publisherLogo: name => {
          const publisherLogosById = {
            'bioRxiv': 'https://www.biorxiv.org/sites/default/files/images/favicon.ico',
            'embo press': 'https://www.embopress.org/favicon.ico',
          }
          return publisherLogosById[name] || null;
        }
      }
    • publisherName: A callable that receives the name of a publisher and returns how it should be displayed. This publisher name is what's displayed on the left side of the timeline. The default is to return the received name unchanged for unknown publishers and use the correct capitalization for known publishers like bioRxiv, EMBO Press, etc. Can be used to e.g. correct capitalization or use abbreviations:
      {
        publisherName: name => {
          const publisherNamesById = {
            'elife': 'eLife',
            'embo journal': 'EMBOJ',
          }
          return publisherNamesById[name] || name;
        }
      }
    • renderMarkdown: A callable that takes a Markdown-formatted string and return an HTML representation of it. Is used to render the full text of reviews and replies. Uses the very small drawdown library by default. Other possibilites are e.g. marked or markdown-it:
      { renderMarkdown: marked.parse }
  • itemDate: Pass in the string "earliest" or "latest" to control which date is shown for an item in the timeline with multiple contents. Defaults to "latest".
  • highlightDoi: Automatically open the highlight viewer for the review or response with this DOI.
  • reportSummaryIssue: Pass in an object to configure how the "Report issue" button for the auto-summaries works:
    • recipient: The email address that should receive the issue reports. Defaults to eeb-feedback@embl.de.
    • subject: The subject line of the issue report. Defaults to Issue with auto-summary.
    • body: A callable that receives the URI of the preprint and the text of the auto-summary and returns the body of the issue report. Defaults to a function that returns an explanatory text.
      {
        reportSummaryIssue: {
          body: (uri, summary) => `There is an issue with the auto-summary for ${uri}:\n\n${summary}`
        }
      }

Styling

The component uses CSS custom properties to enable custom styling of some aspects of the rendered review process. Set the properties on the custom element or one of its ancestors to override the default values.

These are the available options:

  • --rr-timeline-width: The width of the timeline. Defaults to 500px.

  • --rr-timeline-line-color: The color of the line that connects the timeline items. Defaults to grey.

  • --rr-timeline-text-color: The color of the text in the timeline (publisher names, dates). Defaults to grey.

  • --rr-preprint-bg-color: The background color of the preprint items in the timeline. Defaults to #accbd2.

  • --rr-preprint-text-color: The text color of the preprint items in the timeline. Defaults to #056277.

  • --rr-reviews-bg-color: The background color of the reviews items in the timeline. Defaults to #5796a4.

  • --rr-reviews-text-color: The text color of the reviews items in the timeline. Defaults to ivory.

  • --rr-published-bg-color: The background color of the published items in the timeline. Defaults to #056277.

  • --rr-published-text-color: The text color of the published items in the timeline. Defaults to ivory.

  • --rr-highlight-max-width: The maximum width of the highlight viewer. Defaults to 860px.

  • --rr-highlight-height: The height of the highlight viewer. Defaults to 94vh.
  • --rr-highlight-margin: The margin of the highlight viewer. Defaults to 3vh auto.

  • --rr-highlight-nav-bg-color: The background color of the navigation bar in the highlight viewer. Defaults to the background color of the reviews items.

  • --rr-highlight-nav-text-color: The text color of the navigation bar in the highlight viewer. Defaults to the text color of the reviews items.

  • --rr-timeline-summary-bg-color: The background color of the automated summary in the timeline. Defaults to #eee.

  • --rr-timeline-summary-text-color: The text color of the automated summary in the timeline. Defaults to grey.

Sub-components

The <render-rev> element is composed of several sub-components that can be used individually to customize the display of the review process.

<render-rev-timeline> and <render-rev-timeline-horizontal>

The <render-rev-timeline> element displays the review process as a vertical timeline with the preprint at the top and the published article at the bottom. The <render-rev-timeline-horizontal> element displays the review process as a horizontal timeline with the preprint on the left and the published article on the right.

Both elements accept the attributes of the display configuration option described above to customize the display of the timeline. They can be styled using the CSS custom properties described above.

import { parseDocmaps, RenderRevTimeline, RenderRevTimelineHorizontal } from '@source-data/render-rev';
const docmaps = fetch('https://eeb.embo.org/api/v2/docmap/10.1101/2022.02.25.481813')
  .then(response => response.json())
  .then(parseDocmaps)
  .then(reviewProcess => {
    const timeline = new RenderRevTimeline();
    timeline.reviewProcess = reviewProcess;
    timeline.options = {
      publisherName: name => name.toUpperCase(),
    };
    document.body.appendChild(timeline);

    const timelineHorizontal = new RenderRevTimelineHorizontal();
    timelineHorizontal.reviewProcess = reviewProcess;
    timelineHorizontal.options = {
      formatDate: date => date.toLocaleDateString('en-US', { month: 'short', day: 'numeric', year: 'numeric' }),
    };
    document.body.appendChild(timelineHorizontal);
  });

parseDocmaps

The async parseDocmaps function takes an array of DocMaps and returns a ReviewProcess object that can be passed to the reviewProcess property of the timeline elements described above.

Development

The project is scaffolded with Open Web Components and built with Lit.

Linting and formatting

To scan the project for linting and formatting errors, run

npm run lint

To automatically fix linting and formatting errors, run

npm run format

Testing with Web Test Runner

To execute a single test run:

npm run test

To run the tests in interactive watch mode run:

npm run test:watch

Tooling configs

For most of the tools, the configuration is in the package.json to minimize the amount of files in the project.

Local Demo with web-dev-server

npm start

To run a local development server that serves the basic demo located in demo/index.html

0.2.7

3 months ago

0.2.6

3 months ago

0.2.5

4 months ago

0.2.4

4 months ago

0.2.3

5 months ago

0.2.2

5 months ago

0.2.1

5 months ago

0.2.0

5 months ago

0.1.35

6 months ago

0.1.30

1 year ago

0.1.31

12 months ago

0.1.32

12 months ago

0.1.33

12 months ago

0.1.34

12 months ago

0.1.27

1 year ago

0.1.28

1 year ago

0.1.29

1 year ago

0.1.25

1 year ago

0.1.26

1 year ago

0.1.23

1 year ago

0.1.24

1 year ago

0.1.22

1 year ago

0.1.10

2 years ago

0.1.11

2 years ago

0.1.12

2 years ago

0.1.13

2 years ago

0.1.14

2 years ago

0.1.15

1 year ago

0.1.20

1 year ago

0.1.21

1 year ago

0.1.16

1 year ago

0.1.8

2 years ago

0.1.17

1 year ago

0.1.7

2 years ago

0.1.18

1 year ago

0.1.19

1 year ago

0.1.9

2 years ago

0.1.4

2 years ago

0.1.6

2 years ago

0.1.5

2 years ago

0.1.3

2 years ago

0.1.2

2 years ago

0.1.1

2 years ago

0.1.0

2 years ago

0.0.0

2 years ago