UNPKG

@blueprintjs/core

Version:

Core styles & components

47 lines 1.98 kB
"use strict"; /* * Copyright 2024 Palantir Technologies, Inc. All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ Object.defineProperty(exports, "__esModule", { value: true }); exports.OverlaysProvider = exports.OverlaysContext = void 0; var tslib_1 = require("tslib"); var React = tslib_1.__importStar(require("react")); /** * A React context used to interact with the overlay stack in an application. * Users should take care to make sure that only _one_ of these is instantiated and used within an * application. * * You will likely not be using this OverlaysContext directly, it's mostly used internally by the * Overlay2 component. * * For more information, see the [OverlaysProvider documentation](https://blueprintjs.com/docs/#core/context/overlays-provider). */ exports.OverlaysContext = React.createContext({ hasProvider: false, stack: { current: [] }, }); /** * Overlays context provider, necessary for the `useOverlayStack` hook. * * @see https://blueprintjs.com/docs/#core/context/overlays-provider */ var OverlaysProvider = function (_a) { var children = _a.children; var stack = React.useRef([]); var contextValue = React.useMemo(function () { return ({ hasProvider: true, stack: stack }); }, [stack]); return React.createElement(exports.OverlaysContext.Provider, { value: contextValue }, children); }; exports.OverlaysProvider = OverlaysProvider; //# sourceMappingURL=overlaysProvider.js.map