@civet/events 1.0.2 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +2 -2
- package/lib/ConfigProvider.js +3 -5
- package/lib/EventHandler.js +2 -4
- package/lib/EventReceiver.js +7 -12
- package/lib/composeHandlers.js +1 -2
- package/lib/context.js +5 -8
- package/lib/index.js +5 -6
- package/lib/useEventHandler.js +19 -12
- package/package.json +30 -26
- package/src/{ConfigProvider.js → ConfigProvider.jsx} +1 -3
- package/src/{EventHandler.js → EventHandler.jsx} +0 -2
- package/src/EventReceiver.js +0 -1
- package/src/context.js +3 -3
- package/src/index.js +1 -1
- package/src/useEventHandler.js +13 -7
package/LICENSE
CHANGED
package/lib/ConfigProvider.js
CHANGED
|
@@ -5,14 +5,13 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
});
|
|
6
6
|
exports["default"] = void 0;
|
|
7
7
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
8
|
-
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
var _context = require("./context");
|
|
10
8
|
var _EventReceiver = require("./EventReceiver");
|
|
9
|
+
var _context = require("./context");
|
|
11
10
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
12
11
|
var ConfigProvider = function ConfigProvider(_ref) {
|
|
13
12
|
var eventReceiver = _ref.eventReceiver,
|
|
14
13
|
children = _ref.children;
|
|
15
|
-
return /*#__PURE__*/
|
|
14
|
+
return /*#__PURE__*/React.createElement(_context.ConfigContext.Provider, {
|
|
16
15
|
value: {
|
|
17
16
|
eventReceiver: eventReceiver
|
|
18
17
|
}
|
|
@@ -22,5 +21,4 @@ ConfigProvider.propTypes = {
|
|
|
22
21
|
eventReceiver: _EventReceiver.eventReceiverPropType,
|
|
23
22
|
children: _propTypes["default"].node
|
|
24
23
|
};
|
|
25
|
-
var _default = ConfigProvider;
|
|
26
|
-
exports["default"] = _default;
|
|
24
|
+
var _default = exports["default"] = ConfigProvider;
|
package/lib/EventHandler.js
CHANGED
|
@@ -5,7 +5,6 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
});
|
|
6
6
|
exports["default"] = void 0;
|
|
7
7
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
8
|
-
var _react = _interopRequireDefault(require("react"));
|
|
9
8
|
var _EventReceiver = require("./EventReceiver");
|
|
10
9
|
var _useEventHandler = _interopRequireDefault(require("./useEventHandler"));
|
|
11
10
|
var _excluded = ["children"];
|
|
@@ -16,7 +15,7 @@ function EventHandler(_ref) {
|
|
|
16
15
|
var children = _ref.children,
|
|
17
16
|
props = _objectWithoutProperties(_ref, _excluded);
|
|
18
17
|
(0, _useEventHandler["default"])(props);
|
|
19
|
-
return /*#__PURE__*/
|
|
18
|
+
return /*#__PURE__*/React.createElement(React.Fragment, null, children);
|
|
20
19
|
}
|
|
21
20
|
EventHandler.propTypes = {
|
|
22
21
|
eventReceiver: _EventReceiver.eventReceiverPropType,
|
|
@@ -27,5 +26,4 @@ EventHandler.propTypes = {
|
|
|
27
26
|
onNotify: _propTypes["default"].func,
|
|
28
27
|
children: _propTypes["default"].node
|
|
29
28
|
};
|
|
30
|
-
var _default = EventHandler;
|
|
31
|
-
exports["default"] = _default;
|
|
29
|
+
var _default = exports["default"] = EventHandler;
|
package/lib/EventReceiver.js
CHANGED
|
@@ -6,35 +6,30 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.isEventReceiver = exports.eventReceiverPropType = exports["default"] = void 0;
|
|
7
7
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
8
8
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
9
|
-
function _typeof(
|
|
9
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
10
10
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
|
11
11
|
function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, _toPropertyKey(descriptor.key), descriptor); } }
|
|
12
12
|
function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); Object.defineProperty(Constructor, "prototype", { writable: false }); return Constructor; }
|
|
13
|
-
function _toPropertyKey(
|
|
14
|
-
function _toPrimitive(
|
|
13
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
|
|
14
|
+
function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
15
15
|
var EventReceiver = /*#__PURE__*/function () {
|
|
16
16
|
function EventReceiver() {
|
|
17
17
|
_classCallCheck(this, EventReceiver);
|
|
18
18
|
}
|
|
19
|
-
_createClass(EventReceiver, [{
|
|
19
|
+
return _createClass(EventReceiver, [{
|
|
20
20
|
key: "subscribe",
|
|
21
21
|
value: function subscribe(resource, options, handler) {
|
|
22
22
|
if (typeof handler !== 'function') throw new Error('Handler must be a function');
|
|
23
23
|
var unsubscribe = this.handleSubscribe(resource, options, handler);
|
|
24
24
|
if (typeof unsubscribe !== 'function') {
|
|
25
|
-
// eslint-disable-next-line no-console
|
|
26
25
|
console.warn('EventReceiver.handleSubscribe should return a callback to cancel the subscription. Ignoring this warning may result in the execution of obsolete handlers and potential memory leaks.');
|
|
27
26
|
}
|
|
28
27
|
return unsubscribe;
|
|
29
28
|
}
|
|
30
29
|
}]);
|
|
31
|
-
return EventReceiver;
|
|
32
30
|
}();
|
|
33
|
-
var isEventReceiver = function isEventReceiver(eventReceiver) {
|
|
31
|
+
var isEventReceiver = exports.isEventReceiver = function isEventReceiver(eventReceiver) {
|
|
34
32
|
return eventReceiver instanceof EventReceiver;
|
|
35
33
|
};
|
|
36
|
-
exports.
|
|
37
|
-
var
|
|
38
|
-
exports.eventReceiverPropType = eventReceiverPropType;
|
|
39
|
-
var _default = EventReceiver;
|
|
40
|
-
exports["default"] = _default;
|
|
34
|
+
var eventReceiverPropType = exports.eventReceiverPropType = _propTypes["default"].instanceOf(EventReceiver);
|
|
35
|
+
var _default = exports["default"] = EventReceiver;
|
package/lib/composeHandlers.js
CHANGED
package/lib/context.js
CHANGED
|
@@ -4,12 +4,9 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.useConfigContext = exports.ConfigContext = void 0;
|
|
7
|
-
var _react =
|
|
8
|
-
|
|
9
|
-
var ConfigContext = /*#__PURE__*/_react["default"].createContext({});
|
|
10
|
-
exports.ConfigContext = ConfigContext;
|
|
7
|
+
var _react = require("react");
|
|
8
|
+
var ConfigContext = exports.ConfigContext = /*#__PURE__*/(0, _react.createContext)({});
|
|
11
9
|
ConfigContext.displayName = 'Events.ConfigContext';
|
|
12
|
-
var useConfigContext = function useConfigContext() {
|
|
13
|
-
return _react
|
|
14
|
-
};
|
|
15
|
-
exports.useConfigContext = useConfigContext;
|
|
10
|
+
var useConfigContext = exports.useConfigContext = function useConfigContext() {
|
|
11
|
+
return (0, _react.useContext)(ConfigContext);
|
|
12
|
+
};
|
package/lib/index.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
function _typeof(
|
|
3
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
4
4
|
Object.defineProperty(exports, "__esModule", {
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
@@ -54,13 +54,12 @@ Object.defineProperty(exports, "useEventHandler", {
|
|
|
54
54
|
}
|
|
55
55
|
});
|
|
56
56
|
var _context = require("./context");
|
|
57
|
-
var _composeHandlers = _interopRequireDefault(require("./composeHandlers"));
|
|
58
57
|
var _ConfigProvider = _interopRequireDefault(require("./ConfigProvider"));
|
|
59
58
|
var _EventHandler = _interopRequireDefault(require("./EventHandler"));
|
|
60
59
|
var _EventReceiver = _interopRequireWildcard(require("./EventReceiver"));
|
|
60
|
+
var _composeHandlers = _interopRequireDefault(require("./composeHandlers"));
|
|
61
61
|
var _useEventHandler = _interopRequireDefault(require("./useEventHandler"));
|
|
62
|
-
function _getRequireWildcardCache(
|
|
63
|
-
function _interopRequireWildcard(
|
|
62
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(e) { return e ? t : r; })(e); }
|
|
63
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != _typeof(e) && "function" != typeof e) return { "default": e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n["default"] = e, t && t.set(e, n), n; }
|
|
64
64
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
65
|
-
var ConfigConsumer = _context.ConfigContext.Consumer;
|
|
66
|
-
exports.ConfigConsumer = ConfigConsumer;
|
|
65
|
+
var ConfigConsumer = exports.ConfigConsumer = _context.ConfigContext.Consumer;
|
package/lib/useEventHandler.js
CHANGED
|
@@ -6,14 +6,14 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports["default"] = void 0;
|
|
7
7
|
var _core = require("@civet/core");
|
|
8
8
|
var _fastDeepEqual = _interopRequireDefault(require("fast-deep-equal"));
|
|
9
|
-
var _react =
|
|
9
|
+
var _react = require("react");
|
|
10
10
|
var _context = require("./context");
|
|
11
11
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
|
12
12
|
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
13
13
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
14
14
|
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
15
15
|
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i]; return arr2; }
|
|
16
|
-
function _iterableToArrayLimit(
|
|
16
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
17
17
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
18
18
|
function useEventHandler(_ref) {
|
|
19
19
|
var eventReceiverProp = _ref.eventReceiver,
|
|
@@ -25,16 +25,24 @@ function useEventHandler(_ref) {
|
|
|
25
25
|
var configContext = (0, _context.useConfigContext)();
|
|
26
26
|
var eventReceiver = eventReceiverProp || configContext.eventReceiver;
|
|
27
27
|
var resourceContext = (0, _core.useResourceContext)();
|
|
28
|
-
var
|
|
29
|
-
var
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
28
|
+
var currentResource = resourceProp || resourceContext;
|
|
29
|
+
var _useState = (0, _react.useState)(currentResource),
|
|
30
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
31
|
+
resource = _useState2[0],
|
|
32
|
+
setResource = _useState2[1];
|
|
33
|
+
if ((currentResource === null || currentResource === void 0 ? void 0 : currentResource.request) !== (resource === null || resource === void 0 ? void 0 : resource.request)) {
|
|
34
|
+
setResource(currentResource);
|
|
35
|
+
}
|
|
36
|
+
var _useState3 = (0, _react.useState)(optionsProp),
|
|
37
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
38
|
+
options = _useState4[0],
|
|
39
|
+
setOptions = _useState4[1];
|
|
33
40
|
if (!(0, _fastDeepEqual["default"])(options, optionsProp)) {
|
|
34
41
|
setOptions(optionsProp);
|
|
35
42
|
}
|
|
36
|
-
|
|
37
|
-
|
|
43
|
+
var isDisabled = !!disabled;
|
|
44
|
+
(0, _react.useEffect)(function () {
|
|
45
|
+
if (eventReceiver == null || isDisabled) return undefined;
|
|
38
46
|
var unsubscribe = eventReceiver.subscribe(resource, options, function (data) {
|
|
39
47
|
if (((data === null || data === void 0 ? void 0 : data.length) || 0) === 0) return;
|
|
40
48
|
var unhandledEvents;
|
|
@@ -54,7 +62,6 @@ function useEventHandler(_ref) {
|
|
|
54
62
|
}
|
|
55
63
|
});
|
|
56
64
|
return unsubscribe;
|
|
57
|
-
}, [eventReceiver,
|
|
65
|
+
}, [eventReceiver, isDisabled, resource, options, onEvent, onNotify]);
|
|
58
66
|
}
|
|
59
|
-
var _default = useEventHandler;
|
|
60
|
-
exports["default"] = _default;
|
|
67
|
+
var _default = exports["default"] = useEventHandler;
|
package/package.json
CHANGED
|
@@ -1,22 +1,29 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@civet/events",
|
|
3
|
-
"version": "1.0
|
|
3
|
+
"version": "1.1.0",
|
|
4
4
|
"description": "Civet",
|
|
5
5
|
"main": "./lib/index.js",
|
|
6
|
+
"exports": {
|
|
7
|
+
".": {
|
|
8
|
+
"import": "./src/index.js",
|
|
9
|
+
"require": "./lib/index.js",
|
|
10
|
+
"default": "./lib/index.js"
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
"files": [
|
|
14
|
+
"lib",
|
|
15
|
+
"src"
|
|
16
|
+
],
|
|
6
17
|
"scripts": {
|
|
7
18
|
"build:clean": "rimraf ./lib",
|
|
8
19
|
"prebuild": "npm run build:clean",
|
|
9
|
-
"build": "
|
|
10
|
-
"lint": "eslint src",
|
|
20
|
+
"build": "babel src -d lib",
|
|
21
|
+
"lint": "eslint src --report-unused-disable-directives",
|
|
11
22
|
"prepare": "npm run lint && npm run build",
|
|
12
23
|
"preversion": "git diff HEAD --name-only --exit-code || (echo -\\> unclean working directory && exit 1)",
|
|
13
24
|
"postversion": "cross-env git commit -am$npm_package_version",
|
|
14
25
|
"prettify": "prettier --write src/**"
|
|
15
26
|
},
|
|
16
|
-
"files": [
|
|
17
|
-
"lib",
|
|
18
|
-
"src"
|
|
19
|
-
],
|
|
20
27
|
"repository": {
|
|
21
28
|
"type": "git",
|
|
22
29
|
"url": "git+https://github.com/civet-org/events.git"
|
|
@@ -34,32 +41,29 @@
|
|
|
34
41
|
},
|
|
35
42
|
"homepage": "https://civet.js.org/",
|
|
36
43
|
"devDependencies": {
|
|
37
|
-
"@babel/cli": "^7.
|
|
38
|
-
"@babel/core": "^7.
|
|
39
|
-
"@babel/
|
|
40
|
-
"@babel/preset-env": "^7.
|
|
44
|
+
"@babel/cli": "^7.22.15",
|
|
45
|
+
"@babel/core": "^7.24.4",
|
|
46
|
+
"@babel/eslint-parser": "^7.22.15",
|
|
47
|
+
"@babel/preset-env": "^7.24.4",
|
|
41
48
|
"@babel/preset-react": "^7.18.6",
|
|
42
|
-
"@civet/core": "^1.
|
|
43
|
-
"babel-eslint": "^10.1.0",
|
|
49
|
+
"@civet/core": "^1.3.0",
|
|
44
50
|
"cross-env": "^7.0.3",
|
|
45
|
-
"eslint": "^
|
|
46
|
-
"eslint-config-
|
|
47
|
-
"eslint-
|
|
48
|
-
"eslint-
|
|
49
|
-
"eslint-plugin-
|
|
50
|
-
"eslint-plugin-jsx-a11y": "^6.6.1",
|
|
51
|
-
"eslint-plugin-prettier": "^4.2.1",
|
|
52
|
-
"eslint-plugin-react": "^7.31.11",
|
|
51
|
+
"eslint": "^8.53.0",
|
|
52
|
+
"eslint-config-prettier": "^9.0.0",
|
|
53
|
+
"eslint-plugin-import": "^2.29.0",
|
|
54
|
+
"eslint-plugin-prettier": "^5.0.1",
|
|
55
|
+
"eslint-plugin-react": "^7.33.2",
|
|
53
56
|
"eslint-plugin-react-hooks": "^4.6.0",
|
|
54
|
-
"
|
|
57
|
+
"eslint-plugin-unused-imports": "^3.0.0",
|
|
58
|
+
"prettier": "^3.2.5",
|
|
55
59
|
"react": "^18.2.0",
|
|
56
60
|
"react-dom": "^18.2.0",
|
|
57
|
-
"rimraf": "^
|
|
61
|
+
"rimraf": "^5.0.5"
|
|
58
62
|
},
|
|
59
63
|
"peerDependencies": {
|
|
60
|
-
"@civet/core": ">=
|
|
61
|
-
"react": ">=
|
|
62
|
-
"react-dom": ">=
|
|
64
|
+
"@civet/core": ">=1.3.0",
|
|
65
|
+
"react": ">=18.0",
|
|
66
|
+
"react-dom": ">=18.0"
|
|
63
67
|
},
|
|
64
68
|
"dependencies": {
|
|
65
69
|
"fast-deep-equal": "^3.1.3",
|
|
@@ -1,8 +1,6 @@
|
|
|
1
1
|
import PropTypes from 'prop-types';
|
|
2
|
-
import React from 'react';
|
|
3
|
-
|
|
4
|
-
import { ConfigContext } from './context';
|
|
5
2
|
import { eventReceiverPropType } from './EventReceiver';
|
|
3
|
+
import { ConfigContext } from './context';
|
|
6
4
|
|
|
7
5
|
const ConfigProvider = ({ eventReceiver, children }) => (
|
|
8
6
|
<ConfigContext.Provider value={{ eventReceiver }}>{children}</ConfigContext.Provider>
|
package/src/EventReceiver.js
CHANGED
|
@@ -5,7 +5,6 @@ class EventReceiver {
|
|
|
5
5
|
if (typeof handler !== 'function') throw new Error('Handler must be a function');
|
|
6
6
|
const unsubscribe = this.handleSubscribe(resource, options, handler);
|
|
7
7
|
if (typeof unsubscribe !== 'function') {
|
|
8
|
-
// eslint-disable-next-line no-console
|
|
9
8
|
console.warn(
|
|
10
9
|
'EventReceiver.handleSubscribe should return a callback to cancel the subscription. Ignoring this warning may result in the execution of obsolete handlers and potential memory leaks.',
|
|
11
10
|
);
|
package/src/context.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { createContext, useContext } from 'react';
|
|
2
2
|
|
|
3
|
-
export const ConfigContext =
|
|
3
|
+
export const ConfigContext = createContext({});
|
|
4
4
|
ConfigContext.displayName = 'Events.ConfigContext';
|
|
5
|
-
export const useConfigContext = () =>
|
|
5
|
+
export const useConfigContext = () => useContext(ConfigContext);
|
package/src/index.js
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
import { ConfigContext, useConfigContext } from './context';
|
|
2
2
|
|
|
3
3
|
export const { Consumer: ConfigConsumer } = ConfigContext;
|
|
4
|
-
export { default as composeHandlers } from './composeHandlers';
|
|
5
4
|
export { default as ConfigProvider } from './ConfigProvider';
|
|
6
5
|
export { default as EventHandler } from './EventHandler';
|
|
7
6
|
export { default as EventReceiver, eventReceiverPropType, isEventReceiver } from './EventReceiver';
|
|
7
|
+
export { default as composeHandlers } from './composeHandlers';
|
|
8
8
|
export { default as useEventHandler } from './useEventHandler';
|
|
9
9
|
export { useConfigContext };
|
package/src/useEventHandler.js
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { useResourceContext } from '@civet/core';
|
|
2
2
|
import deepEquals from 'fast-deep-equal';
|
|
3
|
-
import
|
|
4
|
-
|
|
3
|
+
import { useEffect, useState } from 'react';
|
|
5
4
|
import { useConfigContext } from './context';
|
|
6
5
|
|
|
7
6
|
function useEventHandler({
|
|
@@ -16,15 +15,22 @@ function useEventHandler({
|
|
|
16
15
|
const eventReceiver = eventReceiverProp || configContext.eventReceiver;
|
|
17
16
|
|
|
18
17
|
const resourceContext = useResourceContext();
|
|
19
|
-
const
|
|
18
|
+
const currentResource = resourceProp || resourceContext;
|
|
19
|
+
|
|
20
|
+
const [resource, setResource] = useState(currentResource);
|
|
21
|
+
if (currentResource?.request !== resource?.request) {
|
|
22
|
+
setResource(currentResource);
|
|
23
|
+
}
|
|
20
24
|
|
|
21
|
-
const [options, setOptions] =
|
|
25
|
+
const [options, setOptions] = useState(optionsProp);
|
|
22
26
|
if (!deepEquals(options, optionsProp)) {
|
|
23
27
|
setOptions(optionsProp);
|
|
24
28
|
}
|
|
25
29
|
|
|
26
|
-
|
|
27
|
-
|
|
30
|
+
const isDisabled = !!disabled;
|
|
31
|
+
|
|
32
|
+
useEffect(() => {
|
|
33
|
+
if (eventReceiver == null || isDisabled) return undefined;
|
|
28
34
|
const unsubscribe = eventReceiver.subscribe(resource, options, (data) => {
|
|
29
35
|
if ((data?.length || 0) === 0) return;
|
|
30
36
|
let unhandledEvents;
|
|
@@ -40,7 +46,7 @@ function useEventHandler({
|
|
|
40
46
|
}
|
|
41
47
|
});
|
|
42
48
|
return unsubscribe;
|
|
43
|
-
}, [eventReceiver,
|
|
49
|
+
}, [eventReceiver, isDisabled, resource, options, onEvent, onNotify]);
|
|
44
50
|
}
|
|
45
51
|
|
|
46
52
|
export default useEventHandler;
|