Source code
Revision control
Copy as Markdown
Other Tools
/* 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
"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;