summaryrefslogtreecommitdiffstats
path: root/devtools/client/webconsole/components/FilterBar/FilterButton.js
blob: 2a2ad6bf70f8e24c56bf0b21e7ce5f4a1db8e965 (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
37
/* 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";

const PropTypes = require("resource://devtools/client/shared/vendor/react-prop-types.js");
const dom = require("resource://devtools/client/shared/vendor/react-dom-factories.js");
const actions = require("resource://devtools/client/webconsole/actions/index.js");

FilterButton.displayName = "FilterButton";

FilterButton.propTypes = {
  label: PropTypes.string.isRequired,
  filterKey: PropTypes.string.isRequired,
  active: PropTypes.bool.isRequired,
  dispatch: PropTypes.func.isRequired,
  title: PropTypes.string,
};

function FilterButton(props) {
  const { active, label, filterKey, dispatch, title } = props;

  return dom.button(
    {
      "aria-pressed": active === true,
      className: "devtools-togglebutton",
      "data-category": filterKey,
      title,
      onClick: () => {
        dispatch(actions.filterToggle(filterKey));
      },
    },
    label
  );
}

module.exports = FilterButton;