summaryrefslogtreecommitdiffstats
path: root/devtools/client/netmonitor/src/components/messages/MessageListItem.js
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--devtools/client/netmonitor/src/components/messages/MessageListItem.js127
1 files changed, 127 insertions, 0 deletions
diff --git a/devtools/client/netmonitor/src/components/messages/MessageListItem.js b/devtools/client/netmonitor/src/components/messages/MessageListItem.js
new file mode 100644
index 0000000000..a5d837a31b
--- /dev/null
+++ b/devtools/client/netmonitor/src/components/messages/MessageListItem.js
@@ -0,0 +1,127 @@
+/* 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 {
+ Component,
+ createFactory,
+} = require("resource://devtools/client/shared/vendor/react.js");
+const dom = require("resource://devtools/client/shared/vendor/react-dom-factories.js");
+const PropTypes = require("resource://devtools/client/shared/vendor/react-prop-types.js");
+
+loader.lazyGetter(this, "ColumnData", function () {
+ return createFactory(
+ require("resource://devtools/client/netmonitor/src/components/messages/ColumnData.js")
+ );
+});
+loader.lazyGetter(this, "ColumnEventName", function () {
+ return createFactory(
+ require("resource://devtools/client/netmonitor/src/components/messages/ColumnEventName.js")
+ );
+});
+loader.lazyGetter(this, "ColumnFinBit", function () {
+ return createFactory(
+ require("resource://devtools/client/netmonitor/src/components/messages/ColumnFinBit.js")
+ );
+});
+loader.lazyGetter(this, "ColumnLastEventId", function () {
+ return createFactory(
+ require("resource://devtools/client/netmonitor/src/components/messages/ColumnLastEventId.js")
+ );
+});
+loader.lazyGetter(this, "ColumnMaskBit", function () {
+ return createFactory(
+ require("resource://devtools/client/netmonitor/src/components/messages/ColumnMaskBit.js")
+ );
+});
+loader.lazyGetter(this, "ColumnOpCode", function () {
+ return createFactory(
+ require("resource://devtools/client/netmonitor/src/components/messages/ColumnOpCode.js")
+ );
+});
+loader.lazyGetter(this, "ColumnRetry", function () {
+ return createFactory(
+ require("resource://devtools/client/netmonitor/src/components/messages/ColumnRetry.js")
+ );
+});
+loader.lazyGetter(this, "ColumnSize", function () {
+ return createFactory(
+ require("resource://devtools/client/netmonitor/src/components/messages/ColumnSize.js")
+ );
+});
+loader.lazyGetter(this, "ColumnTime", function () {
+ return createFactory(
+ require("resource://devtools/client/netmonitor/src/components/messages/ColumnTime.js")
+ );
+});
+
+const COLUMN_COMPONENT_MAP = {
+ data: ColumnData,
+ eventName: ColumnEventName,
+ finBit: ColumnFinBit,
+ lastEventId: ColumnLastEventId,
+ maskBit: ColumnMaskBit,
+ opCode: ColumnOpCode,
+ retry: ColumnRetry,
+ size: ColumnSize,
+ time: ColumnTime,
+};
+
+/**
+ * Renders one row in the list.
+ */
+class MessageListItem extends Component {
+ static get propTypes() {
+ return {
+ item: PropTypes.object.isRequired,
+ index: PropTypes.number.isRequired,
+ isSelected: PropTypes.bool.isRequired,
+ onMouseDown: PropTypes.func.isRequired,
+ onContextMenu: PropTypes.func.isRequired,
+ connector: PropTypes.object.isRequired,
+ visibleColumns: PropTypes.array.isRequired,
+ };
+ }
+
+ render() {
+ const {
+ item,
+ index,
+ isSelected,
+ onMouseDown,
+ onContextMenu,
+ connector,
+ visibleColumns,
+ } = this.props;
+
+ const classList = [
+ "message-list-item",
+ index % 2 ? "odd" : "even",
+ item.type,
+ ];
+ if (isSelected) {
+ classList.push("selected");
+ }
+
+ return dom.tr(
+ {
+ className: classList.join(" "),
+ tabIndex: 0,
+ onMouseDown,
+ onContextMenu,
+ },
+ visibleColumns.map(name => {
+ const ColumnComponent = COLUMN_COMPONENT_MAP[name];
+ return ColumnComponent({
+ key: `message-list-column-${name}-${index}`,
+ connector,
+ item,
+ });
+ })
+ );
+ }
+}
+
+module.exports = MessageListItem;