@wordpress/compose
Version:
WordPress higher-order components (HOCs).
41 lines (33 loc) • 1.36 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 _createHigherOrderComponent = _interopRequireDefault(require("../../utils/create-higher-order-component"));
var _usePreferredColorScheme = _interopRequireDefault(require("../../hooks/use-preferred-color-scheme"));
/**
* Internal dependencies
*/
/**
* WordPress dependencies
*/
const withPreferredColorScheme = (0, _createHigherOrderComponent.default)(WrappedComponent => props => {
const colorScheme = (0, _usePreferredColorScheme.default)();
const isDarkMode = colorScheme === 'dark';
const getStyles = (0, _element.useCallback)((lightStyles, darkStyles) => {
const finalDarkStyles = { ...lightStyles,
...darkStyles
};
return isDarkMode ? finalDarkStyles : lightStyles;
}, [isDarkMode]);
return (0, _element.createElement)(WrappedComponent, (0, _extends2.default)({
preferredColorScheme: colorScheme,
getStylesFromColorScheme: getStyles
}, props));
}, 'withPreferredColorScheme');
var _default = withPreferredColorScheme;
exports.default = _default;
//# sourceMappingURL=index.native.js.map