mirror of
https://github.com/codex-team/editor.js
synced 2024-06-04 23:12:34 +02:00
8f156a87ea
* the popover component, vertical toolbox * toolbox position improved * popover width improved * always show the plus button * search field added * search input in popover * trying to create mobile toolbox * feat(toolbox): popover adapted for mobile devices (#2004) * FIx mobile popover fixed positioning * Add mobile popover overlay * Hide mobile popover on scroll * Alter toolbox buttons hover * Fix closing popover on overlay click * Tests fix * Fix onchange test * restore focus after toolbox closing by ESC * don't move toolbar by block-hover on mobile Resolves #1972 * popover mobile styles improved * Cleanup * Remove scroll event listener * Lock scroll on mobile * don't show shortcuts in mobile popover * Change data attr name * Remove unused styles * Remove unused listeners * disable hover on mobile popover * Scroll fix * Lint * Revert "Scroll fix" This reverts commit82deae543e
. * Return back background color for active state of toolbox buttons Co-authored-by: Peter Savchenko <specc.dev@gmail.com> * Vertical toolbox fixes (#2017) * Replace visibility property with display for hiding popover * Disable arrow right and left keys for popover * Revert "Replace visibility property with display for hiding popover" This reverts commitaf521cf6f2
. * Hide popover via setting max-height to 0 to fix animation in safari * Remove redundant condition * Extend element interface to avoid ts errors * Do not subscribe to block hovered if mobile * Add unsubscribing from overlay click event * Rename isMobile to isMobileScreen * Cleanup * fix: popover opening direction (#2022) * Change popover opening direction based on available space below it * Update check * Use cacheable decorator * Update src/components/flipper.ts Co-authored-by: George Berezhnoy <gohabereg@users.noreply.github.com> * Fixes * Fix test * Clear search on popover hide * Fix popover width * Fix for tests * Update todos * Linter fixes * rm todo about beforeInsert because I have no idea what does it mean * i18n for search labels done * rm methods for hiding/showing of + * some code style update * Update CHANGELOG.md * make the list items a little bit compact * fix z-index issue caused by block-appearing animation also, improve popover padding for two reasons: - make the popover more consistent with the Table tool popover (in future, it can be done with the same api method) - make popover looks better Co-authored-by: Tanya Fomina <fomina.tatianaaa@yandex.ru> Co-authored-by: George Berezhnoy <gohabereg@users.noreply.github.com>
127 lines
3.1 KiB
TypeScript
127 lines
3.1 KiB
TypeScript
/**
|
|
* Editor.js Saver
|
|
*
|
|
* @module Saver
|
|
* @author Codex Team
|
|
* @version 2.0.0
|
|
*/
|
|
import Module from '../__module';
|
|
import { OutputData } from '../../../types';
|
|
import { SavedData, ValidatedData } from '../../../types/data-formats';
|
|
import Block from '../block';
|
|
import * as _ from '../utils';
|
|
import { sanitizeBlocks } from '../utils/sanitizer';
|
|
|
|
declare const VERSION: string;
|
|
|
|
/**
|
|
* @classdesc This method reduces all Blocks asyncronically and calls Block's save method to extract data
|
|
*
|
|
* @typedef {Saver} Saver
|
|
* @property {Element} html - Editor HTML content
|
|
* @property {string} json - Editor JSON output
|
|
*/
|
|
export default class Saver extends Module {
|
|
/**
|
|
* Composes new chain of Promises to fire them alternatelly
|
|
*
|
|
* @returns {OutputData}
|
|
*/
|
|
public async save(): Promise<OutputData> {
|
|
const { BlockManager, Tools } = this.Editor;
|
|
const blocks = BlockManager.blocks,
|
|
chainData = [];
|
|
|
|
try {
|
|
blocks.forEach((block: Block) => {
|
|
chainData.push(this.getSavedData(block));
|
|
});
|
|
|
|
const extractedData = await Promise.all(chainData) as Array<Pick<SavedData, 'data' | 'tool'>>;
|
|
const sanitizedData = await sanitizeBlocks(extractedData, (name) => {
|
|
return Tools.blockTools.get(name).sanitizeConfig;
|
|
});
|
|
|
|
return this.makeOutput(sanitizedData);
|
|
} catch (e) {
|
|
_.logLabeled(`Saving failed due to the Error %o`, 'error', e);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Saves and validates
|
|
*
|
|
* @param {Block} block - Editor's Tool
|
|
* @returns {ValidatedData} - Tool's validated data
|
|
*/
|
|
private async getSavedData(block: Block): Promise<ValidatedData> {
|
|
const blockData = await block.save();
|
|
const isValid = blockData && await block.validate(blockData.data);
|
|
|
|
return {
|
|
...blockData,
|
|
isValid,
|
|
};
|
|
}
|
|
|
|
/**
|
|
* Creates output object with saved data, time and version of editor
|
|
*
|
|
* @param {ValidatedData} allExtractedData - data extracted from Blocks
|
|
* @returns {OutputData}
|
|
*/
|
|
private makeOutput(allExtractedData): OutputData {
|
|
let totalTime = 0;
|
|
const blocks = [];
|
|
|
|
_.log('[Editor.js saving]:', 'groupCollapsed');
|
|
|
|
allExtractedData.forEach(({ id, tool, data, tunes, time, isValid }) => {
|
|
totalTime += time;
|
|
|
|
/**
|
|
* Capitalize Tool name
|
|
*/
|
|
_.log(`${tool.charAt(0).toUpperCase() + tool.slice(1)}`, 'group');
|
|
|
|
if (isValid) {
|
|
/** Group process info */
|
|
_.log(data);
|
|
_.log(undefined, 'groupEnd');
|
|
} else {
|
|
_.log(`Block «${tool}» skipped because saved data is invalid`);
|
|
_.log(undefined, 'groupEnd');
|
|
|
|
return;
|
|
}
|
|
|
|
/** If it was stub Block, get original data */
|
|
if (tool === this.Editor.Tools.stubTool) {
|
|
blocks.push(data);
|
|
|
|
return;
|
|
}
|
|
|
|
const output = {
|
|
id,
|
|
type: tool,
|
|
data,
|
|
...!_.isEmpty(tunes) && {
|
|
tunes,
|
|
},
|
|
};
|
|
|
|
blocks.push(output);
|
|
});
|
|
|
|
_.log('Total', 'log', totalTime);
|
|
_.log(undefined, 'groupEnd');
|
|
|
|
return {
|
|
time: +new Date(),
|
|
blocks,
|
|
version: VERSION,
|
|
};
|
|
}
|
|
}
|