context.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. var _typeof = require("@babel/runtime/helpers/typeof");
  4. Object.defineProperty(exports, "__esModule", {
  5. value: true
  6. });
  7. exports.createContext = createContext;
  8. exports.useContext = useContext;
  9. var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
  10. var _useEvent = _interopRequireDefault(require("rc-util/lib/hooks/useEvent"));
  11. var _useLayoutEffect = _interopRequireDefault(require("rc-util/lib/hooks/useLayoutEffect"));
  12. var _isEqual = _interopRequireDefault(require("rc-util/lib/isEqual"));
  13. var React = _interopRequireWildcard(require("react"));
  14. var _reactDom = require("react-dom");
  15. function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
  16. function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
  17. function createContext(defaultValue) {
  18. var Context = /*#__PURE__*/React.createContext(undefined);
  19. var Provider = function Provider(_ref) {
  20. var value = _ref.value,
  21. children = _ref.children;
  22. var valueRef = React.useRef(value);
  23. valueRef.current = value;
  24. var _React$useState = React.useState(function () {
  25. return {
  26. getValue: function getValue() {
  27. return valueRef.current;
  28. },
  29. listeners: new Set()
  30. };
  31. }),
  32. _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 1),
  33. context = _React$useState2[0];
  34. (0, _useLayoutEffect.default)(function () {
  35. (0, _reactDom.unstable_batchedUpdates)(function () {
  36. context.listeners.forEach(function (listener) {
  37. listener(value);
  38. });
  39. });
  40. }, [value]);
  41. return /*#__PURE__*/React.createElement(Context.Provider, {
  42. value: context
  43. }, children);
  44. };
  45. return {
  46. Context: Context,
  47. Provider: Provider,
  48. defaultValue: defaultValue
  49. };
  50. }
  51. /** e.g. useSelect(userContext) => user */
  52. /** e.g. useSelect(userContext, user => user.name) => user.name */
  53. /** e.g. useSelect(userContext, ['name', 'age']) => user { name, age } */
  54. /** e.g. useSelect(userContext, 'name') => user.name */
  55. function useContext(holder, selector) {
  56. var eventSelector = (0, _useEvent.default)(typeof selector === 'function' ? selector : function (ctx) {
  57. if (selector === undefined) {
  58. return ctx;
  59. }
  60. if (!Array.isArray(selector)) {
  61. return ctx[selector];
  62. }
  63. var obj = {};
  64. selector.forEach(function (key) {
  65. obj[key] = ctx[key];
  66. });
  67. return obj;
  68. });
  69. var context = React.useContext(holder === null || holder === void 0 ? void 0 : holder.Context);
  70. var _ref2 = context || {},
  71. listeners = _ref2.listeners,
  72. getValue = _ref2.getValue;
  73. var valueRef = React.useRef();
  74. valueRef.current = eventSelector(context ? getValue() : holder === null || holder === void 0 ? void 0 : holder.defaultValue);
  75. var _React$useState3 = React.useState({}),
  76. _React$useState4 = (0, _slicedToArray2.default)(_React$useState3, 2),
  77. forceUpdate = _React$useState4[1];
  78. (0, _useLayoutEffect.default)(function () {
  79. if (!context) {
  80. return;
  81. }
  82. function trigger(nextValue) {
  83. var nextSelectorValue = eventSelector(nextValue);
  84. if (!(0, _isEqual.default)(valueRef.current, nextSelectorValue, true)) {
  85. forceUpdate({});
  86. }
  87. }
  88. listeners.add(trigger);
  89. return function () {
  90. listeners.delete(trigger);
  91. };
  92. }, [context]);
  93. return valueRef.current;
  94. }