summaryrefslogtreecommitdiffstats
path: root/devtools/client/webconsole/new-console-output/components/message-repeat.js
blob: 1820340ea3cc06a772b0d8e378d5ff0025a38c55 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36

/* -*- indent-tabs-mode: nil; js-indent-level: 2 -*- */
/* vim: set ft=javascript ts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
 * License, v. 2.0. If a copy of the MPL was not distributed with this
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */

"use strict";

// React & Redux
const {
  DOM: dom,
  PropTypes
} = require("devtools/client/shared/vendor/react");
const { PluralForm } = require("devtools/shared/plural-form");
const { l10n } = require("devtools/client/webconsole/new-console-output/utils/messages");

MessageRepeat.displayName = "MessageRepeat";

MessageRepeat.propTypes = {
  repeat: PropTypes.number.isRequired
};

function MessageRepeat(props) {
  const { repeat } = props;
  const visibility = repeat > 1 ? "visible" : "hidden";

  return dom.span({
    className: "message-repeats",
    style: {visibility},
    title: PluralForm.get(repeat, l10n.getStr("messageRepeats.tooltip2"))
      .replace("#1", repeat)
  }, repeat);
}

module.exports = MessageRepeat;