@atlaskit/editor-plugin-hyperlink
Version:
Hyperlink plugin for @atlaskit/editor-core
38 lines (37 loc) • 1.4 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ButtonWrapper = void 0;
var _react = _interopRequireDefault(require("react"));
var _reactDom = require("react-dom");
var _reactIntl = require("react-intl");
var _link = require("@atlaskit/editor-common/link");
var ButtonWrapper = exports.ButtonWrapper = function ButtonWrapper(_ref) {
var editorView = _ref.editorView,
pos = _ref.pos,
stateKey = _ref.stateKey,
intl = _ref.intl,
onOpenLinkClick = _ref.onOpenLinkClick;
var wrapper = document.createElement('span');
wrapper.style.position = 'relative';
var nonBreakingCharacter = "\u2060";
var onDropdownChange = function onDropdownChange(isOpen) {
editorView.dispatch(editorView.state.tr.setMeta(stateKey, {
type: _link.LinkAction.SET_CONFIGURE_DROPDOWN_OPEN,
isOpen: isOpen
}));
};
(0, _reactDom.render)( /*#__PURE__*/_react.default.createElement(_reactIntl.IntlProvider, {
locale: intl.locale || 'en',
messages: intl.messages,
formats: intl.formats
}, /*#__PURE__*/_react.default.createElement(_link.OverlayButton, {
targetElementPos: pos,
editorView: editorView,
onDropdownChange: onDropdownChange,
onOpenLinkClick: onOpenLinkClick
}), nonBreakingCharacter), wrapper);
return wrapper;
};