UNPKG

@atlaskit/editor-plugin-block-menu

Version:

BlockMenu plugin for @atlaskit/editor-core

62 lines (61 loc) 3.24 kB
"use strict"; 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); };