Mypal68/devtools/client/aboutdebugging/components/TargetList.js
2022-04-16 07:41:55 +03:00

84 lines
2.1 KiB
JavaScript

/* 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 } = require("devtools/client/shared/vendor/react");
const PropTypes = require("devtools/client/shared/vendor/react-prop-types");
const dom = require("devtools/client/shared/vendor/react-dom-factories");
const Services = require("Services");
loader.lazyRequireGetter(
this,
"DebuggerClient",
"devtools/shared/client/debugger-client",
true
);
const Strings = Services.strings.createBundle(
"chrome://devtools/locale/aboutdebugging.properties"
);
const LocaleCompare = (a, b) => {
return a.name.toLowerCase().localeCompare(b.name.toLowerCase());
};
class TargetList extends Component {
static get propTypes() {
return {
client: PropTypes.instanceOf(DebuggerClient).isRequired,
connect: PropTypes.object,
debugDisabled: PropTypes.bool,
error: PropTypes.node,
id: PropTypes.string.isRequired,
name: PropTypes.string,
sort: PropTypes.bool,
targetClass: PropTypes.func.isRequired,
targets: PropTypes.arrayOf(PropTypes.object).isRequired,
};
}
render() {
let {
client,
connect,
debugDisabled,
error,
targetClass,
targets,
sort,
} = this.props;
if (sort) {
targets = targets.sort(LocaleCompare);
}
targets = targets.map((target, index) => {
return targetClass({
key: target.addonID || target.url || index,
client,
connect,
target,
debugDisabled,
});
});
let content = "";
if (error) {
content = error;
} else if (targets.length > 0) {
content = dom.ul({ className: "target-list" }, targets);
} else {
content = dom.p(null, Strings.GetStringFromName("nothing"));
}
return dom.div(
{ id: this.props.id, className: "targets" },
dom.h2(null, this.props.name),
content
);
}
}
module.exports = TargetList;