UNPKG

@wener/ui

Version:

45 lines 2.06 kB
"use strict"; 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