UNPKG

@wordpress/block-editor

Version:
66 lines (52 loc) 1.58 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.BlockIcon = BlockIcon; exports.default = void 0; var _element = require("@wordpress/element"); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _reactNative = require("react-native"); var _components = require("@wordpress/components"); var _icons = require("@wordpress/icons"); var _compose = require("@wordpress/compose"); var _style = _interopRequireDefault(require("./style.scss")); /** * External dependencies */ /** * WordPress dependencies */ /** * Internal dependencies */ function BlockIcon({ icon, fill, size, showColors = false }) { if (icon?.src === 'block-default') { icon = { src: _icons.blockDefault }; } const defaultFill = (0, _compose.usePreferredColorSchemeStyle)(_style.default.iconPlaceholder, _style.default.iconPlaceholderDark)?.fill; const iconForeground = showColors ? icon?.foreground : undefined; const renderedIcon = (0, _element.createElement)(_components.Icon, (0, _extends2.default)({ icon: icon && icon.src ? icon.src : icon, fill: fill || iconForeground || defaultFill }, size && { size })); const style = showColors ? { backgroundColor: icon && icon.background } : {}; return (0, _element.createElement)(_reactNative.View, { style: style }, renderedIcon); } var _default = BlockIcon; exports.default = _default; //# sourceMappingURL=index.native.js.map