UNPKG

@atlaskit/editor-common

Version:

A package that contains common classes and components for editor and renderer

161 lines (160 loc) • 8.8 kB
"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;