@wordpress/components
Version:
UI components for WordPress.
57 lines (45 loc) • 1.66 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var _element = require("@wordpress/element");
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _classnames = _interopRequireDefault(require("classnames"));
var _lodash = require("lodash");
var _ = _interopRequireDefault(require("./"));
/**
* External dependencies
*/
/**
* Internal dependencies
*/
/**
* Renders a list of notices.
*
* @param {Object} $0 Props passed to the component.
* @param {Array} $0.notices Array of notices to render.
* @param {Function} $0.onRemove Function called when a notice should be removed / dismissed.
* @param {Object} $0.className Name of the class used by the component.
* @param {Object} $0.children Array of children to be rendered inside the notice list.
* @return {Object} The rendered notices list.
*/
function NoticeList({
notices,
onRemove = _lodash.noop,
className,
children
}) {
const removeNotice = id => () => onRemove(id);
className = (0, _classnames.default)('components-notice-list', className);
return (0, _element.createElement)("div", {
className: className
}, children, [...notices].reverse().map(notice => (0, _element.createElement)(_.default, (0, _extends2.default)({}, (0, _lodash.omit)(notice, ['content']), {
key: notice.id,
onRemove: removeNotice(notice.id)
}), notice.content)));
}
var _default = NoticeList;
exports.default = _default;
//# sourceMappingURL=list.js.map