/* 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;