@atlaskit/editor-plugin-insert-block
Version:
Insert block plugin for @atlaskit/editor-core
50 lines (49 loc) • 2.55 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.ImageButton = void 0;
var _react = _interopRequireDefault(require("react"));
var _reactIntl = require("react-intl");
var _hooks = require("@atlaskit/editor-common/hooks");
var _messages = require("@atlaskit/editor-common/messages");
var _toolbar = require("@atlaskit/editor-common/toolbar");
var _editorPluginConnectivity = require("@atlaskit/editor-plugin-connectivity");
var _editorToolbar = require("@atlaskit/editor-toolbar");
var ImageButton = exports.ImageButton = function ImageButton(_ref) {
var api = _ref.api;
var _useIntl = (0, _reactIntl.useIntl)(),
formatMessage = _useIntl.formatMessage;
var _useSharedPluginState = (0, _hooks.useSharedPluginStateWithSelector)(api, ['connectivity', 'imageUpload'], function (states) {
var _states$connectivityS, _states$imageUploadSt;
return {
connectivityMode: (_states$connectivityS = states.connectivityState) === null || _states$connectivityS === void 0 ? void 0 : _states$connectivityS.mode,
imageUploadEnabled: (_states$imageUploadSt = states.imageUploadState) === null || _states$imageUploadSt === void 0 ? void 0 : _states$imageUploadSt.enabled
};
}),
connectivityMode = _useSharedPluginState.connectivityMode,
imageUploadEnabled = _useSharedPluginState.imageUploadEnabled;
var _useEditorToolbar = (0, _toolbar.useEditorToolbar)(),
editorView = _useEditorToolbar.editorView;
var isOffline = (0, _editorPluginConnectivity.isOfflineMode)(connectivityMode);
var onClick = function onClick() {
if (editorView) {
var _api$imageUpload;
var state = editorView.state,
dispatch = editorView.dispatch;
api === null || api === void 0 || (_api$imageUpload = api.imageUpload) === null || _api$imageUpload === void 0 || _api$imageUpload.actions.startUpload()(state, dispatch);
}
};
return /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarTooltip, {
content: formatMessage(_messages.toolbarInsertBlockMessages.image)
}, /*#__PURE__*/_react.default.createElement(_editorToolbar.ToolbarButton, {
iconBefore: /*#__PURE__*/_react.default.createElement(_editorToolbar.ImageIcon, {
label: formatMessage(_messages.toolbarInsertBlockMessages.image),
size: "small"
}),
onClick: onClick,
isDisabled: !imageUploadEnabled || isOffline,
testId: _toolbar.TOOLBAR_BUTTON_TEST_ID.IMAGE
}));
};