@atlaskit/editor-plugin-synced-block
Version:
SyncedBlock plugin for @atlaskit/editor-core
137 lines (136 loc) • 7.7 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.syncedBlockPlugin = void 0;
var _react = _interopRequireDefault(require("react"));
var _adfSchema = require("@atlaskit/adf-schema");
var _editorSyncedBlockProvider = require("@atlaskit/editor-synced-block-provider");
var _experiments = require("@atlaskit/tmp-editor-statsig/experiments");
var _editorActions = require("./editor-actions");
var _editorCommands = require("./editor-commands");
var _bodiedSyncBlockNodeWithToDOMFixed = require("./nodeviews/bodiedSyncBlockNodeWithToDOMFixed");
var _main = require("./pm-plugins/main");
var _menuAndToolbarExperiences = require("./pm-plugins/menu-and-toolbar-experiences");
var _blockMenuComponents = require("./ui/block-menu-components");
var _DeleteConfirmationModal = require("./ui/DeleteConfirmationModal");
var _Flag = require("./ui/Flag");
var _floatingToolbar = require("./ui/floating-toolbar");
var _quickInsert = require("./ui/quick-insert");
var _SyncBlockRefresher = require("./ui/SyncBlockRefresher");
var _toolbarComponents = require("./ui/toolbar-components");
var syncedBlockPlugin = exports.syncedBlockPlugin = function syncedBlockPlugin(_ref) {
var _api$editorViewMode, _api$analytics, _api$blockMenu, _config$enableSourceC, _api$toolbar, _config$enableSourceC2;
var config = _ref.config,
api = _ref.api;
var refs = {};
var viewMode = api === null || api === void 0 || (_api$editorViewMode = api.editorViewMode) === null || _api$editorViewMode === void 0 || (_api$editorViewMode = _api$editorViewMode.sharedState.currentState()) === null || _api$editorViewMode === void 0 ? void 0 : _api$editorViewMode.mode;
var syncBlockStore = new _editorSyncedBlockProvider.SyncBlockStoreManager(config === null || config === void 0 ? void 0 : config.syncBlockDataProvider, viewMode, config === null || config === void 0 ? void 0 : config.__livePage);
syncBlockStore.setFireAnalyticsEvent(api === null || api === void 0 || (_api$analytics = api.analytics) === null || _api$analytics === void 0 || (_api$analytics = _api$analytics.actions) === null || _api$analytics === void 0 ? void 0 : _api$analytics.fireAnalyticsEvent);
api === null || api === void 0 || (_api$blockMenu = api.blockMenu) === null || _api$blockMenu === void 0 || _api$blockMenu.actions.registerBlockMenuComponents((0, _blockMenuComponents.getBlockMenuComponents)(api, (_config$enableSourceC = config === null || config === void 0 ? void 0 : config.enableSourceCreation) !== null && _config$enableSourceC !== void 0 ? _config$enableSourceC : false));
api === null || api === void 0 || (_api$toolbar = api.toolbar) === null || _api$toolbar === void 0 || _api$toolbar.actions.registerComponents((0, _toolbarComponents.getToolbarComponents)(api, (_config$enableSourceC2 = config === null || config === void 0 ? void 0 : config.enableSourceCreation) !== null && _config$enableSourceC2 !== void 0 ? _config$enableSourceC2 : false));
return {
name: 'syncedBlock',
nodes: function nodes() {
return [{
name: 'syncBlock',
node: _adfSchema.syncBlock
}, {
name: 'bodiedSyncBlock',
node: !(0, _experiments.editorExperiment)('platform_synced_block_patch_6', true, {
exposure: true
}) ?
// delete bodiedSyncBlockNodeWithToDOMFixed when cleaning up platform_synced_block_patch_6
(0, _bodiedSyncBlockNodeWithToDOMFixed.bodiedSyncBlockNodeWithToDOMFixed)() : _adfSchema.bodiedSyncBlock
}];
},
pmPlugins: function pmPlugins() {
return [{
name: 'syncedBlockPlugin',
plugin: function plugin(params) {
return (0, _main.createPlugin)(config, params, syncBlockStore, api);
}
}, {
name: 'menuAndToolbarExperiencesPlugin',
plugin: function plugin() {
return (0, _menuAndToolbarExperiences.getMenuAndToolbarExperiencesPlugin)({
refs: refs,
dispatchAnalyticsEvent: function dispatchAnalyticsEvent(payload) {
var _api$analytics2;
return api === null || api === void 0 || (_api$analytics2 = api.analytics) === null || _api$analytics2 === void 0 || (_api$analytics2 = _api$analytics2.actions) === null || _api$analytics2 === void 0 ? void 0 : _api$analytics2.fireAnalyticsEvent(payload);
}
});
}
}];
},
commands: {
copySyncedBlockReferenceToClipboard: function copySyncedBlockReferenceToClipboard(inputMethod) {
return (0, _editorCommands.copySyncedBlockReferenceToClipboardEditorCommand)(syncBlockStore, inputMethod, api);
},
insertSyncedBlock: function insertSyncedBlock() {
return function (_ref2) {
var _api$analytics3;
var tr = _ref2.tr;
if (!(config !== null && config !== void 0 && config.enableSourceCreation)) {
return null;
}
return (0, _editorCommands.createSyncedBlock)({
tr: tr,
syncBlockStore: syncBlockStore,
fireAnalyticsEvent: api === null || api === void 0 || (_api$analytics3 = api.analytics) === null || _api$analytics3 === void 0 ? void 0 : _api$analytics3.actions.fireAnalyticsEvent
}) || null;
};
}
},
actions: {
flushBodiedSyncBlocks: function flushBodiedSyncBlocks() {
return (0, _editorActions.flushBodiedSyncBlocks)(syncBlockStore);
},
flushSyncedBlocks: function flushSyncedBlocks() {
return (0, _editorActions.flushSyncBlocks)(syncBlockStore);
}
},
pluginsOptions: {
quickInsert: (0, _quickInsert.getQuickInsertConfig)(config, api, syncBlockStore),
floatingToolbar: function floatingToolbar(state, intl) {
return (0, _floatingToolbar.getToolbarConfig)(state, intl, api, syncBlockStore);
}
},
contentComponent: function contentComponent(_ref3) {
var containerElement = _ref3.containerElement,
wrapperElement = _ref3.wrapperElement,
popupsMountPoint = _ref3.popupsMountPoint;
refs.containerElement = containerElement || undefined;
refs.popupsMountPoint = popupsMountPoint || undefined;
refs.wrapperElement = wrapperElement || undefined;
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_SyncBlockRefresher.SyncBlockRefresher, {
syncBlockStoreManager: syncBlockStore,
api: api
}), /*#__PURE__*/_react.default.createElement(_DeleteConfirmationModal.DeleteConfirmationModal, {
syncBlockStoreManager: syncBlockStore,
api: api
}), /*#__PURE__*/_react.default.createElement(_Flag.Flag, {
api: api
}));
},
getSharedState: function getSharedState(editorState) {
if (!editorState) {
return;
}
var _syncedBlockPluginKey = _main.syncedBlockPluginKey.getState(editorState),
activeFlag = _syncedBlockPluginKey.activeFlag,
currentSyncBlockStore = _syncedBlockPluginKey.syncBlockStore,
bodiedSyncBlockDeletionStatus = _syncedBlockPluginKey.bodiedSyncBlockDeletionStatus,
retryCreationPosMap = _syncedBlockPluginKey.retryCreationPosMap,
hasUnsavedBodiedSyncBlockChanges = _syncedBlockPluginKey.hasUnsavedBodiedSyncBlockChanges;
return {
activeFlag: activeFlag,
syncBlockStore: currentSyncBlockStore,
bodiedSyncBlockDeletionStatus: bodiedSyncBlockDeletionStatus,
retryCreationPosMap: retryCreationPosMap,
hasUnsavedBodiedSyncBlockChanges: hasUnsavedBodiedSyncBlockChanges
};
}
};
};