@atlaskit/icon
Version:
An icon is a symbol representing a command, device, directory, or common action.
67 lines (64 loc) • 3.75 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.IconFacade = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _react = _interopRequireWildcard(require("react"));
var _platformFeatureFlags = require("@atlaskit/platform-feature-flags");
var _icon = require("./icon");
var _excluded = ["dangerouslySetGlyph"];
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
var sizeSpacingMap = {
utility: {
small: 'compact',
medium: 'spacious'
},
core: {
small: 'none',
medium: 'spacious'
}
};
/**
* `IconFacade` is a component that conditionally renders either a new or legacy icon based on a feature flag.
*
* @param {IconFacadeProps} props - The props for the IconFacade component. Includes properties for configuring
* the icon such as `size`, `spacing`, `primaryColor`, `iconType`, and potentially others depending on the icon.
* `dangerouslySetGlyph` is a prop specific to the legacy icon component for setting the icon glyph directly.
* @returns A React element representing either the new or legacy icon based on the feature flag and icon size.
*/
var IconFacade = exports.IconFacade = /*#__PURE__*/(0, _react.memo)(function IconFacade(_ref) {
var _props$size;
var dangerouslySetGlyph = _ref.dangerouslySetGlyph,
props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
var NewIcon = props.newIcon;
// By default, the icon size will be medium for core icons and small for utility icons
var size = (_props$size = props.size) !== null && _props$size !== void 0 ? _props$size : 'medium';
var useNewIcon = !props.isFacadeDisabled &&
// eslint-disable-next-line @atlaskit/platform/ensure-feature-flag-prefix
(0, _platformFeatureFlags.fg)('platform-visual-refresh-icons-legacy-facade');
if (useNewIcon && NewIcon && (size === 'small' || size === 'medium')) {
if (props.iconType === 'utility') {
var Icon = NewIcon;
return /*#__PURE__*/_react.default.createElement(Icon, (0, _extends2.default)({}, props, {
spacing: (0, _platformFeatureFlags.fg)('platform-visual-refresh-icons-facade-button-fix') ? sizeSpacingMap['utility'][size] : 'none',
color: props.primaryColor || 'currentColor',
type: props.iconType
}));
} else {
var _Icon = NewIcon;
return /*#__PURE__*/_react.default.createElement(_Icon, (0, _extends2.default)({}, props, {
spacing: sizeSpacingMap['core'][size],
color: props.primaryColor || 'currentColor',
type: props.iconType
}));
}
}
return /*#__PURE__*/_react.default.createElement(_icon.Icon, (0, _extends2.default)({
dangerouslySetGlyph: dangerouslySetGlyph
}, props));
});