use-stomp
Version:
react provider, class decorator, and a hook for websockets using the stomp protocol
102 lines (97 loc) • 12.6 kB
JavaScript
import "core-js/modules/es.object.get-own-property-descriptor";
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
import _defineProperty from "@babel/runtime/helpers/defineProperty";
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
import { SnackbarProvider } from 'notistack';
import React, { useEffect, useMemo } from 'react';
import UseStompCtx from './context';
import useToggle from './useToggle';
import WebSocketWorker from './webSocketWorker';
var UseStompNotificationsProvider = /*#__PURE__*/React.memo(function (name, callable) {
callable.displayName = name;
Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, {
value: name
}));
return callable;
}("UseStompNotificationsProvider", function (_ref) {
var authHeader = _ref.authHeader,
headers = _ref.headers,
reconnectInterval = _ref.reconnectInterval,
reconnectMaxAttempts = _ref.reconnectMaxAttempts,
testReconnect = _ref.testReconnect,
url = _ref.url,
props = _objectWithoutProperties(_ref, ["authHeader", "headers", "reconnectInterval", "reconnectMaxAttempts", "testReconnect", "url"]);
var _useToggle = useToggle(false),
_useToggle2 = _slicedToArray(_useToggle, 2),
connected = _useToggle2[0],
toggleConnected = _useToggle2[1];
var worker = useMemo(function (name, callable) {
callable.displayName = name;
Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, {
value: name
}));
return callable;
}("worker", function () {
return new WebSocketWorker({
onConnected: toggleConnected,
onDisconnected: toggleConnected,
reconnectInterval: reconnectInterval,
reconnectMaxAttempts: reconnectMaxAttempts,
url: url
});
}), []);
useEffect(function () {
if (authHeader) {
worker.setAuthHeader(authHeader);
worker.connect();
}
}, [authHeader]);
useEffect(function () {
return function () {
worker.destroy();
};
}, []);
var ctx = useMemo(function (name, callable) {
callable.displayName = name;
Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, {
value: name
}));
return callable;
}("ctx", function () {
return {
connected: connected,
dismiss: worker.dismiss,
send: worker.send,
subscribe: worker.subscribe,
subscribeSync: worker.subscribeSync
};
}), [connected, worker.dismiss, worker.send, worker.subscribe, worker.subscribeSync]);
useEffect(function () {
if (connected && testReconnect) {
var timeout = setTimeout(function (name, callable) {
callable.displayName = name;
Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, {
value: name
}));
return callable;
}("timeout", function () {
worker.testDisconnect();
}), 10000);
return function () {
clearTimeout(timeout);
};
}
}, [connected, testReconnect]);
return /*#__PURE__*/React.createElement(UseStompCtx.Provider, {
value: ctx
}, /*#__PURE__*/React.createElement(SnackbarProvider, props, props.children));
}));
UseStompNotificationsProvider.defaultProps = {
maxSnack: 3,
reconnectInterval: 10000,
reconnectMaxAttempts: 10
};
export default UseStompNotificationsProvider;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/useStompNotificationsProvider.tsx"],"names":["SnackbarProvider","React","useEffect","useMemo","UseStompCtx","useToggle","WebSocketWorker","UseStompNotificationsProvider","memo","authHeader","headers","reconnectInterval","reconnectMaxAttempts","testReconnect","url","props","connected","toggleConnected","worker","onConnected","onDisconnected","setAuthHeader","connect","destroy","ctx","dismiss","send","subscribe","subscribeSync","timeout","setTimeout","testDisconnect","clearTimeout","children","defaultProps","maxSnack"],"mappings":"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","sourcesContent":["import {SnackbarProvider} from 'notistack';\nimport type {SnackbarProviderProps} from 'notistack';\nimport React, {useEffect, useMemo, useState} from 'react';\n\nimport UseStompCtx from './context';\nimport useToggle from './useToggle';\nimport WebSocketWorker from './webSocketWorker';\n\nexport type UseStompNotificationsProviderProps = SnackbarProviderProps & {\n    /**\n     * url to connect to stomp protocol\n     */\n    url: string;\n    /**\n     * request auth header will be passed to the server or agent through the STOMP connection frame\n     */\n    authHeader?: string;\n    /**\n     * request header will be passed to the server or agent through the STOMP connection frame\n     */\n    headers?: Record<string, unknown>;\n    /**\n     * interval(ms) of attempts to reconnect when the websocket connection is dropped; default is 10,000ms\n     */\n    reconnectInterval?: number;\n    /**\n     * max number of attempts to reconnect when websocket connection is dropped; default is 10\n     */\n    reconnectMaxAttempts?: number;\n    /**\n     * enable testing of reconnection\n     */\n    testReconnect?: boolean;\n};\n\nconst UseStompNotificationsProvider: React.FC<UseStompNotificationsProviderProps> = React.memo(\n    ({\n        authHeader,\n        headers,\n        reconnectInterval,\n        reconnectMaxAttempts,\n        testReconnect,\n        url,\n        ...props\n    }) => {\n        const [connected, toggleConnected] = useToggle(false);\n\n        const worker = useMemo<WebSocketWorker>(\n            () =>\n                new WebSocketWorker({\n                    onConnected: toggleConnected,\n                    onDisconnected: toggleConnected,\n                    reconnectInterval,\n                    reconnectMaxAttempts,\n                    url: url\n                }),\n            []\n        );\n\n        useEffect(() => {\n            if (authHeader) {\n                worker.setAuthHeader(authHeader);\n                worker.connect();\n            }\n        }, [authHeader]);\n\n        useEffect(() => {\n            return () => {\n                worker.destroy();\n            };\n        }, []);\n\n        const ctx = useMemo(\n            () => ({\n                connected,\n                dismiss: worker.dismiss,\n                send: worker.send,\n                subscribe: worker.subscribe,\n                subscribeSync: worker.subscribeSync\n            }),\n            [\n                connected,\n                worker.dismiss,\n                worker.send,\n                worker.subscribe,\n                worker.subscribeSync\n            ]\n        );\n\n        useEffect(() => {\n            if (connected && testReconnect) {\n                const timeout = setTimeout(() => {\n                    worker.testDisconnect();\n                }, 10000);\n\n                return () => {\n                    clearTimeout(timeout);\n                };\n            }\n        }, [connected, testReconnect]);\n\n        return (\n            <UseStompCtx.Provider value={ctx}>\n                <SnackbarProvider {...props}>{props.children}</SnackbarProvider>\n            </UseStompCtx.Provider>\n        );\n    }\n);\n\nUseStompNotificationsProvider.defaultProps = {\n    maxSnack: 3,\n    reconnectInterval: 10000,\n    reconnectMaxAttempts: 10\n};\n\nexport default UseStompNotificationsProvider;\n"]}