@gechiui/block-editor
Version:
70 lines (54 loc) • 1.86 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.BlockIcon = BlockIcon;
exports.default = void 0;
var _element = require("@gechiui/element");
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _reactNative = require("react-native");
var _components = require("@gechiui/components");
var _icons = require("@gechiui/icons");
var _compose = require("@gechiui/compose");
var _style = _interopRequireDefault(require("./style.scss"));
/**
* External dependencies
*/
/**
* GeChiUI dependencies
*/
/**
* Internal dependencies
*/
function BlockIcon(_ref) {
var _icon, _usePreferredColorSch, _icon2;
let {
icon,
fill,
size,
showColors = false
} = _ref;
if (((_icon = icon) === null || _icon === void 0 ? void 0 : _icon.src) === 'block-default') {
icon = {
src: _icons.blockDefault
};
}
const defaultFill = (_usePreferredColorSch = (0, _compose.usePreferredColorSchemeStyle)(_style.default.iconPlaceholder, _style.default.iconPlaceholderDark)) === null || _usePreferredColorSch === void 0 ? void 0 : _usePreferredColorSch.fill;
const iconForeground = showColors ? (_icon2 = icon) === null || _icon2 === void 0 ? void 0 : _icon2.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