use-stomp
Version:
react provider, class decorator, and a hook for websockets using the stomp protocol
370 lines (307 loc) • 37.9 kB
JavaScript
import "core-js/modules/es.array.concat";
import "core-js/modules/es.array.filter";
import "core-js/modules/es.array.for-each";
import "core-js/modules/es.array.includes";
import "core-js/modules/es.array.map";
import "core-js/modules/es.object.get-own-property-descriptor";
import "core-js/modules/es.string.includes";
import "core-js/modules/web.dom-collections.for-each";
import _objectWithoutProperties from "@babel/runtime/helpers/objectWithoutProperties";
import _defineProperty from "@babel/runtime/helpers/defineProperty";
import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
import _inherits from "@babel/runtime/helpers/inherits";
import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstructorReturn";
import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf";
import _wrapNativeSuper from "@babel/runtime/helpers/wrapNativeSuper";
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; }
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } }
import { v4 } from 'uuid';
import { Events, States } from './webSocketConfigs';
var WebSocketWorker = /*#__PURE__*/function (_SharedWorker) {
_inherits(WebSocketWorker, _SharedWorker);
var _super = _createSuper(WebSocketWorker);
function WebSocketWorker(_props) {
var _this$_workerEvents;
var _this;
_classCallCheck(this, WebSocketWorker);
_this = _super.call(this, 'webSocketWorkerInstance.js');
_this._channels = {};
_this._connected = false;
_this._id = v4();
_this._onConnected = function () {};
_this._onDisconnected = function () {};
_this._onSyncState = function (state) {};
_this._syncChannels = {};
_this._syncMessages = {};
_this.connect = function () {
_this.port.postMessage({
type: Events.CONNECT
});
};
_this.destroy = function () {
_this._unregister();
_this.port.removeEventListener('message', _this._onMessage);
document.removeEventListener('visibilitychange', _this._setVisibility);
window.removeEventListener('beforeunload', _this._unregister);
};
_this.disconnect = function () {
_this.port.postMessage({
type: Events.DISCONNECT
});
};
_this.testDisconnect = function () {
_this.port.postMessage({
type: Events.TEST_DISCONNECT
});
};
_this.dismiss = function (channel, id) {
_this.port.postMessage({
type: Events.DISMISS_SYNC,
payload: {
channel: channel,
id: id
}
});
};
_this.send = function (channel, message) {
_this.port.postMessage({
type: Events.SEND_MESSAGE,
payload: {
channel: channel,
message: message
}
});
};
_this.setAuthHeader = function (authHeader) {
_this.port.postMessage({
type: Events.SET_AUTH_HEADER,
payload: authHeader
});
};
_this.setHeader = function (header) {
_this.port.postMessage({
type: Events.SET_HEADER,
payload: header
});
};
_this.setUrl = function (url) {
_this.port.postMessage({
type: Events.SET_URL,
payload: url
});
};
_this.subscribe = function (channel, callback) {
if (!(_this._channels[channel] || []).length) {
_this._channels[channel] = [callback];
_this.port.postMessage({
type: Events.SUBSCRIBE,
payload: {
id: _this._id,
channel: channel
}
});
} else {
_this._channels[channel] = [].concat(_toConsumableArray(_this._channels[channel]), [callback]);
}
return function () {
_this._channels[channel] = (_this._channels[channel] || []).filter(function (fn) {
return fn !== callback;
});
if (!_this._channels[channel].length) {
_this.unsubscribe(channel);
}
};
};
_this.subscribeSync = function (channel, callback) {
var fn = function fn(messages) {
var oldMessages = _this._syncMessages[channel] || [];
var oldIds = oldMessages.map(function (name, callable) {
callable.displayName = name;
Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, {
value: name
}));
return callable;
}("oldIds", function (msg) {
return msg.id;
}));
_this._syncMessages[channel] = messages;
var newIds = (_this._syncMessages[channel] || []).map(function (name, callable) {
callable.displayName = name;
Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, {
value: name
}));
return callable;
}("newIds", function (msg) {
return msg.id;
}));
var add = messages.filter(function (name, callable) {
callable.displayName = name;
Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, {
value: name
}));
return callable;
}("add", function (_ref) {
var id = _ref.id;
return !oldIds.includes(id) && newIds.includes(id);
}));
var remove = oldMessages.filter(function (name, callable) {
callable.displayName = name;
Object.defineProperty(callable, "name", _objectSpread(_objectSpread({}, Object.getOwnPropertyDescriptor(callable, "name")), {}, {
value: name
}));
return callable;
}("remove", function (_ref2) {
var id = _ref2.id;
return !newIds.includes(id) && oldIds.includes(id);
}));
callback(messages, add, remove);
};
if (!(_this._syncChannels[channel] || []).length) {
_this._syncChannels[channel] = [fn];
_this.port.postMessage({
type: Events.SUBSCRIBE_SYNC,
payload: {
id: _this._id,
channel: channel
}
});
} else {
_this._syncChannels[channel] = [].concat(_toConsumableArray(_this._syncChannels[channel]), [fn]);
}
return function () {
_this._syncChannels[channel] = (_this._syncChannels[channel] || []).filter(function (callback) {
return callback !== fn;
});
if (!_this._syncChannels[channel].length) {
_this.unsubscribeSync(channel);
}
};
};
_this.unsubscribe = function (channel) {
_this.port.postMessage({
type: Events.UNSUBSCRIBE,
payload: {
id: _this._id,
channel: channel
}
});
};
_this.unsubscribeSync = function (channel) {
_this.port.postMessage({
type: Events.UNSUBSCRIBE_SYNC,
payload: {
id: _this._id,
channel: channel
}
});
};
_this._onMessage = function (event) {
if (_this._workerEvents[event.data.type]) {
_this._workerEvents[event.data.type](event);
}
};
_this._register = function (props) {
_this.port.postMessage({
type: Events.REGISTER,
payload: {
id: _this._id,
reconnectInterval: props.reconnectInterval,
reconnectMaxAttempts: props.reconnectMaxAttempts,
visibility: document.visibilityState === 'visible'
}
});
};
_this._setError = function (event) {
console.error('[use-stomp]', event.data.payload);
};
_this._setVisibility = function () {
_this.port.postMessage({
type: Events.SET_VISIBILITY,
payload: {
id: _this._id,
visibility: document.visibilityState === 'visible'
}
});
};
_this._setMessage = function (event) {
if (_this._channels[event.data.payload.channel]) {
_this._channels[event.data.payload.channel].forEach(function (fn) {
return fn(event.data.payload.message);
});
}
if (_this._syncChannels[event.data.payload.channel]) {
_this._syncChannels[event.data.payload.channel].forEach(function (fn) {
fn((event.data.payload.message || []).map(function (_ref3) {
var message = _ref3.message,
item = _objectWithoutProperties(_ref3, ["message"]);
return _objectSpread(_objectSpread({}, item), {}, {
content: message,
dismiss: function dismiss() {
return _this.dismiss(event.data.payload.channel, item.id);
}
});
}));
});
}
};
_this._setConnection = function (event) {
var wasConnected = !!_this._connected;
switch (event.data.payload) {
case States.CONNECTED:
_this._connected = true;
break;
case States.CONNECTING:
_this._connected = false;
break;
case States.DISCONNECTED:
_this._connected = false;
break;
case States.DISCONNECTING:
_this._connected = false;
break;
}
if (!wasConnected && _this._connected) {
_this._onConnected();
}
if (wasConnected && !_this._connected) {
_this._onDisconnected();
}
};
_this._unregister = function () {
_this.port.postMessage({
type: Events.UNREGISTER,
payload: {
id: _this._id
}
});
};
_this._workerEvents = (_this$_workerEvents = {}, _defineProperty(_this$_workerEvents, Events.CONNECTION, _this._setConnection), _defineProperty(_this$_workerEvents, Events.ERROR, _this._setError), _defineProperty(_this$_workerEvents, Events.MESSAGE, _this._setMessage), _this$_workerEvents);
if (_props !== null && _props !== void 0 && _props.onConnected) {
_this._onConnected = _props.onConnected;
}
if (_props !== null && _props !== void 0 && _props.onDisconnected) {
_this._onDisconnected = _props.onDisconnected;
}
if (_props !== null && _props !== void 0 && _props.onSyncState) {
_this._onSyncState = _props.onSyncState;
}
_this.port.start();
_this.port.addEventListener('message', _this._onMessage);
_this._register({
reconnectMaxAttempts: _props.reconnectMaxAttempts || 10,
reconnectInterval: _props.reconnectInterval || 10000
});
if (_props.url) {
_this.setUrl(_props.url);
}
document.addEventListener('visibilitychange', _this._setVisibility);
window.addEventListener('beforeunload', _this._unregister);
return _this;
}
return WebSocketWorker;
}( /*#__PURE__*/_wrapNativeSuper(SharedWorker));
export { WebSocketWorker as default };
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/webSocketWorker.ts"],"names":["v4","Events","States","WebSocketWorker","props","_channels","_connected","_id","_onConnected","_onDisconnected","_onSyncState","state","_syncChannels","_syncMessages","connect","port","postMessage","type","CONNECT","destroy","_unregister","removeEventListener","_onMessage","document","_setVisibility","window","disconnect","DISCONNECT","testDisconnect","TEST_DISCONNECT","dismiss","channel","id","DISMISS_SYNC","payload","send","message","SEND_MESSAGE","setAuthHeader","authHeader","SET_AUTH_HEADER","setHeader","header","SET_HEADER","setUrl","url","SET_URL","subscribe","callback","length","SUBSCRIBE","filter","fn","unsubscribe","subscribeSync","messages","oldMessages","oldIds","map","msg","newIds","add","includes","remove","SUBSCRIBE_SYNC","unsubscribeSync","UNSUBSCRIBE","UNSUBSCRIBE_SYNC","event","_workerEvents","data","_register","REGISTER","reconnectInterval","reconnectMaxAttempts","visibility","visibilityState","_setError","console","error","SET_VISIBILITY","_setMessage","forEach","item","content","_setConnection","wasConnected","CONNECTED","CONNECTING","DISCONNECTED","DISCONNECTING","UNREGISTER","CONNECTION","ERROR","MESSAGE","onConnected","onDisconnected","onSyncState","start","addEventListener","SharedWorker"],"mappings":"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","sourcesContent":["import {v4} from 'uuid';\n\nimport {StompNotification} from './useStompNotifications';\nimport {Events, States} from './webSocketConfigs';\n\nexport type WebSocketWorkerProps = {\n    onConnected?(): void;\n    onDisconnected?(): void;\n    onSyncState?(state: any): void;\n    reconnectMaxAttempts?: number;\n    reconnectInterval?: number;\n    url?: string;\n};\n\nexport default class WebSocketWorker extends SharedWorker {\n    _channels = {};\n\n    _connected = false;\n\n    _id = v4();\n\n    _onConnected = () => {};\n\n    _onDisconnected = () => {};\n\n    _onSyncState = (state: any) => {};\n\n    _syncChannels = {};\n\n    _syncMessages = {};\n\n    constructor(props?: WebSocketWorkerProps) {\n        super('webSocketWorkerInstance.js');\n\n        if (props?.onConnected) {\n            this._onConnected = props.onConnected;\n        }\n\n        if (props?.onDisconnected) {\n            this._onDisconnected = props.onDisconnected;\n        }\n\n        if (props?.onSyncState) {\n            this._onSyncState = props.onSyncState;\n        }\n\n        this.port.start();\n\n        this.port.addEventListener('message', this._onMessage);\n\n        this._register({\n            reconnectMaxAttempts: props.reconnectMaxAttempts || 10,\n            reconnectInterval: props.reconnectInterval || 10000\n        });\n\n        if (props.url) {\n            this.setUrl(props.url);\n        }\n\n        document.addEventListener('visibilitychange', this._setVisibility);\n        window.addEventListener('beforeunload', this._unregister);\n    }\n\n    connect = () => {\n        this.port.postMessage({\n            type: Events.CONNECT\n        });\n    };\n\n    destroy = () => {\n        this._unregister();\n\n        this.port.removeEventListener('message', this._onMessage);\n        document.removeEventListener('visibilitychange', this._setVisibility);\n        window.removeEventListener('beforeunload', this._unregister);\n    };\n\n    disconnect = () => {\n        this.port.postMessage({\n            type: Events.DISCONNECT\n        });\n    };\n\n    testDisconnect = () => {\n        this.port.postMessage({\n            type: Events.TEST_DISCONNECT\n        });\n    };\n\n    dismiss = (channel, id) => {\n        this.port.postMessage({\n            type: Events.DISMISS_SYNC,\n            payload: {\n                channel,\n                id\n            }\n        });\n    };\n\n    send = (channel: string, message: any) => {\n        this.port.postMessage({\n            type: Events.SEND_MESSAGE,\n            payload: {\n                channel,\n                message\n            }\n        });\n    };\n\n    setAuthHeader = (authHeader) => {\n        this.port.postMessage({\n            type: Events.SET_AUTH_HEADER,\n            payload: authHeader\n        });\n    };\n\n    setHeader = (header) => {\n        this.port.postMessage({\n            type: Events.SET_HEADER,\n            payload: header\n        });\n    };\n\n    setUrl = (url) => {\n        this.port.postMessage({\n            type: Events.SET_URL,\n            payload: url\n        });\n    };\n\n    subscribe = (\n        channel: string,\n        callback: (message: any) => void\n    ): (() => void) => {\n        if (!(this._channels[channel] || []).length) {\n            this._channels[channel] = [callback];\n\n            this.port.postMessage({\n                type: Events.SUBSCRIBE,\n                payload: {\n                    id: this._id,\n                    channel\n                }\n            });\n        } else {\n            this._channels[channel] = [...this._channels[channel], callback];\n        }\n\n        return () => {\n            this._channels[channel] = (this._channels[channel] || []).filter(\n                (fn) => fn !== callback\n            );\n\n            if (!this._channels[channel].length) {\n                this.unsubscribe(channel);\n            }\n        };\n    };\n\n    subscribeSync = (\n        channel: string,\n        callback: (\n            messages: StompNotification<any>[],\n            add: StompNotification<any>[],\n            remove: StompNotification<any>[]\n        ) => void\n    ): (() => void) => {\n        const fn = (messages) => {\n            const oldMessages = this._syncMessages[channel] || [];\n\n            const oldIds = oldMessages.map((msg) => msg.id);\n\n            this._syncMessages[channel] = messages;\n\n            const newIds = (this._syncMessages[channel] || []).map(\n                (msg) => msg.id\n            );\n\n            const add = messages.filter(\n                ({id}) => !oldIds.includes(id) && newIds.includes(id)\n            );\n\n            const remove = oldMessages.filter(\n                ({id}) => !newIds.includes(id) && oldIds.includes(id)\n            );\n\n            callback(messages, add, remove);\n        };\n\n        if (!(this._syncChannels[channel] || []).length) {\n            this._syncChannels[channel] = [fn];\n\n            this.port.postMessage({\n                type: Events.SUBSCRIBE_SYNC,\n                payload: {\n                    id: this._id,\n                    channel\n                }\n            });\n        } else {\n            this._syncChannels[channel] = [...this._syncChannels[channel], fn];\n        }\n\n        return () => {\n            this._syncChannels[channel] = (\n                this._syncChannels[channel] || []\n            ).filter((callback) => callback !== fn);\n\n            if (!this._syncChannels[channel].length) {\n                this.unsubscribeSync(channel);\n            }\n        };\n    };\n\n    unsubscribe = (channel) => {\n        this.port.postMessage({\n            type: Events.UNSUBSCRIBE,\n            payload: {\n                id: this._id,\n                channel\n            }\n        });\n    };\n\n    unsubscribeSync = (channel) => {\n        this.port.postMessage({\n            type: Events.UNSUBSCRIBE_SYNC,\n            payload: {\n                id: this._id,\n                channel\n            }\n        });\n    };\n\n    _onMessage = (event) => {\n        if (this._workerEvents[event.data.type]) {\n            this._workerEvents[event.data.type](event);\n        }\n    };\n\n    _register = (\n        props: Pick<\n            WebSocketWorkerProps,\n            'reconnectMaxAttempts' | 'reconnectInterval'\n        >\n    ) => {\n        this.port.postMessage({\n            type: Events.REGISTER,\n            payload: {\n                id: this._id,\n                reconnectInterval: props.reconnectInterval,\n                reconnectMaxAttempts: props.reconnectMaxAttempts,\n                visibility: document.visibilityState === 'visible'\n            }\n        });\n    };\n\n    _setError = (event) => {\n        console.error('[use-stomp]', event.data.payload);\n    };\n\n    _setVisibility = () => {\n        this.port.postMessage({\n            type: Events.SET_VISIBILITY,\n            payload: {\n                id: this._id,\n                visibility: document.visibilityState === 'visible'\n            }\n        });\n    };\n\n    _setMessage = (event) => {\n        if (this._channels[event.data.payload.channel]) {\n            this._channels[event.data.payload.channel].forEach((fn) =>\n                fn(event.data.payload.message)\n            );\n        }\n\n        if (this._syncChannels[event.data.payload.channel]) {\n            this._syncChannels[event.data.payload.channel].forEach((fn) => {\n                fn(\n                    (event.data.payload.message || []).map(\n                        ({message, ...item}) => ({\n                            ...item,\n                            content: message,\n                            dismiss: () =>\n                                this.dismiss(\n                                    event.data.payload.channel,\n                                    item.id\n                                )\n                        })\n                    )\n                );\n            });\n        }\n    };\n\n    _setConnection = (event) => {\n        const wasConnected = !!this._connected;\n\n        switch (event.data.payload) {\n            case States.CONNECTED:\n                this._connected = true;\n                break;\n            case States.CONNECTING:\n                this._connected = false;\n                break;\n            case States.DISCONNECTED:\n                this._connected = false;\n                break;\n            case States.DISCONNECTING:\n                this._connected = false;\n                break;\n        }\n\n        if (!wasConnected && this._connected) {\n            this._onConnected();\n        }\n\n        if (wasConnected && !this._connected) {\n            this._onDisconnected();\n        }\n    };\n\n    _unregister = () => {\n        this.port.postMessage({\n            type: Events.UNREGISTER,\n            payload: {\n                id: this._id\n            }\n        });\n    };\n\n    _workerEvents = {\n        [Events.CONNECTION]: this._setConnection,\n        [Events.ERROR]: this._setError,\n        [Events.MESSAGE]: this._setMessage\n    };\n}\n"]}