@logicflow/react-node-registry
Version:
LogicFlow React Shape
78 lines • 2.5 kB
JavaScript
var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
if (ar || !(i in from)) {
if (!ar) ar = Array.prototype.slice.call(from, 0, i);
ar[i] = from[i];
}
}
return to.concat(ar || Array.prototype.slice.call(from));
};
import React, { useReducer } from 'react';
export var Portal;
(function (Portal) {
var active = false;
var dispatch;
var reducer = function (state, action) {
var payload = action.payload;
switch (action.type) {
case 'add': {
var index = state.findIndex(function (item) { return item.id === payload.id; });
if (index >= 0) {
state[index] = payload;
return __spreadArray([], state, true);
}
return __spreadArray(__spreadArray([], state, true), [payload], false);
}
case 'remove': {
var index = state.findIndex(function (item) { return item.id === payload.id; });
if (index >= 0) {
var result = __spreadArray([], state, true);
result.splice(index, 1);
return result;
}
break;
}
default: {
break;
}
}
return state;
};
function connect(id, portal) {
if (active) {
dispatch({
type: 'add',
payload: {
id: id,
portal: portal,
},
});
}
}
Portal.connect = connect;
function disconnect(id) {
if (active) {
dispatch({
type: 'remove',
payload: { id: id },
});
}
}
Portal.disconnect = disconnect;
function isActive() {
return active;
}
Portal.isActive = isActive;
function getProvider() {
return function () {
active = true;
var _a = useReducer(reducer, []), items = _a[0], mutate = _a[1];
dispatch = mutate;
return React.createElement(React.Fragment, {
children: items.map(function (item) { return item.portal; }),
});
};
}
Portal.getProvider = getProvider;
})(Portal || (Portal = {}));
//# sourceMappingURL=portal.js.map