@atlaskit/editor-common
Version:
A package that contains common classes and components for editor and renderer
88 lines (86 loc) • 4.54 kB
JavaScript
;
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ContextPanelWidthProvider = exports.ContextPanelProvider = exports.ContextPanelConsumer = exports.ContextPanel = void 0;
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 = _interopRequireDefault(require("react"));
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; })(); }
// React context to communicate the active context panel width up and down the tree.
//
// We need the width prop from the ContextPanel component.
//
// However, the actual <ContextPanel /> component might be deeply nested inside the contextPanel.
// For example, in the template context panel storybook, we wrap it in 2 higher order components.
//
// Changing the max-width on the main editor container happens above where the <ContextPanel /> gets rendered.
//
// To subtract the context panel width from the available real estate, we use the Provider and Consumer.
//
// positionedOverEditor is used to determine whether the context panel is positioned over the Editor so we are
// able to position and add margins to handle certain elements like inline comment dialogues overlapping the context
// panel
var ContextPanel = exports.ContextPanel = /*#__PURE__*/_react.default.createContext({
width: 0,
positionedOverEditor: false,
broadcastWidth: function broadcastWidth() {},
broadcastPosition: function broadcastPosition() {}
});
// Ignored via go/ees005
// eslint-disable-next-line @repo/internal/react/no-class-components, @typescript-eslint/no-explicit-any
var ContextPanelWidthProvider = exports.ContextPanelWidthProvider = /*#__PURE__*/function (_React$Component) {
// Ignored via go/ees005
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function ContextPanelWidthProvider(props) {
var _this;
(0, _classCallCheck2.default)(this, ContextPanelWidthProvider);
_this = _callSuper(this, ContextPanelWidthProvider, [props]);
(0, _defineProperty2.default)(_this, "state", {
width: 0,
positionedOverEditor: false
});
(0, _defineProperty2.default)(_this, "broadcastSidebarWidth", function (width) {
if (width !== _this.state.width) {
_this.setState({
width: width
});
}
});
(0, _defineProperty2.default)(_this, "broadcastPosition", function (positionedOverEditor) {
if (positionedOverEditor !== _this.state.positionedOverEditor) {
_this.setState({
positionedOverEditor: positionedOverEditor
});
}
});
return _this;
}
(0, _inherits2.default)(ContextPanelWidthProvider, _React$Component);
return (0, _createClass2.default)(ContextPanelWidthProvider, [{
key: "render",
value: function render() {
var _this$state = this.state,
width = _this$state.width,
positionedOverEditor = _this$state.positionedOverEditor;
return /*#__PURE__*/_react.default.createElement(Provider
// eslint-disable-next-line @atlassian/perf-linting/no-unstable-inline-props -- Ignored via go/ees017 (to be fixed)
, {
value: {
width: width,
positionedOverEditor: positionedOverEditor,
broadcastWidth: this.broadcastSidebarWidth,
broadcastPosition: this.broadcastPosition
}
}, this.props.children);
}
}]);
}(_react.default.Component);
var Provider = exports.ContextPanelProvider = ContextPanel.Provider;
var Consumer = exports.ContextPanelConsumer = ContextPanel.Consumer;