@wener/ui
Version:
45 lines • 2.06 kB
JavaScript
;
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
Object.defineProperty(o, "default", { enumerable: true, value: v });
}) : function(o, v) {
o["default"] = v;
});
var __importStar = (this && this.__importStar) || function (mod) {
if (mod && mod.__esModule) return mod;
var result = {};
if (mod != null) for (var k in mod) if (k !== "default" && Object.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
__setModuleDefault(result, mod);
return result;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.useNamedTheme = exports.NamedThemeProvider = void 0;
const react_1 = __importStar(require("react"));
const rxjs_1 = require("rxjs");
const useConstant_1 = require("./useConstant");
const NamedThemeContext = react_1.default.createContext(new rxjs_1.BehaviorSubject(null));
function NamedThemeProvider({ children, initialTheme }) {
const state = useConstant_1.useConstant(() => new rxjs_1.BehaviorSubject(typeof initialTheme === 'function' ? initialTheme() : initialTheme));
react_1.useEffect(() => {
return () => state.complete();
}, []);
return react_1.default.createElement(NamedThemeContext.Provider, { value: state }, children);
}
exports.NamedThemeProvider = NamedThemeProvider;
function useNamedTheme() {
const state = react_1.useContext(NamedThemeContext);
const [theme, setTheme] = react_1.useState(state.value);
react_1.useEffect(() => {
const subscribe = state.subscribe(setTheme);
return subscribe.unsubscribe.bind(subscribe);
}, [state]);
return [theme, (v) => state.next(v)];
}
exports.useNamedTheme = useNamedTheme;
//# sourceMappingURL=useNamedTheme.js.map