summaryrefslogtreecommitdiffstats
path: root/devtools/client/performance/components/recording-button.js
diff options
context:
space:
mode:
Diffstat (limited to 'devtools/client/performance/components/recording-button.js')
-rw-r--r--devtools/client/performance/components/recording-button.js37
1 files changed, 37 insertions, 0 deletions
diff --git a/devtools/client/performance/components/recording-button.js b/devtools/client/performance/components/recording-button.js
new file mode 100644
index 000000000..877fd0e2b
--- /dev/null
+++ b/devtools/client/performance/components/recording-button.js
@@ -0,0 +1,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 {L10N} = require("devtools/client/performance/modules/global");
+const {DOM, createClass} = require("devtools/client/shared/vendor/react");
+const {button} = DOM;
+
+module.exports = createClass({
+ displayName: "Recording Button",
+
+ render() {
+ let {
+ onRecordButtonClick,
+ isRecording,
+ isLocked
+ } = this.props;
+
+ let classList = ["devtools-button", "record-button"];
+
+ if (isRecording) {
+ classList.push("checked");
+ }
+
+ return button(
+ {
+ className: classList.join(" "),
+ onClick: onRecordButtonClick,
+ "data-standalone": "true",
+ "data-text-only": "true",
+ disabled: isLocked
+ },
+ isRecording ? L10N.getStr("recordings.stop") : L10N.getStr("recordings.start")
+ );
+ }
+});