@atlaskit/editor-plugin-block-menu
Version:
BlockMenu plugin for @atlaskit/editor-core
62 lines (61 loc) • 3.24 kB
JavaScript
;
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.useBlockMenu = exports.BlockMenuProvider = void 0;
var _react = _interopRequireWildcard(require("react"));
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function _interopRequireWildcard(e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != _typeof(e) && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (var _t in e) "default" !== _t && {}.hasOwnProperty.call(e, _t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, _t)) && (i.get || i.set) ? o(f, _t, i) : f[_t] = e[_t]); return f; })(e, t); }
var BlockMenuContext = /*#__PURE__*/(0, _react.createContext)({
onDropdownOpenChanged: function onDropdownOpenChanged() {},
moveDownRef: /*#__PURE__*/_react.default.createRef(),
moveUpRef: /*#__PURE__*/_react.default.createRef(),
getFirstSelectedDomNode: function getFirstSelectedDomNode() {
return undefined;
}
});
var useBlockMenu = exports.useBlockMenu = function useBlockMenu() {
var context = (0, _react.useContext)(BlockMenuContext);
if (!context) {
throw new Error('useBlockMenu must be used within BlockMenuProvider');
}
return context;
};
var BlockMenuProvider = exports.BlockMenuProvider = function BlockMenuProvider(_ref) {
var children = _ref.children,
api = _ref.api,
editorView = _ref.editorView;
var moveUpRef = (0, _react.useRef)(null);
var moveDownRef = (0, _react.useRef)(null);
var getFirstSelectedDomNode = (0, _react.useCallback)(function () {
var _api$selection;
var from = api === null || api === void 0 || (_api$selection = api.selection) === null || _api$selection === void 0 || (_api$selection = _api$selection.sharedState.currentState()) === null || _api$selection === void 0 || (_api$selection = _api$selection.selection) === null || _api$selection === void 0 ? void 0 : _api$selection.from;
if (from !== undefined) {
var nodeDOM = editorView === null || editorView === void 0 ? void 0 : editorView.nodeDOM(from);
if (nodeDOM instanceof Element) {
return nodeDOM;
}
}
}, [api, editorView]);
var onDropdownOpenChanged = (0, _react.useCallback)(function (isOpen) {
if (!isOpen) {
// On Dropdown closed, return focus to editor
setTimeout(function () {
return requestAnimationFrame(function () {
api === null || api === void 0 || api.core.actions.focus({
scrollIntoView: false
});
});
}, 1);
}
}, [api]);
return /*#__PURE__*/_react.default.createElement(BlockMenuContext.Provider, {
// eslint-disable-next-line @atlassian/perf-linting/no-inline-context-value, @atlassian/perf-linting/no-unstable-inline-props -- Ignored via go/ees017 (to be fixed)
value: {
onDropdownOpenChanged: onDropdownOpenChanged,
moveDownRef: moveDownRef,
moveUpRef: moveUpRef,
getFirstSelectedDomNode: getFirstSelectedDomNode
}
}, children);
};