You've already forked joplin
mirror of
https://github.com/laurent22/joplin.git
synced 2025-08-10 22:11:50 +02:00
Chore: Editor: Refactor editor package (#12743)
This commit is contained in:
@@ -962,47 +962,46 @@ packages/editor/CodeMirror/editorCommands/duplicateLine.js
|
||||
packages/editor/CodeMirror/editorCommands/editorCommands.js
|
||||
packages/editor/CodeMirror/editorCommands/insertLineAfter.test.js
|
||||
packages/editor/CodeMirror/editorCommands/insertLineAfter.js
|
||||
packages/editor/CodeMirror/editorCommands/insertNewlineContinueMarkup.test.js
|
||||
packages/editor/CodeMirror/editorCommands/insertNewlineContinueMarkup.js
|
||||
packages/editor/CodeMirror/editorCommands/jumpToHash.test.js
|
||||
packages/editor/CodeMirror/editorCommands/jumpToHash.js
|
||||
packages/editor/CodeMirror/editorCommands/markdownCommands.bulletedVsChecklist.test.js
|
||||
packages/editor/CodeMirror/editorCommands/markdownCommands.test.js
|
||||
packages/editor/CodeMirror/editorCommands/markdownCommands.toggleList.test.js
|
||||
packages/editor/CodeMirror/editorCommands/markdownCommands.js
|
||||
packages/editor/CodeMirror/editorCommands/sortSelectedLines.test.js
|
||||
packages/editor/CodeMirror/editorCommands/sortSelectedLines.js
|
||||
packages/editor/CodeMirror/editorCommands/supportsCommand.js
|
||||
packages/editor/CodeMirror/extensions/biDirectionalTextExtension.js
|
||||
packages/editor/CodeMirror/extensions/keyUpHandlerExtension.js
|
||||
packages/editor/CodeMirror/extensions/markdownDecorationExtension.test.js
|
||||
packages/editor/CodeMirror/extensions/markdownDecorationExtension.js
|
||||
packages/editor/CodeMirror/extensions/markdownHighlightExtension.test.js
|
||||
packages/editor/CodeMirror/extensions/markdownHighlightExtension.js
|
||||
packages/editor/CodeMirror/extensions/markdownMathExtension.test.js
|
||||
packages/editor/CodeMirror/extensions/markdownMathExtension.js
|
||||
packages/editor/CodeMirror/extensions/overwriteModeExtension.test.js
|
||||
packages/editor/CodeMirror/extensions/overwriteModeExtension.js
|
||||
packages/editor/CodeMirror/extensions/searchExtension.js
|
||||
packages/editor/CodeMirror/extensions/selectedNoteIdExtension.js
|
||||
packages/editor/CodeMirror/getScrollFraction.js
|
||||
packages/editor/CodeMirror/markdown/MarkdownHighlightExtension.test.js
|
||||
packages/editor/CodeMirror/markdown/MarkdownHighlightExtension.js
|
||||
packages/editor/CodeMirror/markdown/MarkdownMathExtension.test.js
|
||||
packages/editor/CodeMirror/markdown/MarkdownMathExtension.js
|
||||
packages/editor/CodeMirror/markdown/codeBlockLanguages/allLanguages.js
|
||||
packages/editor/CodeMirror/markdown/codeBlockLanguages/defaultLanguage.js
|
||||
packages/editor/CodeMirror/markdown/codeBlockLanguages/lookUpLanguage.js
|
||||
packages/editor/CodeMirror/markdown/computeSelectionFormatting.test.js
|
||||
packages/editor/CodeMirror/markdown/computeSelectionFormatting.js
|
||||
packages/editor/CodeMirror/markdown/decoratorExtension.test.js
|
||||
packages/editor/CodeMirror/markdown/decoratorExtension.js
|
||||
packages/editor/CodeMirror/markdown/insertNewlineContinueMarkup.test.js
|
||||
packages/editor/CodeMirror/markdown/insertNewlineContinueMarkup.js
|
||||
packages/editor/CodeMirror/markdown/markdownCommands.bulletedVsChecklist.test.js
|
||||
packages/editor/CodeMirror/markdown/markdownCommands.test.js
|
||||
packages/editor/CodeMirror/markdown/markdownCommands.toggleList.test.js
|
||||
packages/editor/CodeMirror/markdown/markdownCommands.js
|
||||
packages/editor/CodeMirror/markdown/utils/renumberSelectedLists.test.js
|
||||
packages/editor/CodeMirror/markdown/utils/renumberSelectedLists.js
|
||||
packages/editor/CodeMirror/markdown/utils/stripBlockquote.js
|
||||
packages/editor/CodeMirror/pluginApi/PluginLoader.js
|
||||
packages/editor/CodeMirror/pluginApi/codeMirrorRequire.js
|
||||
packages/editor/CodeMirror/pluginApi/customEditorCompletion.test.js
|
||||
packages/editor/CodeMirror/pluginApi/customEditorCompletion.js
|
||||
packages/editor/CodeMirror/testUtil/createEditorControl.js
|
||||
packages/editor/CodeMirror/testUtil/createEditorSettings.js
|
||||
packages/editor/CodeMirror/testUtil/createTestEditor.js
|
||||
packages/editor/CodeMirror/testUtil/findNodesWithName.js
|
||||
packages/editor/CodeMirror/testUtil/forceFullParse.js
|
||||
packages/editor/CodeMirror/testUtil/loadLanguages.js
|
||||
packages/editor/CodeMirror/testUtil/pressReleaseKey.js
|
||||
packages/editor/CodeMirror/testUtil/typeText.js
|
||||
packages/editor/CodeMirror/testing/createEditorControl.js
|
||||
packages/editor/CodeMirror/testing/createEditorSettings.js
|
||||
packages/editor/CodeMirror/testing/createTestEditor.js
|
||||
packages/editor/CodeMirror/testing/findNodesWithName.js
|
||||
packages/editor/CodeMirror/testing/forceFullParse.js
|
||||
packages/editor/CodeMirror/testing/loadLanguages.js
|
||||
packages/editor/CodeMirror/testing/pressReleaseKey.js
|
||||
packages/editor/CodeMirror/testing/typeText.js
|
||||
packages/editor/CodeMirror/theme.js
|
||||
packages/editor/CodeMirror/utils/biDirectionalTextExtension.js
|
||||
packages/editor/CodeMirror/utils/formatting/RegionSpec.js
|
||||
packages/editor/CodeMirror/utils/formatting/computeSelectionFormatting.test.js
|
||||
packages/editor/CodeMirror/utils/formatting/computeSelectionFormatting.js
|
||||
packages/editor/CodeMirror/utils/formatting/findInlineMatch.test.js
|
||||
packages/editor/CodeMirror/utils/formatting/findInlineMatch.js
|
||||
packages/editor/CodeMirror/utils/formatting/isIndentationEquivalent.js
|
||||
@@ -1021,11 +1020,12 @@ packages/editor/CodeMirror/utils/handleLinkEditRequests.js
|
||||
packages/editor/CodeMirror/utils/handlePasteEvent.js
|
||||
packages/editor/CodeMirror/utils/isCursorAtBeginning.js
|
||||
packages/editor/CodeMirror/utils/isInSyntaxNode.js
|
||||
packages/editor/CodeMirror/utils/keyUpHandlerExtension.js
|
||||
packages/editor/CodeMirror/utils/overwriteModeExtension.test.js
|
||||
packages/editor/CodeMirror/utils/overwriteModeExtension.js
|
||||
packages/editor/CodeMirror/utils/searchExtension.js
|
||||
packages/editor/CodeMirror/utils/selectedNoteIdExtension.js
|
||||
packages/editor/CodeMirror/utils/markdown/codeBlockLanguages/allLanguages.js
|
||||
packages/editor/CodeMirror/utils/markdown/codeBlockLanguages/defaultLanguage.js
|
||||
packages/editor/CodeMirror/utils/markdown/codeBlockLanguages/lookUpLanguage.js
|
||||
packages/editor/CodeMirror/utils/markdown/renumberSelectedLists.test.js
|
||||
packages/editor/CodeMirror/utils/markdown/renumberSelectedLists.js
|
||||
packages/editor/CodeMirror/utils/markdown/stripBlockquote.js
|
||||
packages/editor/CodeMirror/utils/setupVim.js
|
||||
packages/editor/SelectionFormatting.js
|
||||
packages/editor/events.js
|
||||
|
68
.gitignore
vendored
68
.gitignore
vendored
@@ -937,47 +937,46 @@ packages/editor/CodeMirror/editorCommands/duplicateLine.js
|
||||
packages/editor/CodeMirror/editorCommands/editorCommands.js
|
||||
packages/editor/CodeMirror/editorCommands/insertLineAfter.test.js
|
||||
packages/editor/CodeMirror/editorCommands/insertLineAfter.js
|
||||
packages/editor/CodeMirror/editorCommands/insertNewlineContinueMarkup.test.js
|
||||
packages/editor/CodeMirror/editorCommands/insertNewlineContinueMarkup.js
|
||||
packages/editor/CodeMirror/editorCommands/jumpToHash.test.js
|
||||
packages/editor/CodeMirror/editorCommands/jumpToHash.js
|
||||
packages/editor/CodeMirror/editorCommands/markdownCommands.bulletedVsChecklist.test.js
|
||||
packages/editor/CodeMirror/editorCommands/markdownCommands.test.js
|
||||
packages/editor/CodeMirror/editorCommands/markdownCommands.toggleList.test.js
|
||||
packages/editor/CodeMirror/editorCommands/markdownCommands.js
|
||||
packages/editor/CodeMirror/editorCommands/sortSelectedLines.test.js
|
||||
packages/editor/CodeMirror/editorCommands/sortSelectedLines.js
|
||||
packages/editor/CodeMirror/editorCommands/supportsCommand.js
|
||||
packages/editor/CodeMirror/extensions/biDirectionalTextExtension.js
|
||||
packages/editor/CodeMirror/extensions/keyUpHandlerExtension.js
|
||||
packages/editor/CodeMirror/extensions/markdownDecorationExtension.test.js
|
||||
packages/editor/CodeMirror/extensions/markdownDecorationExtension.js
|
||||
packages/editor/CodeMirror/extensions/markdownHighlightExtension.test.js
|
||||
packages/editor/CodeMirror/extensions/markdownHighlightExtension.js
|
||||
packages/editor/CodeMirror/extensions/markdownMathExtension.test.js
|
||||
packages/editor/CodeMirror/extensions/markdownMathExtension.js
|
||||
packages/editor/CodeMirror/extensions/overwriteModeExtension.test.js
|
||||
packages/editor/CodeMirror/extensions/overwriteModeExtension.js
|
||||
packages/editor/CodeMirror/extensions/searchExtension.js
|
||||
packages/editor/CodeMirror/extensions/selectedNoteIdExtension.js
|
||||
packages/editor/CodeMirror/getScrollFraction.js
|
||||
packages/editor/CodeMirror/markdown/MarkdownHighlightExtension.test.js
|
||||
packages/editor/CodeMirror/markdown/MarkdownHighlightExtension.js
|
||||
packages/editor/CodeMirror/markdown/MarkdownMathExtension.test.js
|
||||
packages/editor/CodeMirror/markdown/MarkdownMathExtension.js
|
||||
packages/editor/CodeMirror/markdown/codeBlockLanguages/allLanguages.js
|
||||
packages/editor/CodeMirror/markdown/codeBlockLanguages/defaultLanguage.js
|
||||
packages/editor/CodeMirror/markdown/codeBlockLanguages/lookUpLanguage.js
|
||||
packages/editor/CodeMirror/markdown/computeSelectionFormatting.test.js
|
||||
packages/editor/CodeMirror/markdown/computeSelectionFormatting.js
|
||||
packages/editor/CodeMirror/markdown/decoratorExtension.test.js
|
||||
packages/editor/CodeMirror/markdown/decoratorExtension.js
|
||||
packages/editor/CodeMirror/markdown/insertNewlineContinueMarkup.test.js
|
||||
packages/editor/CodeMirror/markdown/insertNewlineContinueMarkup.js
|
||||
packages/editor/CodeMirror/markdown/markdownCommands.bulletedVsChecklist.test.js
|
||||
packages/editor/CodeMirror/markdown/markdownCommands.test.js
|
||||
packages/editor/CodeMirror/markdown/markdownCommands.toggleList.test.js
|
||||
packages/editor/CodeMirror/markdown/markdownCommands.js
|
||||
packages/editor/CodeMirror/markdown/utils/renumberSelectedLists.test.js
|
||||
packages/editor/CodeMirror/markdown/utils/renumberSelectedLists.js
|
||||
packages/editor/CodeMirror/markdown/utils/stripBlockquote.js
|
||||
packages/editor/CodeMirror/pluginApi/PluginLoader.js
|
||||
packages/editor/CodeMirror/pluginApi/codeMirrorRequire.js
|
||||
packages/editor/CodeMirror/pluginApi/customEditorCompletion.test.js
|
||||
packages/editor/CodeMirror/pluginApi/customEditorCompletion.js
|
||||
packages/editor/CodeMirror/testUtil/createEditorControl.js
|
||||
packages/editor/CodeMirror/testUtil/createEditorSettings.js
|
||||
packages/editor/CodeMirror/testUtil/createTestEditor.js
|
||||
packages/editor/CodeMirror/testUtil/findNodesWithName.js
|
||||
packages/editor/CodeMirror/testUtil/forceFullParse.js
|
||||
packages/editor/CodeMirror/testUtil/loadLanguages.js
|
||||
packages/editor/CodeMirror/testUtil/pressReleaseKey.js
|
||||
packages/editor/CodeMirror/testUtil/typeText.js
|
||||
packages/editor/CodeMirror/testing/createEditorControl.js
|
||||
packages/editor/CodeMirror/testing/createEditorSettings.js
|
||||
packages/editor/CodeMirror/testing/createTestEditor.js
|
||||
packages/editor/CodeMirror/testing/findNodesWithName.js
|
||||
packages/editor/CodeMirror/testing/forceFullParse.js
|
||||
packages/editor/CodeMirror/testing/loadLanguages.js
|
||||
packages/editor/CodeMirror/testing/pressReleaseKey.js
|
||||
packages/editor/CodeMirror/testing/typeText.js
|
||||
packages/editor/CodeMirror/theme.js
|
||||
packages/editor/CodeMirror/utils/biDirectionalTextExtension.js
|
||||
packages/editor/CodeMirror/utils/formatting/RegionSpec.js
|
||||
packages/editor/CodeMirror/utils/formatting/computeSelectionFormatting.test.js
|
||||
packages/editor/CodeMirror/utils/formatting/computeSelectionFormatting.js
|
||||
packages/editor/CodeMirror/utils/formatting/findInlineMatch.test.js
|
||||
packages/editor/CodeMirror/utils/formatting/findInlineMatch.js
|
||||
packages/editor/CodeMirror/utils/formatting/isIndentationEquivalent.js
|
||||
@@ -996,11 +995,12 @@ packages/editor/CodeMirror/utils/handleLinkEditRequests.js
|
||||
packages/editor/CodeMirror/utils/handlePasteEvent.js
|
||||
packages/editor/CodeMirror/utils/isCursorAtBeginning.js
|
||||
packages/editor/CodeMirror/utils/isInSyntaxNode.js
|
||||
packages/editor/CodeMirror/utils/keyUpHandlerExtension.js
|
||||
packages/editor/CodeMirror/utils/overwriteModeExtension.test.js
|
||||
packages/editor/CodeMirror/utils/overwriteModeExtension.js
|
||||
packages/editor/CodeMirror/utils/searchExtension.js
|
||||
packages/editor/CodeMirror/utils/selectedNoteIdExtension.js
|
||||
packages/editor/CodeMirror/utils/markdown/codeBlockLanguages/allLanguages.js
|
||||
packages/editor/CodeMirror/utils/markdown/codeBlockLanguages/defaultLanguage.js
|
||||
packages/editor/CodeMirror/utils/markdown/codeBlockLanguages/lookUpLanguage.js
|
||||
packages/editor/CodeMirror/utils/markdown/renumberSelectedLists.test.js
|
||||
packages/editor/CodeMirror/utils/markdown/renumberSelectedLists.js
|
||||
packages/editor/CodeMirror/utils/markdown/stripBlockquote.js
|
||||
packages/editor/CodeMirror/utils/setupVim.js
|
||||
packages/editor/SelectionFormatting.js
|
||||
packages/editor/events.js
|
||||
|
@@ -3,7 +3,7 @@
|
||||
import CommandService from '@joplin/lib/services/CommandService';
|
||||
import useEditorCommandHandler from './useEditorCommandHandler';
|
||||
import commandDeclarations from '../commandDeclarations';
|
||||
import createTestEditorControl from '@joplin/editor/CodeMirror/testUtil/createEditorControl';
|
||||
import createTestEditorControl from '@joplin/editor/CodeMirror/testing/createEditorControl';
|
||||
import { renderHook } from '../../../utils/testing/testingLibrary';
|
||||
import { defaultState } from '@joplin/lib/reducer';
|
||||
|
||||
|
@@ -1,7 +1,7 @@
|
||||
import { ViewPlugin } from '@codemirror/view';
|
||||
import createEditorControl from './testUtil/createEditorControl';
|
||||
import createEditorControl from './testing/createEditorControl';
|
||||
import { EditorCommandType } from '../types';
|
||||
import pressReleaseKey from './testUtil/pressReleaseKey';
|
||||
import pressReleaseKey from './testing/pressReleaseKey';
|
||||
import { EditorSelection, EditorState } from '@codemirror/state';
|
||||
|
||||
describe('CodeMirrorControl', () => {
|
||||
|
@@ -3,7 +3,7 @@ import { EditorCommandType, EditorControl, EditorSettings, LogMessageCallback, C
|
||||
import CodeMirror5Emulation from './CodeMirror5Emulation/CodeMirror5Emulation';
|
||||
import editorCommands from './editorCommands/editorCommands';
|
||||
import { Compartment, EditorSelection, Extension, StateEffect } from '@codemirror/state';
|
||||
import { updateLink } from './markdown/markdownCommands';
|
||||
import { updateLink } from './editorCommands/markdownCommands';
|
||||
import { searchPanelOpen, SearchQuery, setSearchQuery } from '@codemirror/search';
|
||||
import PluginLoader from './pluginApi/PluginLoader';
|
||||
import customEditorCompletion, { editorCompletionSource, enableLanguageDataAutocomplete } from './pluginApi/customEditorCompletion';
|
||||
@@ -11,7 +11,7 @@ import { CompletionSource } from '@codemirror/autocomplete';
|
||||
import { RegionSpec } from './utils/formatting/RegionSpec';
|
||||
import toggleInlineSelectionFormat from './utils/formatting/toggleInlineSelectionFormat';
|
||||
import getSearchState from './utils/getSearchState';
|
||||
import { noteIdFacet, setNoteIdEffect } from './utils/selectedNoteIdExtension';
|
||||
import { noteIdFacet, setNoteIdEffect } from './extensions/selectedNoteIdExtension';
|
||||
import jumpToHash from './editorCommands/jumpToHash';
|
||||
|
||||
interface Callbacks {
|
||||
|
@@ -5,15 +5,15 @@ import createTheme from './theme';
|
||||
import { EditorState } from '@codemirror/state';
|
||||
import { deleteMarkupBackward, markdown, markdownLanguage } from '@codemirror/lang-markdown';
|
||||
import { GFM as GitHubFlavoredMarkdownExtension } from '@lezer/markdown';
|
||||
import MarkdownMathExtension from './markdown/MarkdownMathExtension';
|
||||
import MarkdownHighlightExtension from './markdown/MarkdownHighlightExtension';
|
||||
import lookUpLanguage from './markdown/codeBlockLanguages/lookUpLanguage';
|
||||
import markdownMathExtension from './extensions/markdownMathExtension';
|
||||
import markdownHighlightExtension from './extensions/markdownHighlightExtension';
|
||||
import lookUpLanguage from './utils/markdown/codeBlockLanguages/lookUpLanguage';
|
||||
import { html } from '@codemirror/lang-html';
|
||||
import { defaultKeymap, emacsStyleKeymap } from '@codemirror/commands';
|
||||
import { vim } from '@replit/codemirror-vim';
|
||||
import { indentUnit } from '@codemirror/language';
|
||||
import { Prec } from '@codemirror/state';
|
||||
import insertNewlineContinueMarkup from './markdown/insertNewlineContinueMarkup';
|
||||
import insertNewlineContinueMarkup from './editorCommands/insertNewlineContinueMarkup';
|
||||
|
||||
const configFromSettings = (settings: EditorSettings) => {
|
||||
const languageExtension = (() => {
|
||||
@@ -26,10 +26,10 @@ const configFromSettings = (settings: EditorSettings) => {
|
||||
extensions: [
|
||||
GitHubFlavoredMarkdownExtension,
|
||||
|
||||
settings.markdownMarkEnabled ? MarkdownHighlightExtension : [],
|
||||
settings.markdownMarkEnabled ? markdownHighlightExtension : [],
|
||||
|
||||
// Don't highlight KaTeX if the user disabled it
|
||||
settings.katexEnabled ? MarkdownMathExtension : [],
|
||||
settings.katexEnabled ? markdownMathExtension : [],
|
||||
],
|
||||
codeLanguages: lookUpLanguage,
|
||||
|
||||
|
@@ -5,10 +5,10 @@
|
||||
import createEditor from './createEditor';
|
||||
import Setting from '@joplin/lib/models/Setting';
|
||||
import { forceParsing } from '@codemirror/language';
|
||||
import loadLanguages from './testUtil/loadLanguages';
|
||||
import loadLanguages from './testing/loadLanguages';
|
||||
|
||||
import { expect, describe, it } from '@jest/globals';
|
||||
import createEditorSettings from './testUtil/createEditorSettings';
|
||||
import createEditorSettings from './testing/createEditorSettings';
|
||||
|
||||
|
||||
describe('createEditor', () => {
|
||||
|
@@ -21,21 +21,21 @@ import {
|
||||
insertOrIncreaseIndent,
|
||||
toggleBolded, toggleCode,
|
||||
toggleItalicized, toggleMath,
|
||||
} from './markdown/markdownCommands';
|
||||
import decoratorExtension from './markdown/decoratorExtension';
|
||||
import computeSelectionFormatting from './markdown/computeSelectionFormatting';
|
||||
} from './editorCommands/markdownCommands';
|
||||
import decoratorExtension from './extensions/markdownDecorationExtension';
|
||||
import computeSelectionFormatting from './utils/formatting/computeSelectionFormatting';
|
||||
import { selectionFormattingEqual } from '../SelectionFormatting';
|
||||
import configFromSettings from './configFromSettings';
|
||||
import getScrollFraction from './getScrollFraction';
|
||||
import CodeMirrorControl from './CodeMirrorControl';
|
||||
import insertLineAfter from './editorCommands/insertLineAfter';
|
||||
import handlePasteEvent from './utils/handlePasteEvent';
|
||||
import biDirectionalTextExtension from './utils/biDirectionalTextExtension';
|
||||
import searchExtension from './utils/searchExtension';
|
||||
import biDirectionalTextExtension from './extensions/biDirectionalTextExtension';
|
||||
import searchExtension from './extensions/searchExtension';
|
||||
import isCursorAtBeginning from './utils/isCursorAtBeginning';
|
||||
import overwriteModeExtension from './utils/overwriteModeExtension';
|
||||
import overwriteModeExtension from './extensions/overwriteModeExtension';
|
||||
import handleLinkEditRequests, { showLinkEditor } from './utils/handleLinkEditRequests';
|
||||
import selectedNoteIdExtension, { setNoteIdEffect } from './utils/selectedNoteIdExtension';
|
||||
import selectedNoteIdExtension, { setNoteIdEffect } from './extensions/selectedNoteIdExtension';
|
||||
|
||||
// Newer versions of CodeMirror by default use Chrome's EditContext API.
|
||||
// While this might be stable enough for desktop use, it causes significant
|
||||
|
@@ -7,7 +7,7 @@ import {
|
||||
toggleBolded, toggleCode,
|
||||
toggleHeaderLevel, toggleItalicized,
|
||||
toggleList, toggleMath,
|
||||
} from '../markdown/markdownCommands';
|
||||
} from './markdownCommands';
|
||||
import duplicateLine from './duplicateLine';
|
||||
import sortSelectedLines from './sortSelectedLines';
|
||||
import { closeSearchPanel, findNext, findPrevious, openSearchPanel, replaceAll, replaceNext, searchPanelOpen } from '@codemirror/search';
|
||||
|
@@ -1,5 +1,5 @@
|
||||
import { EditorSelection } from '@codemirror/state';
|
||||
import createTestEditor from '../testUtil/createTestEditor';
|
||||
import createTestEditor from '../testing/createTestEditor';
|
||||
import insertLineAfter from './insertLineAfter';
|
||||
|
||||
describe('insertLineAfter', () => {
|
||||
|
@@ -1,7 +1,7 @@
|
||||
import { insertNewlineAndIndent } from '@codemirror/commands';
|
||||
import { EditorSelection, SelectionRange } from '@codemirror/state';
|
||||
import { EditorView } from '@codemirror/view';
|
||||
import insertNewlineContinueMarkup from '../markdown/insertNewlineContinueMarkup';
|
||||
import insertNewlineContinueMarkup from './insertNewlineContinueMarkup';
|
||||
|
||||
const insertLineAfter = (view: EditorView) => {
|
||||
const state = view.state;
|
||||
|
@@ -1,6 +1,6 @@
|
||||
import { EditorSelection } from '@codemirror/state';
|
||||
import createTestEditor from '../testUtil/createTestEditor';
|
||||
import pressReleaseKey from '../testUtil/pressReleaseKey';
|
||||
import createTestEditor from '../testing/createTestEditor';
|
||||
import pressReleaseKey from '../testing/pressReleaseKey';
|
||||
import { keymap } from '@codemirror/view';
|
||||
import insertNewlineContinueMarkup from './insertNewlineContinueMarkup';
|
||||
|
@@ -1,5 +1,5 @@
|
||||
import { EditorSelection } from '@codemirror/state';
|
||||
import createTestEditor from '../testUtil/createTestEditor';
|
||||
import createTestEditor from '../testing/createTestEditor';
|
||||
import jumpToHash from './jumpToHash';
|
||||
|
||||
describe('jumpToHash', () => {
|
||||
|
@@ -1,7 +1,7 @@
|
||||
import { EditorSelection } from '@codemirror/state';
|
||||
import { ListType } from '../../types';
|
||||
import createTestEditor from '../testUtil/createTestEditor';
|
||||
import { toggleList } from './markdownCommands';
|
||||
import createTestEditor from '../testing/createTestEditor';
|
||||
import { toggleList } from '../editorCommands/markdownCommands';
|
||||
|
||||
describe('markdownCommands.bulletedVsChecklist', () => {
|
||||
|
@@ -3,9 +3,9 @@ import {
|
||||
insertHorizontalRule,
|
||||
insertOrIncreaseIndent,
|
||||
toggleBolded, toggleCode, toggleHeaderLevel, toggleItalicized, toggleMath, updateLink,
|
||||
} from './markdownCommands';
|
||||
import createTestEditor from '../testUtil/createTestEditor';
|
||||
import { blockMathTagName } from './MarkdownMathExtension';
|
||||
} from '../editorCommands/markdownCommands';
|
||||
import createTestEditor from '../testing/createTestEditor';
|
||||
import { blockMathTagName } from '../extensions/markdownMathExtension';
|
||||
|
||||
describe('markdownCommands', () => {
|
||||
|
@@ -1,9 +1,7 @@
|
||||
import { EditorSelection, EditorState } from '@codemirror/state';
|
||||
import {
|
||||
increaseIndent, toggleList,
|
||||
} from './markdownCommands';
|
||||
import { increaseIndent, toggleList } from '../editorCommands/markdownCommands';
|
||||
import { ListType } from '../../types';
|
||||
import createTestEditor from '../testUtil/createTestEditor';
|
||||
import createTestEditor from '../testing/createTestEditor';
|
||||
|
||||
describe('markdownCommands.toggleList', () => {
|
||||
|
@@ -11,8 +11,8 @@ import intersectsSyntaxNode from '../utils/isInSyntaxNode';
|
||||
import toggleRegionFormatGlobally from '../utils/formatting/toggleRegionFormatGlobally';
|
||||
import { RegionSpec } from '../utils/formatting/RegionSpec';
|
||||
import toggleInlineFormatGlobally from '../utils/formatting/toggleInlineFormatGlobally';
|
||||
import stripBlockquote from './utils/stripBlockquote';
|
||||
import renumberSelectedLists from './utils/renumberSelectedLists';
|
||||
import stripBlockquote from '../utils/markdown/stripBlockquote';
|
||||
import renumberSelectedLists from '../utils/markdown/renumberSelectedLists';
|
||||
import toggleSelectedLinesStartWith from '../utils/formatting/toggleSelectedLinesStartWith';
|
||||
|
||||
|
@@ -1,6 +1,6 @@
|
||||
import { EditorSelection } from '@codemirror/state';
|
||||
import createTestEditor from '../testUtil/createTestEditor';
|
||||
import decoratorExtension from './decoratorExtension';
|
||||
import createTestEditor from '../testing/createTestEditor';
|
||||
import decoratorExtension from './markdownDecorationExtension';
|
||||
|
||||
jest.retryTimes(2);
|
||||
|
@@ -1,8 +1,8 @@
|
||||
import { EditorSelection, EditorState } from '@codemirror/state';
|
||||
|
||||
import createTestEditor from '../testUtil/createTestEditor';
|
||||
import findNodesWithName from '../testUtil/findNodesWithName';
|
||||
import { highlightMarkerTagName, highlightTagName } from './MarkdownHighlightExtension';
|
||||
import createTestEditor from '../testing/createTestEditor';
|
||||
import findNodesWithName from '../testing/findNodesWithName';
|
||||
import { highlightMarkerTagName, highlightTagName } from './markdownHighlightExtension';
|
||||
|
||||
const createEditorState = async (initialText: string, expectedTags: string[]): Promise<EditorState> => {
|
||||
return (await createTestEditor(initialText, EditorSelection.cursor(0), expectedTags)).state;
|
@@ -1,5 +1,5 @@
|
||||
import { tags, Tag } from '@lezer/highlight';
|
||||
import { MarkdownConfig, InlineContext } from '@lezer/markdown';
|
||||
import { MarkdownConfig, InlineContext, MarkdownExtension } from '@lezer/markdown';
|
||||
|
||||
const equalsSignCharcode = 61;
|
||||
|
||||
@@ -16,7 +16,7 @@ const isSpaceOrEmpty = (text: string) => text.match(/^\s*$/);
|
||||
// Markdown extension for recognizing highlighting. This is similar to the upstream
|
||||
// extension for strikethrough:
|
||||
// https://github.com/lezer-parser/markdown/blob/d6f0aa095722329a0188b9c7afe207dab4835e55/src/extension.ts#L10
|
||||
const HighlightConfig: MarkdownConfig = {
|
||||
const highlightConfig: MarkdownConfig = {
|
||||
defineNodes: [
|
||||
{
|
||||
name: highlightTagName,
|
||||
@@ -59,7 +59,7 @@ const HighlightConfig: MarkdownConfig = {
|
||||
}],
|
||||
};
|
||||
|
||||
const MarkdownHighlightExtension: MarkdownConfig[] = [
|
||||
HighlightConfig,
|
||||
const markdownHighlightExtension: MarkdownExtension = [
|
||||
highlightConfig,
|
||||
];
|
||||
export default MarkdownHighlightExtension;
|
||||
export default markdownHighlightExtension;
|
@@ -1,8 +1,8 @@
|
||||
import { EditorSelection, EditorState } from '@codemirror/state';
|
||||
import { blockMathTagName, inlineMathContentTagName, inlineMathTagName } from './MarkdownMathExtension';
|
||||
import { blockMathTagName, inlineMathContentTagName, inlineMathTagName } from './markdownMathExtension';
|
||||
|
||||
import createTestEditor from '../testUtil/createTestEditor';
|
||||
import findNodesWithName from '../testUtil/findNodesWithName';
|
||||
import createTestEditor from '../testing/createTestEditor';
|
||||
import findNodesWithName from '../testing/findNodesWithName';
|
||||
|
||||
// Creates an EditorState with math and markdown extensions
|
||||
const createEditorState = async (initialText: string, expectedTags: string[]): Promise<EditorState> => {
|
@@ -10,6 +10,7 @@ import { parseMixed, SyntaxNodeRef, Input, NestedParse, ParseWrapper } from '@le
|
||||
import {
|
||||
MarkdownConfig, InlineContext,
|
||||
BlockContext, Line, LeafBlock,
|
||||
MarkdownExtension,
|
||||
} from '@lezer/markdown';
|
||||
|
||||
// The existing stexMath parser is used to parse the text between the $s
|
||||
@@ -50,7 +51,7 @@ const wrappedTeXParser = (nodeTag: string): ParseWrapper => {
|
||||
};
|
||||
|
||||
// Markdown extension for recognizing inline code
|
||||
const InlineMathConfig: MarkdownConfig = {
|
||||
const inlineMathConfig: MarkdownConfig = {
|
||||
defineNodes: [
|
||||
{
|
||||
name: inlineMathTagName,
|
||||
@@ -120,7 +121,7 @@ const InlineMathConfig: MarkdownConfig = {
|
||||
};
|
||||
|
||||
// Extension for recognising block code
|
||||
const BlockMathConfig: MarkdownConfig = {
|
||||
const blockMathConfig: MarkdownConfig = {
|
||||
defineNodes: [
|
||||
{
|
||||
name: blockMathTagName,
|
||||
@@ -206,9 +207,9 @@ const BlockMathConfig: MarkdownConfig = {
|
||||
};
|
||||
|
||||
// Markdown configuration for block and inline math support.
|
||||
const MarkdownMathExtension: MarkdownConfig[] = [
|
||||
InlineMathConfig,
|
||||
BlockMathConfig,
|
||||
const markdownMathExtension: MarkdownExtension = [
|
||||
inlineMathConfig,
|
||||
blockMathConfig,
|
||||
];
|
||||
|
||||
export default MarkdownMathExtension;
|
||||
export default markdownMathExtension;
|
@@ -1,8 +1,8 @@
|
||||
import { EditorSelection } from '@codemirror/state';
|
||||
import createTestEditor from '../testUtil/createTestEditor';
|
||||
import createTestEditor from '../testing/createTestEditor';
|
||||
import overwriteModeExtension, { overwriteModeEnabled, toggleOverwrite } from './overwriteModeExtension';
|
||||
import typeText from '../testUtil/typeText';
|
||||
import pressReleaseKey from '../testUtil/pressReleaseKey';
|
||||
import typeText from '../testing/typeText';
|
||||
import pressReleaseKey from '../testing/pressReleaseKey';
|
||||
|
||||
const createEditor = async (initialText: string, defaultEnabled = false) => {
|
||||
const editor = await createTestEditor(initialText, EditorSelection.cursor(0), [], [
|
@@ -1,7 +1,7 @@
|
||||
import { EditorState, Extension } from '@codemirror/state';
|
||||
import { EditorView } from '@codemirror/view';
|
||||
import { EditorSettings, OnEventCallback } from '../../types';
|
||||
import getSearchState from './getSearchState';
|
||||
import getSearchState from '../utils/getSearchState';
|
||||
import { EditorEventType } from '../../events';
|
||||
import { search, searchPanelOpen, setSearchQuery } from '@codemirror/search';
|
||||
|
@@ -1,8 +1,8 @@
|
||||
import { EditorState, StateEffect } from '@codemirror/state';
|
||||
import createEditorControl from '../testUtil/createEditorControl';
|
||||
import createEditorControl from '../testing/createEditorControl';
|
||||
import { EditorView } from '@codemirror/view';
|
||||
import { completeFromList, completionStatus, currentCompletions } from '@codemirror/autocomplete';
|
||||
import typeText from '../testUtil/typeText';
|
||||
import typeText from '../testing/typeText';
|
||||
|
||||
const waitForShownCompletionsToContain = (editor: EditorView, completionLabels: string[]) => {
|
||||
return new Promise<string[]>(resolve => {
|
||||
|
@@ -3,10 +3,10 @@ import { GFM as GithubFlavoredMarkdownExt } from '@lezer/markdown';
|
||||
import { indentUnit, syntaxTree } from '@codemirror/language';
|
||||
import { SelectionRange, EditorSelection, EditorState, Extension } from '@codemirror/state';
|
||||
import { EditorView } from '@codemirror/view';
|
||||
import MarkdownMathExtension from '../markdown/MarkdownMathExtension';
|
||||
import forceFullParse from './forceFullParse';
|
||||
import loadLanguages from './loadLanguages';
|
||||
import MarkdownHighlightExtension from '../markdown/MarkdownHighlightExtension';
|
||||
import markdownMathExtension from '../extensions/markdownMathExtension';
|
||||
import markdownHighlightExtension from '../extensions/markdownHighlightExtension';
|
||||
|
||||
// Creates and returns a minimal editor with markdown extensions. Waits to return the editor
|
||||
// until all syntax tree tags in `expectedSyntaxTreeTags` exist.
|
||||
@@ -26,7 +26,7 @@ const createTestEditor = async (
|
||||
selection: EditorSelection.create(initialSelection),
|
||||
extensions: [
|
||||
markdown({
|
||||
extensions: [MarkdownMathExtension, MarkdownHighlightExtension, GithubFlavoredMarkdownExt],
|
||||
extensions: [markdownMathExtension, markdownHighlightExtension, GithubFlavoredMarkdownExt],
|
||||
addKeymap: addMarkdownKeymap,
|
||||
}),
|
||||
indentUnit.of('\t'),
|
@@ -1,4 +1,4 @@
|
||||
import allLanguages from '../markdown/codeBlockLanguages/allLanguages';
|
||||
import allLanguages from '../utils/markdown/codeBlockLanguages/allLanguages';
|
||||
|
||||
// Ensure languages we use are loaded. Without this, tests may randomly fail (LanguageDescriptions
|
||||
// are loaded asynchronously, in the background).
|
2
packages/editor/CodeMirror/theme.ts
vendored
2
packages/editor/CodeMirror/theme.ts
vendored
@@ -8,7 +8,7 @@ import { tags } from '@lezer/highlight';
|
||||
import { EditorView } from '@codemirror/view';
|
||||
import { Extension } from '@codemirror/state';
|
||||
|
||||
import { inlineMathTag, mathTag } from './markdown/MarkdownMathExtension';
|
||||
import { inlineMathTag, mathTag } from './extensions/markdownMathExtension';
|
||||
import { EditorTheme } from '../types';
|
||||
|
||||
// For an example on how to customize the theme, see:
|
||||
|
@@ -1,5 +1,5 @@
|
||||
import { EditorSelection } from '@codemirror/state';
|
||||
import createTestEditor from '../testUtil/createTestEditor';
|
||||
import createTestEditor from '../../testing/createTestEditor';
|
||||
import computeSelectionFormatting from './computeSelectionFormatting';
|
||||
|
||||
|
@@ -1,4 +1,4 @@
|
||||
import SelectionFormatting, { MutableSelectionFormatting, defaultSelectionFormatting } from '../../SelectionFormatting';
|
||||
import SelectionFormatting, { MutableSelectionFormatting, defaultSelectionFormatting } from '../../../SelectionFormatting';
|
||||
import { syntaxTree } from '@codemirror/language';
|
||||
import { EditorState } from '@codemirror/state';
|
||||
|
@@ -1,5 +1,5 @@
|
||||
import { EditorSelection } from '@codemirror/state';
|
||||
import createTestEditor from '../../testUtil/createTestEditor';
|
||||
import createTestEditor from '../../testing/createTestEditor';
|
||||
import renumberSelectedLists from './renumberSelectedLists';
|
||||
|
||||
describe('renumberSelectedLists', () => {
|
Reference in New Issue
Block a user