@chakra-ui/react
Version:
Responsive and accessible React UI components built with React and Emotion
37 lines (33 loc) • 923 B
JavaScript
"use client";
;
var React = require('react');
function getErrorMessage(hook, provider) {
return `${hook} returned \`undefined\`. Seems you forgot to wrap component within ${provider}`;
}
function createContext(options = {}) {
const {
name,
strict = true,
hookName = "useContext",
providerName = "Provider",
errorMessage,
defaultValue
} = options;
const Context = React.createContext(defaultValue);
Context.displayName = name;
function useContext() {
const context = React.useContext(Context);
if (!context && strict) {
const error = new Error(
errorMessage ?? getErrorMessage(hookName, providerName)
);
error.name = "ContextError";
Error.captureStackTrace?.(error, useContext);
throw error;
}
return context;
}
return [Context.Provider, useContext, Context];
}
exports.createContext = createContext;
;