@atlaskit/editor-common
Version:
A package that contains common classes and components for editor and renderer
161 lines (160 loc) • 8.8 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _typeof = require("@babel/runtime/helpers/typeof");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.Dropdown = void 0;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _react = _interopRequireWildcard(require("react"));
var _uiReact = require("../../ui-react");
var _DropList = _interopRequireDefault(require("../../ui/DropList"));
var _Popup = _interopRequireDefault(require("../../ui/Popup"));
var _utils = require("../../ui/Popup/utils");
var _ArrowKeyNavigationProvider = require("../ArrowKeyNavigationProvider");
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); }
function _callSuper(t, o, e) { return o = (0, _getPrototypeOf2.default)(o), (0, _possibleConstructorReturn2.default)(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2.default)(t).constructor) : o.apply(t, e)); }
function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
/**
* Wrapper around @atlaskit/droplist which uses Popup and Portal to render
* droplist outside of "overflow: hidden" containers when needed.
*
* Also it controls popper's placement.
*/
// Ignored via go/ees005
// eslint-disable-next-line @repo/internal/react/no-class-components
var Dropdown = exports.Dropdown = /*#__PURE__*/function (_PureComponent) {
function Dropdown(props) {
var _this;
(0, _classCallCheck2.default)(this, Dropdown);
_this = _callSuper(this, Dropdown, [props]);
(0, _defineProperty2.default)(_this, "handleRef", function (setOutsideClickTargetRef) {
return function (target) {
setOutsideClickTargetRef(target);
_this.setState({
target: target || undefined
});
};
});
(0, _defineProperty2.default)(_this, "updatePopupPlacement", function (placement) {
_this.setState({
popupPlacement: placement
});
});
(0, _defineProperty2.default)(_this, "handleCloseAndFocus", function (event) {
var _this$state$target;
(_this$state$target = _this.state.target) === null || _this$state$target === void 0 || (_this$state$target = _this$state$target.querySelector('button')) === null || _this$state$target === void 0 || _this$state$target.focus();
_this.handleClose(event);
});
(0, _defineProperty2.default)(_this, "handleClose", function (event) {
if (_this.props.onOpenChange) {
_this.props.onOpenChange({
isOpen: false,
event: event
});
}
});
_this.state = {
popupPlacement: ['bottom', 'left']
};
return _this;
}
(0, _inherits2.default)(Dropdown, _PureComponent);
return (0, _createClass2.default)(Dropdown, [{
key: "componentDidUpdate",
value: function componentDidUpdate(prevProps) {
if (!prevProps.isOpen && this.props.isOpen && this.state.target) {
// Dropdown flickers when opens as placement is calculated in Popup component and updated after the first render.
// popupPlacement is set to ['bottom', 'left'] by default, but it may not be the correct placement and is required in DropdownList.
// To avoid flicker we calculate placement here and set it to state when the dropdown opens.
var initialPlacement = (0, _utils.calculatePlacement)(this.state.target, this.props.boundariesElement || document.body, this.props.fitWidth, this.props.fitHeight, this.props.alignX, this.props.alignY, this.props.forcePlacement);
this.setState({
popupPlacement: initialPlacement
});
}
}
}, {
key: "renderDropdown",
value: function renderDropdown() {
var _this$state = this.state,
target = _this$state.target,
popupPlacement = _this$state.popupPlacement;
var _this$props = this.props,
children = _this$props.children,
mountTo = _this$props.mountTo,
boundariesElement = _this$props.boundariesElement,
scrollableElement = _this$props.scrollableElement,
onOpenChange = _this$props.onOpenChange,
fitHeight = _this$props.fitHeight,
fitWidth = _this$props.fitWidth,
zIndex = _this$props.zIndex,
arrowKeyNavigationProviderOptions = _this$props.arrowKeyNavigationProviderOptions,
dropdownListId = _this$props.dropdownListId,
alignDropdownWithParentElement = _this$props.alignDropdownWithParentElement,
targetProp = _this$props.target,
forcePlacement = _this$props.forcePlacement,
alignX = _this$props.alignX,
alignY = _this$props.alignY,
offset = _this$props.offset,
_this$props$shouldFit = _this$props.shouldFitContainer,
shouldFitContainer = _this$props$shouldFit === void 0 ? true : _this$props$shouldFit,
testId = _this$props.testId;
return /*#__PURE__*/_react.default.createElement(_Popup.default, {
target: targetProp !== null && targetProp !== void 0 ? targetProp : alignDropdownWithParentElement ? // Ignored via go/ees005
// eslint-disable-next-line @atlaskit/editor/no-as-casting
target === null || target === void 0 ? void 0 : target.closest("[data-testid='editor-floating-toolbar']") : target,
mountTo: mountTo,
boundariesElement: boundariesElement,
scrollableElement: scrollableElement,
onPlacementChanged: forcePlacement ? undefined : this.updatePopupPlacement,
fitHeight: fitHeight,
fitWidth: fitWidth,
zIndex: zIndex,
allowOutOfBounds: alignDropdownWithParentElement,
alignX: alignX,
alignY: alignY,
forcePlacement: forcePlacement,
offset: offset
}, /*#__PURE__*/_react.default.createElement(_ArrowKeyNavigationProvider.ArrowKeyNavigationProvider
// Ignored via go/ees005
// eslint-disable-next-line react/jsx-props-no-spreading
, (0, _extends2.default)({}, arrowKeyNavigationProviderOptions, {
closeOnTab: true,
handleClose: this.handleCloseAndFocus
}), /*#__PURE__*/_react.default.createElement("div", {
style: {
height: 0,
minWidth: fitWidth || 0
}
}, /*#__PURE__*/_react.default.createElement(_DropList.default, {
isOpen: true,
onOpenChange: onOpenChange,
position: popupPlacement.join(' '),
shouldFitContainer: shouldFitContainer,
id: dropdownListId,
testId: testId
}, children))));
}
}, {
key: "render",
value: function render() {
var _this2 = this;
var _this$props2 = this.props,
trigger = _this$props2.trigger,
isOpen = _this$props2.isOpen;
return trigger ? /*#__PURE__*/_react.default.createElement(_uiReact.OutsideClickTargetRefContext.Consumer, null, function (setOutsideClickTargetRef) {
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
ref: _this2.handleRef(setOutsideClickTargetRef)
}, trigger), isOpen ? _this2.renderDropdown() : null);
}) : /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, isOpen ? this.renderDropdown() : null);
}
}]);
}(_react.PureComponent);
var DropdownWithOuterListeners = (0, _uiReact.withReactEditorViewOuterListeners)(Dropdown);
var _default = exports.default = DropdownWithOuterListeners;