@worktile/theia 2.1.7 → 2.1.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/worktile-theia.umd.js +60 -21
- package/bundles/worktile-theia.umd.js.map +1 -1
- package/editor.module.d.ts +2 -2
- package/esm2015/plugins/common/move-selection.plugin.js +2 -2
- package/esm2015/plugins/inline-code/inline-code.component.js +14 -15
- package/esm2015/plugins/inline-code/inline-code.editor.js +7 -3
- package/esm2015/plugins/inline-code/inline-code.plugin.js +40 -2
- package/esm2015/plugins/link/link.component.js +15 -3
- package/fesm2015/worktile-theia.js +71 -20
- package/fesm2015/worktile-theia.js.map +1 -1
- package/package.json +1 -1
- package/plugins/inline-code/inline-code.component.d.ts +2 -7
- package/plugins/inline-code/inline-code.editor.d.ts +2 -2
- package/plugins/link/link.component.d.ts +1 -0
package/editor.module.d.ts
CHANGED
|
@@ -12,7 +12,7 @@ import { TheNumberedListComponent } from './plugins/list/components/numbered-lis
|
|
|
12
12
|
import { TheColorSelectComponent } from './components/color-select/color-select.component';
|
|
13
13
|
import { TheColorToolbarItemComponent } from './plugins/color/toolbar-item.component';
|
|
14
14
|
import { TheCodeComponent } from './plugins/code/code.component';
|
|
15
|
-
import {
|
|
15
|
+
import { TheReadonlyLinkComponent } from './plugins/link/link.component';
|
|
16
16
|
import { TheLinkEditComponent } from './plugins/link/edit/link-edit.component';
|
|
17
17
|
import { TheLinkHoverComponent } from './plugins/link/hover/link-hover.component';
|
|
18
18
|
import { TheTableToolbarComponent } from './plugins/table/components/toolbar/table-toolbar.component';
|
|
@@ -89,7 +89,7 @@ import * as i57 from "ngx-tethys/switch";
|
|
|
89
89
|
import * as i58 from "ng-codemirror";
|
|
90
90
|
import * as i59 from "./components/column-resize/column-resize.module";
|
|
91
91
|
export declare const COMPONENTS: (typeof TheColorSelectComponent | typeof TheContextMenuComponent | typeof TheToolbarGroupComponent | typeof TheTextComponent | typeof TheDefaultElementComponent | typeof TheConversionHintComponent | typeof TheColorToolbarItemComponent | typeof TheTableSelectComponent | typeof TheTableToolbarItemComponent | typeof TheVerticalToolbarItemComponent | typeof TheQuickToolbarComponent | typeof TheToolbarItemComponent | typeof NavSplitLineComponent | typeof TheToolbarDropdownComponent | typeof TheToolbarComponent | typeof TheQuickInsertComponent | typeof TheInsertMarkComponent | typeof TheInlineToolbarComponent)[];
|
|
92
|
-
export declare const PLUGIN_COMPONENTS: (typeof TheTableToolbarComponent | typeof TheTableComponent | typeof TheImageComponent | typeof TheNumberedListComponent | typeof TheBulletedListComponent | typeof TheBlockquoteComponent | typeof TheCodeComponent | typeof TheLinkHoverComponent | typeof TheLinkEditComponent | typeof
|
|
92
|
+
export declare const PLUGIN_COMPONENTS: (typeof TheTableToolbarComponent | typeof TheTableComponent | typeof TheImageComponent | typeof TheNumberedListComponent | typeof TheBulletedListComponent | typeof TheBlockquoteComponent | typeof TheCodeComponent | typeof TheLinkHoverComponent | typeof TheLinkEditComponent | typeof TheReadonlyLinkComponent | typeof TheTdComponent | typeof TheTemplateComponent)[];
|
|
93
93
|
export declare class TheEditorModule {
|
|
94
94
|
static ɵfac: i0.ɵɵFactoryDeclaration<TheEditorModule, never>;
|
|
95
95
|
static ɵmod: i0.ɵɵNgModuleDeclaration<TheEditorModule, [typeof i1.TheEditorComponent, typeof i2.ElementStylePipe, typeof i2.ElementClassPipe, typeof i3.TheToolbarComponent, typeof i4.TheToolbarDropdownComponent, typeof i5.TheToolbarGroupComponent, typeof i6.TheToolbarItemComponent, typeof i7.TheInlineToolbarComponent, typeof i8.NavSplitLineComponent, typeof i9.TheTextComponent, typeof i10.TheDefaultElementComponent, typeof i11.TheQuickInsertComponent, typeof i12.TheQuickToolbarComponent, typeof i13.TheColorSelectComponent, typeof i14.TheColorToolbarItemComponent, typeof i15.TheContextMenuComponent, typeof i16.TheInsertMarkComponent, typeof i17.TheTableSelectComponent, typeof i18.TheTableToolbarItemComponent, typeof i19.TheConversionHintComponent, typeof i20.TheVerticalToolbarItemComponent, typeof i21.TheImageComponent, typeof i22.TheTemplateComponent, typeof i23.TheHrComponent, typeof i24.TheBlockquoteComponent, typeof i25.TheTodoItemComponent, typeof i26.TheListItemComponent, typeof i27.TheBulletedListComponent, typeof i28.TheNumberedListComponent, typeof i29.TheCodeComponent, typeof i30.TheLinkComponent, typeof i30.TheReadonlyLinkComponent, typeof i31.TheLinkEditComponent, typeof i32.TheLinkHoverComponent, typeof i33.TheTableToolbarComponent, typeof i34.TheTableComponent, typeof i35.TheTableRowComponent, typeof i36.TheTdComponent, typeof i37.TheInlineCodeComponent], [typeof i38.CommonModule, typeof i39.SlateModule, typeof i40.FormsModule, typeof i41.ThyIconModule, typeof i42.ThyAvatarModule, typeof i43.ThyNavModule, typeof i44.ThyFormModule, typeof i45.ThySharedModule, typeof i46.ThyListModule, typeof i47.ThyTooltipModule, typeof i48.ThyProgressModule, typeof i49.ThyAutocompleteModule, typeof i50.ThyActionMenuModule, typeof i51.ThyInputModule, typeof i52.ThySelectModule, typeof i53.ThyButtonModule, typeof i54.ThyNotifyModule, typeof i55.ThyAlertModule, typeof i56.ThyResizableModule, typeof i57.ThySwitchModule, typeof i58.CodemirrorModule, typeof i59.TheColumnSizeModule], [typeof i1.TheEditorComponent, typeof i3.TheToolbarComponent, typeof i4.TheToolbarDropdownComponent, typeof i6.TheToolbarItemComponent, typeof i10.TheDefaultElementComponent]>;
|
|
@@ -3,7 +3,7 @@ import { AngularEditor } from 'slate-angular';
|
|
|
3
3
|
import * as TheQueries from '../../queries';
|
|
4
4
|
import { timer } from 'rxjs';
|
|
5
5
|
export const withMoveSelection = (editor) => {
|
|
6
|
-
const { onClick, deleteBackward } = editor;
|
|
6
|
+
const { onClick, deleteBackward, onKeydown } = editor;
|
|
7
7
|
editor.onClick = (event) => {
|
|
8
8
|
const domSelection = window.getSelection();
|
|
9
9
|
if (domSelection && !domSelection.isCollapsed && event.detail >= 2 && editor.selection) {
|
|
@@ -36,4 +36,4 @@ export const withMoveSelection = (editor) => {
|
|
|
36
36
|
};
|
|
37
37
|
return editor;
|
|
38
38
|
};
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibW92ZS1zZWxlY3Rpb24ucGx1Z2luLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3BsdWdpbnMvY29tbW9uL21vdmUtc2VsZWN0aW9uLnBsdWdpbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUUsTUFBTSxPQUFPLENBQUM7QUFDbEQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM5QyxPQUFPLEtBQUssVUFBVSxNQUFNLGVBQWUsQ0FBQztBQUM1QyxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRTdCLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLENBQUMsTUFBYyxFQUFFLEVBQUU7SUFDaEQsTUFBTSxFQUFFLE9BQU8sRUFBRSxjQUFjLEVBQUUsU0FBUyxFQUFFLEdBQUcsTUFBTSxDQUFDO0lBRXRELE1BQU0sQ0FBQyxPQUFPLEdBQUcsQ0FBQyxLQUFpQixFQUFFLEVBQUU7UUFDbkMsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLFlBQVksRUFBRSxDQUFDO1FBQzNDLElBQUksWUFBWSxJQUFJLENBQUMsWUFBWSxDQUFDLFdBQVcsSUFBSSxLQUFLLENBQUMsTUFBTSxJQUFJLENBQUMsSUFBSSxNQUFNLENBQUMsU0FBUyxFQUFFO1lBQ3BGLE1BQU0sY0FBYyxHQUFHLGFBQWEsQ0FBQyxZQUFZLENBQUMsTUFBTSxFQUFFLFlBQVksQ0FBQyxDQUFDO1lBQ3hFLE1BQU0sV0FBVyxHQUFHLGNBQWMsQ0FBQyxLQUFLLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQztZQUV0RCxJQUFJLEtBQUssQ0FBQyxVQUFVLENBQUMsY0FBYyxDQUFDLElBQUksS0FBSyxDQUFDLFNBQVMsQ0FBQyxjQUFjLENBQUMsSUFBSSxXQUFXLEVBQUU7Z0JBQ3BGLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxFQUFFLGNBQWMsQ0FBQyxLQUFLLENBQUMsQ0FBQztnQkFDaEUsTUFBTSxZQUFZLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUUsY0FBYyxDQUFDLE1BQU0sRUFBRSxXQUFXLENBQUMsQ0FBQztnQkFFOUUsZ0VBQWdFO2dCQUNoRSxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLEdBQUcsRUFBRTtvQkFDckIsVUFBVSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsWUFBWSxDQUFDLENBQUM7Z0JBQzVDLENBQUMsQ0FBQyxDQUFDO2dCQUNILE9BQU87YUFDVjtTQUNKO1FBQ0QsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ25CLENBQUMsQ0FBQztJQUVGLE1BQU0sQ0FBQyxjQUFjLEdBQUcsSUFBSSxDQUFDLEVBQUU7UUFDM0IsTUFBTSxFQUFFLFNBQVMsRUFBRSxHQUFHLE1BQU0sQ0FBQztRQUM3QixNQUFNLGdCQUFnQixHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFO1lBQzFDLEtBQUssRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztTQUN6QyxDQUFDLENBQUM7UUFDSCxrREFBa0Q7UUFDbEQsMkJBQTJCO1FBQzNCLElBQUksZ0JBQWdCLElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLFNBQVMsQ0FBQyxNQUFNLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtZQUNsRyxNQUFNLFdBQVcsR0FBRyxVQUFVLENBQUMsY0FBYyxDQUFDLE1BQU0sRUFBRSxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDdkUsVUFBVSxDQUFDLE1BQU0sQ0FBQyxNQUFNLEVBQUUsV0FBVyxDQUFDLENBQUM7U0FDMUM7UUFDRCxjQUFjLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDekIsQ0FBQyxDQUFDO0lBRUYsT0FBTyxNQUFNLENBQUM7QUFDbEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRWRpdG9yLCBUcmFuc2Zvcm1zLCBSYW5nZSB9IGZyb20gJ3NsYXRlJztcbmltcG9ydCB7IEFuZ3VsYXJFZGl0b3IgfSBmcm9tICdzbGF0ZS1hbmd1bGFyJztcbmltcG9ydCAqIGFzIFRoZVF1ZXJpZXMgZnJvbSAnLi4vLi4vcXVlcmllcyc7XG5pbXBvcnQgeyB0aW1lciB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgY29uc3Qgd2l0aE1vdmVTZWxlY3Rpb24gPSAoZWRpdG9yOiBFZGl0b3IpID0+IHtcbiAgICBjb25zdCB7IG9uQ2xpY2ssIGRlbGV0ZUJhY2t3YXJkLCBvbktleWRvd24gfSA9IGVkaXRvcjtcblxuICAgIGVkaXRvci5vbkNsaWNrID0gKGV2ZW50OiBNb3VzZUV2ZW50KSA9PiB7XG4gICAgICAgIGNvbnN0IGRvbVNlbGVjdGlvbiA9IHdpbmRvdy5nZXRTZWxlY3Rpb24oKTtcbiAgICAgICAgaWYgKGRvbVNlbGVjdGlvbiAmJiAhZG9tU2VsZWN0aW9uLmlzQ29sbGFwc2VkICYmIGV2ZW50LmRldGFpbCA+PSAyICYmIGVkaXRvci5zZWxlY3Rpb24pIHtcbiAgICAgICAgICAgIGNvbnN0IHNsYXRlU2VsZWN0aW9uID0gQW5ndWxhckVkaXRvci50b1NsYXRlUmFuZ2UoZWRpdG9yLCBkb21TZWxlY3Rpb24pO1xuICAgICAgICAgICAgY29uc3QgaXNOZXh0U3RhcnQgPSBzbGF0ZVNlbGVjdGlvbi5mb2N1cy5vZmZzZXQgPT09IDA7XG5cbiAgICAgICAgICAgIGlmIChSYW5nZS5pc0V4cGFuZGVkKHNsYXRlU2VsZWN0aW9uKSAmJiBSYW5nZS5pc0ZvcndhcmQoc2xhdGVTZWxlY3Rpb24pICYmIGlzTmV4dFN0YXJ0KSB7XG4gICAgICAgICAgICAgICAgY29uc3QgYmVmb3JlUG9pbnQgPSBFZGl0b3IuYmVmb3JlKGVkaXRvciwgc2xhdGVTZWxlY3Rpb24uZm9jdXMpO1xuICAgICAgICAgICAgICAgIGNvbnN0IGNoYW5nZWRSYW5nZSA9IEVkaXRvci5yYW5nZShlZGl0b3IsIHNsYXRlU2VsZWN0aW9uLmFuY2hvciwgYmVmb3JlUG9pbnQpO1xuXG4gICAgICAgICAgICAgICAgLy8gc2xhdGUtYW5ndWxhciB0aHJvdHRsZSA4MG1zLCBzbyB3YWl0IHNlbGVjdGlvbmNoYW5nZSBjb21wbGV0ZVxuICAgICAgICAgICAgICAgIHRpbWVyKDgxKS5zdWJzY3JpYmUoKCkgPT4ge1xuICAgICAgICAgICAgICAgICAgICBUcmFuc2Zvcm1zLnNlbGVjdChlZGl0b3IsIGNoYW5nZWRSYW5nZSk7XG4gICAgICAgICAgICAgICAgfSk7XG4gICAgICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICAgICAgfVxuICAgICAgICB9XG4gICAgICAgIG9uQ2xpY2soZXZlbnQpO1xuICAgIH07XG5cbiAgICBlZGl0b3IuZGVsZXRlQmFja3dhcmQgPSB1bml0ID0+IHtcbiAgICAgICAgY29uc3QgeyBzZWxlY3Rpb24gfSA9IGVkaXRvcjtcbiAgICAgICAgY29uc3QgaW5saW5lQmxvY2tFbnRyeSA9IEVkaXRvci5hYm92ZShlZGl0b3IsIHtcbiAgICAgICAgICAgIG1hdGNoOiBuID0+IEVkaXRvci5pc0lubGluZShlZGl0b3IsIG4pXG4gICAgICAgIH0pO1xuICAgICAgICAvLyBmaXggZGVsZXRlQmFja3dhcmQgb24gdGhlIHN0YXJ0IG9mIGlubGluZSBibG9ja1xuICAgICAgICAvLyBkZWxldGVCYWNrd2FyZCBsb2dpYyBidWdcbiAgICAgICAgaWYgKGlubGluZUJsb2NrRW50cnkgJiYgIUVkaXRvci5pc1ZvaWQoZWRpdG9yLCBpbmxpbmVCbG9ja0VudHJ5WzBdKSAmJiBzZWxlY3Rpb24uYW5jaG9yLm9mZnNldCA9PT0gMCkge1xuICAgICAgICAgICAgY29uc3QgYmVmb3JlUG9pbnQgPSBUaGVRdWVyaWVzLmdldFBvaW50QmVmb3JlKGVkaXRvciwgc2VsZWN0aW9uLmZvY3VzKTtcbiAgICAgICAgICAgIFRyYW5zZm9ybXMuc2VsZWN0KGVkaXRvciwgYmVmb3JlUG9pbnQpO1xuICAgICAgICB9XG4gICAgICAgIGRlbGV0ZUJhY2t3YXJkKHVuaXQpO1xuICAgIH07XG5cbiAgICByZXR1cm4gZWRpdG9yO1xufTtcbiJdfQ==
|
|
@@ -3,25 +3,24 @@ import { TheBaseElementComponent } from '../../interfaces';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "slate-angular";
|
|
5
5
|
export class TheInlineCodeComponent extends TheBaseElementComponent {
|
|
6
|
-
constructor(
|
|
7
|
-
super(
|
|
8
|
-
this
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
ngOnInit() {
|
|
12
|
-
super.ngOnInit();
|
|
13
|
-
}
|
|
14
|
-
ngOnDestroy() {
|
|
15
|
-
super.ngOnDestroy();
|
|
6
|
+
constructor() {
|
|
7
|
+
super(...arguments);
|
|
8
|
+
// Put this at the start and end of an inline component to work around this Chromium bug:
|
|
9
|
+
// https://bugs.chromium.org/p/chromium/issues/detail?id=1249405
|
|
10
|
+
this.inlineChromiumBugfix = '$' + String.fromCodePoint(160);
|
|
16
11
|
}
|
|
17
12
|
}
|
|
18
|
-
TheInlineCodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheInlineCodeComponent, deps:
|
|
19
|
-
TheInlineCodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheInlineCodeComponent, selector: "span[theInlineCode]", usesInheritance: true, ngImport: i0, template:
|
|
13
|
+
TheInlineCodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheInlineCodeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
14
|
+
TheInlineCodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheInlineCodeComponent, selector: "span[theInlineCode]", usesInheritance: true, ngImport: i0, template: ` <span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>
|
|
15
|
+
<slate-children [children]="children" [context]="childrenContext" [viewContext]="viewContext"></slate-children>
|
|
16
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>`, isInline: true, components: [{ type: i1.SlateChildrenComponent, selector: "slate-children", inputs: ["children", "context", "viewContext"] }] });
|
|
20
17
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheInlineCodeComponent, decorators: [{
|
|
21
18
|
type: Component,
|
|
22
19
|
args: [{
|
|
23
20
|
selector: 'span[theInlineCode]',
|
|
24
|
-
template:
|
|
21
|
+
template: ` <span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>
|
|
22
|
+
<slate-children [children]="children" [context]="childrenContext" [viewContext]="viewContext"></slate-children>
|
|
23
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>`
|
|
25
24
|
}]
|
|
26
|
-
}]
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
}] });
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5saW5lLWNvZGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3BsdWdpbnMvaW5saW5lLWNvZGUvaW5saW5lLWNvZGUuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHMUMsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sa0JBQWtCLENBQUM7OztBQVEzRCxNQUFNLE9BQU8sc0JBQXVCLFNBQVEsdUJBQWtEO0lBTjlGOztRQU9JLHlGQUF5RjtRQUN6RixnRUFBZ0U7UUFDaEUseUJBQW9CLEdBQUcsR0FBRyxHQUFHLE1BQU0sQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUM7S0FDMUQ7O29IQUpZLHNCQUFzQjt3R0FBdEIsc0JBQXNCLGtGQUpyQjs7OEZBRWdGOzRGQUVqRixzQkFBc0I7a0JBTmxDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHFCQUFxQjtvQkFDL0IsUUFBUSxFQUFFOzs4RkFFZ0Y7aUJBQzdGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBFZGl0b3IgfSBmcm9tICdzbGF0ZSc7XG5pbXBvcnQgeyBJbmxpbmVDb2RlRWxlbWVudCB9IGZyb20gJy4uLy4uL2N1c3RvbS10eXBlcyc7XG5pbXBvcnQgeyBUaGVCYXNlRWxlbWVudENvbXBvbmVudCB9IGZyb20gJy4uLy4uL2ludGVyZmFjZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3NwYW5bdGhlSW5saW5lQ29kZV0nLFxuICAgIHRlbXBsYXRlOiBgIDxzcGFuIGNvbnRlbnRlZGl0YWJsZT1cImZhbHNlXCIgc3R5bGU9XCJmb250LXNpemU6IDA7XCI+e3sgaW5saW5lQ2hyb21pdW1CdWdmaXggfX08L3NwYW4+XG4gICAgICAgIDxzbGF0ZS1jaGlsZHJlbiBbY2hpbGRyZW5dPVwiY2hpbGRyZW5cIiBbY29udGV4dF09XCJjaGlsZHJlbkNvbnRleHRcIiBbdmlld0NvbnRleHRdPVwidmlld0NvbnRleHRcIj48L3NsYXRlLWNoaWxkcmVuPlxuICAgICAgICA8c3BhbiBjb250ZW50ZWRpdGFibGU9XCJmYWxzZVwiIHN0eWxlPVwiZm9udC1zaXplOiAwO1wiPnt7IGlubGluZUNocm9taXVtQnVnZml4IH19PC9zcGFuPmBcbn0pXG5leHBvcnQgY2xhc3MgVGhlSW5saW5lQ29kZUNvbXBvbmVudCBleHRlbmRzIFRoZUJhc2VFbGVtZW50Q29tcG9uZW50PElubGluZUNvZGVFbGVtZW50LCBFZGl0b3I+IHtcbiAgICAvLyBQdXQgdGhpcyBhdCB0aGUgc3RhcnQgYW5kIGVuZCBvZiBhbiBpbmxpbmUgY29tcG9uZW50IHRvIHdvcmsgYXJvdW5kIHRoaXMgQ2hyb21pdW0gYnVnOlxuICAgIC8vIGh0dHBzOi8vYnVncy5jaHJvbWl1bS5vcmcvcC9jaHJvbWl1bS9pc3N1ZXMvZGV0YWlsP2lkPTEyNDk0MDVcbiAgICBpbmxpbmVDaHJvbWl1bUJ1Z2ZpeCA9ICckJyArIFN0cmluZy5mcm9tQ29kZVBvaW50KDE2MCk7XG59XG4iXX0=
|
|
@@ -37,9 +37,13 @@ export const InlineCodeEditor = {
|
|
|
37
37
|
unwrapInlineCode(editor) {
|
|
38
38
|
Transforms.unwrapNodes(editor, { match: n => Element.isElement(n) && n.type === ElementKinds.inlineCode });
|
|
39
39
|
},
|
|
40
|
-
isInlineCodeActive(editor) {
|
|
41
|
-
|
|
40
|
+
isInlineCodeActive(editor, path) {
|
|
41
|
+
var _a;
|
|
42
|
+
const [inlineCode] = Editor.nodes(editor, {
|
|
43
|
+
at: path ? path : (_a = editor.selection) === null || _a === void 0 ? void 0 : _a.anchor.path,
|
|
44
|
+
match: n => Element.isElement(n) && n.type === ElementKinds.inlineCode
|
|
45
|
+
});
|
|
42
46
|
return !!inlineCode;
|
|
43
47
|
}
|
|
44
48
|
};
|
|
45
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5saW5lLWNvZGUuZWRpdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvc3JjL3BsdWdpbnMvaW5saW5lLWNvZGUvaW5saW5lLWNvZGUuZWRpdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUsT0FBTyxFQUFRLE1BQU0sT0FBTyxDQUFDO0FBRXZFLE9BQU8sRUFBRSxZQUFZLEVBQUUsZUFBZSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFFaEUsTUFBTSxDQUFDLE1BQU0sZ0JBQWdCLEdBQUc7SUFDNUIsZ0JBQWdCLENBQUMsTUFBTSxFQUFFLElBQWE7UUFDbEMsTUFBTSxRQUFRLEdBQUcsZ0JBQWdCLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDN0QsSUFBSSxRQUFRLEVBQUU7WUFDVixnQkFBZ0IsQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztZQUMxQyxPQUFPO1NBQ1Y7UUFDRCxJQUFJLEtBQUssQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxFQUFFO1lBQ3JDLGdCQUFnQixDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7U0FDakQ7YUFBTTtZQUNILE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM1RCxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsQ0FBQztZQUMxQyxNQUFNLFVBQVUsR0FBRyxJQUFJLENBQUMsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQzNDLGdCQUFnQixDQUFDLGNBQWMsQ0FBQyxNQUFNLEVBQUUsVUFBVSxDQUFDLENBQUM7U0FDdkQ7SUFDTCxDQUFDO0lBRUQsY0FBYyxDQUFDLE1BQWMsRUFBRSxJQUFJLEdBQUcsRUFBRTtRQUNwQyxJQUFJLGdCQUFnQixDQUFDLGtCQUFrQixDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQzdDLGdCQUFnQixDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxDQUFDO1NBQzdDO1FBQ0QsTUFBTSxFQUFFLFNBQVMsRUFBRSxHQUFHLE1BQU0sQ0FBQztRQUM3QixNQUFNLFdBQVcsR0FBRyxTQUFTLElBQUksS0FBSyxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUM5RCxNQUFNLFVBQVUsR0FBc0I7WUFDbEMsSUFBSSxFQUFFLFlBQVksQ0FBQyxVQUFVO1lBQzdCLFFBQVEsRUFBRSxXQUFXLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLGVBQWUsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUU7U0FDekUsQ0FBQztRQUNGLElBQUksV0FBVyxFQUFFO1lBQ2IsVUFBVSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEVBQUUsVUFBVSxDQUFDLENBQUM7U0FDOUM7YUFBTTtZQUNILFVBQVUsQ0FBQyxTQUFTLENBQUMsTUFBTSxFQUFFLFVBQVUsRUFBRSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO1NBQzdEO0lBQ0wsQ0FBQztJQUVELGdCQUFnQixDQUFDLE1BQWM7UUFDM0IsVUFBVSxDQUFDLFdBQVcsQ0FBQyxNQUFNLEVBQUUsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLEtBQUssWUFBWSxDQUFDLFVBQVUsRUFBRSxDQUFDLENBQUM7SUFDL0csQ0FBQztJQUVELGtCQUFrQixDQUFDLE1BQWMsRUFBRSxJQUFXOztRQUMxQyxNQUFNLENBQUMsVUFBVSxDQUFDLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLEVBQUU7WUFDdEMsRUFBRSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxNQUFBLE1BQU0sQ0FBQyxTQUFTLDBDQUFFLE1BQU0sQ0FBQyxJQUFJO1lBQy9DLEtBQUssRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLElBQUksS0FBSyxZQUFZLENBQUMsVUFBVTtTQUN6RSxDQUFDLENBQUM7UUFDSCxPQUFPLENBQUMsQ0FBQyxVQUFVLENBQUM7SUFDeEIsQ0FBQztDQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFZGl0b3IsIFJhbmdlLCBUcmFuc2Zvcm1zLCBOb2RlLCBFbGVtZW50LCBQYXRoIH0gZnJvbSAnc2xhdGUnO1xuaW1wb3J0IHsgSW5saW5lQ29kZUVsZW1lbnQgfSBmcm9tICcuLi8uLi9jdXN0b20tdHlwZXMnO1xuaW1wb3J0IHsgRWxlbWVudEtpbmRzLCBaRVJPX1dJRFRIX0NIQVIgfSBmcm9tICcuLi8uLi9jb25zdGFudHMnO1xuXG5leHBvcnQgY29uc3QgSW5saW5lQ29kZUVkaXRvciA9IHtcbiAgICB0b2dnbGVJbmxpbmVDb2RlKGVkaXRvciwgdGV4dD86IHN0cmluZykge1xuICAgICAgICBjb25zdCBpc0FjdGl2ZSA9IElubGluZUNvZGVFZGl0b3IuaXNJbmxpbmVDb2RlQWN0aXZlKGVkaXRvcik7XG4gICAgICAgIGlmIChpc0FjdGl2ZSkge1xuICAgICAgICAgICAgSW5saW5lQ29kZUVkaXRvci51bndyYXBJbmxpbmVDb2RlKGVkaXRvcik7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cbiAgICAgICAgaWYgKFJhbmdlLmlzQ29sbGFwc2VkKGVkaXRvci5zZWxlY3Rpb24pKSB7XG4gICAgICAgICAgICBJbmxpbmVDb2RlRWRpdG9yLndyYXBJbmxpbmVDb2RlKGVkaXRvciwgdGV4dCk7XG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICBjb25zdCBmcmFnbWVudCA9IE5vZGUuZnJhZ21lbnQoZWRpdG9yLCBlZGl0b3Iuc2VsZWN0aW9uKVswXTtcbiAgICAgICAgICAgIGNvbnN0IHNlbGVjdE5vZGUgPSBOb2RlLmdldChmcmFnbWVudCwgW10pO1xuICAgICAgICAgICAgY29uc3Qgc2VsZWN0VGV4dCA9IE5vZGUuc3RyaW5nKHNlbGVjdE5vZGUpO1xuICAgICAgICAgICAgSW5saW5lQ29kZUVkaXRvci53cmFwSW5saW5lQ29kZShlZGl0b3IsIHNlbGVjdFRleHQpO1xuICAgICAgICB9XG4gICAgfSxcblxuICAgIHdyYXBJbmxpbmVDb2RlKGVkaXRvcjogRWRpdG9yLCB0ZXh0ID0gJycpIHtcbiAgICAgICAgaWYgKElubGluZUNvZGVFZGl0b3IuaXNJbmxpbmVDb2RlQWN0aXZlKGVkaXRvcikpIHtcbiAgICAgICAgICAgIElubGluZUNvZGVFZGl0b3IudW53cmFwSW5saW5lQ29kZShlZGl0b3IpO1xuICAgICAgICB9XG4gICAgICAgIGNvbnN0IHsgc2VsZWN0aW9uIH0gPSBlZGl0b3I7XG4gICAgICAgIGNvbnN0IGlzQ29sbGFwc2VkID0gc2VsZWN0aW9uICYmIFJhbmdlLmlzQ29sbGFwc2VkKHNlbGVjdGlvbik7XG4gICAgICAgIGNvbnN0IGlubGluZUNvZGU6IElubGluZUNvZGVFbGVtZW50ID0ge1xuICAgICAgICAgICAgdHlwZTogRWxlbWVudEtpbmRzLmlubGluZUNvZGUsXG4gICAgICAgICAgICBjaGlsZHJlbjogaXNDb2xsYXBzZWQgPyBbeyB0ZXh0OiB0ZXh0ID8gdGV4dCA6IFpFUk9fV0lEVEhfQ0hBUiB9XSA6IFtdXG4gICAgICAgIH07XG4gICAgICAgIGlmIChpc0NvbGxhcHNlZCkge1xuICAgICAgICAgICAgVHJhbnNmb3Jtcy5pbnNlcnROb2RlcyhlZGl0b3IsIGlubGluZUNvZGUpO1xuICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgVHJhbnNmb3Jtcy53cmFwTm9kZXMoZWRpdG9yLCBpbmxpbmVDb2RlLCB7IHNwbGl0OiB0cnVlIH0pO1xuICAgICAgICB9XG4gICAgfSxcblxuICAgIHVud3JhcElubGluZUNvZGUoZWRpdG9yOiBFZGl0b3IpIHtcbiAgICAgICAgVHJhbnNmb3Jtcy51bndyYXBOb2RlcyhlZGl0b3IsIHsgbWF0Y2g6IG4gPT4gRWxlbWVudC5pc0VsZW1lbnQobikgJiYgbi50eXBlID09PSBFbGVtZW50S2luZHMuaW5saW5lQ29kZSB9KTtcbiAgICB9LFxuXG4gICAgaXNJbmxpbmVDb2RlQWN0aXZlKGVkaXRvcjogRWRpdG9yLCBwYXRoPzogUGF0aCkge1xuICAgICAgICBjb25zdCBbaW5saW5lQ29kZV0gPSBFZGl0b3Iubm9kZXMoZWRpdG9yLCB7XG4gICAgICAgICAgICBhdDogcGF0aCA/IHBhdGggOiBlZGl0b3Iuc2VsZWN0aW9uPy5hbmNob3IucGF0aCxcbiAgICAgICAgICAgIG1hdGNoOiBuID0+IEVsZW1lbnQuaXNFbGVtZW50KG4pICYmIG4udHlwZSA9PT0gRWxlbWVudEtpbmRzLmlubGluZUNvZGVcbiAgICAgICAgfSk7XG4gICAgICAgIHJldHVybiAhIWlubGluZUNvZGU7XG4gICAgfVxufTtcbiJdfQ==
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import { Editor, Transforms } from 'slate';
|
|
2
|
+
import { hotkeys } from 'slate-angular';
|
|
2
3
|
import { ElementKinds, ZERO_WIDTH_CHAR } from '../../constants';
|
|
3
4
|
import { TheInlineCodeComponent } from './inline-code.component';
|
|
4
5
|
import { InlineCodeEditor } from './inline-code.editor';
|
|
5
6
|
import { withRemoveEmptyNodes } from '../normalizers/remove-empty-nodes';
|
|
7
|
+
import * as TheQueries from '../../queries';
|
|
6
8
|
export const withInlineCode = (editor) => {
|
|
7
|
-
const { isInline, renderElement, insertText } = editor;
|
|
9
|
+
const { isInline, renderElement, insertText, onKeydown } = editor;
|
|
8
10
|
editor.isInline = (element) => {
|
|
9
11
|
return element.type === ElementKinds.inlineCode ? true : isInline(element);
|
|
10
12
|
};
|
|
@@ -40,7 +42,43 @@ export const withInlineCode = (editor) => {
|
|
|
40
42
|
insertText(text);
|
|
41
43
|
}
|
|
42
44
|
};
|
|
45
|
+
editor.onKeydown = (event) => {
|
|
46
|
+
const { selection } = editor;
|
|
47
|
+
if (!selection || !selection.anchor || !selection.focus) {
|
|
48
|
+
onKeydown(event);
|
|
49
|
+
return;
|
|
50
|
+
}
|
|
51
|
+
const isMoveBackward = hotkeys.isMoveBackward(event);
|
|
52
|
+
const isMoveForward = hotkeys.isMoveForward(event);
|
|
53
|
+
const isCollapsed = selection && TheQueries.isCollapsed(selection);
|
|
54
|
+
const isInlineCode = InlineCodeEditor.isInlineCodeActive(editor);
|
|
55
|
+
if (isCollapsed && isMoveForward) {
|
|
56
|
+
let isInlineCodeBefore = false;
|
|
57
|
+
if (!isInlineCode) {
|
|
58
|
+
const { path } = Editor.after(editor, selection);
|
|
59
|
+
isInlineCodeBefore = InlineCodeEditor.isInlineCodeActive(editor, path);
|
|
60
|
+
}
|
|
61
|
+
if (isInlineCode || isInlineCodeBefore) {
|
|
62
|
+
event.preventDefault();
|
|
63
|
+
Transforms.move(editor, { unit: 'offset' });
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
if (isCollapsed && isMoveBackward) {
|
|
68
|
+
let isInlineCodeAfter = false;
|
|
69
|
+
if (!isInlineCode) {
|
|
70
|
+
const { path } = Editor.before(editor, selection);
|
|
71
|
+
isInlineCodeAfter = InlineCodeEditor.isInlineCodeActive(editor, path);
|
|
72
|
+
}
|
|
73
|
+
if (isInlineCode || isInlineCodeAfter) {
|
|
74
|
+
event.preventDefault();
|
|
75
|
+
Transforms.move(editor, { unit: 'offset', reverse: true });
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
onKeydown(event);
|
|
80
|
+
};
|
|
43
81
|
editor = withRemoveEmptyNodes({ type: ElementKinds.inlineCode })(editor);
|
|
44
82
|
return editor;
|
|
45
83
|
};
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inline-code.plugin.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/inline-code/inline-code.plugin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,OAAO,CAAC;AAC3C,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AACxC,OAAO,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAChE,OAAO,EAAE,sBAAsB,EAAE,MAAM,yBAAyB,CAAC;AACjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,oBAAoB,EAAE,MAAM,mCAAmC,CAAC;AAEzE,OAAO,KAAK,UAAU,MAAM,eAAe,CAAC;AAE5C,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,MAAc,EAAE,EAAE;IAC7C,MAAM,EAAE,QAAQ,EAAE,aAAa,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;IAElE,MAAM,CAAC,QAAQ,GAAG,CAAC,OAA0B,EAAE,EAAE;QAC7C,OAAO,OAAO,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;IAC/E,CAAC,CAAC;IAEF,MAAM,CAAC,aAAa,GAAG,CAAC,OAA0B,EAAE,EAAE;QAClD,IAAI,OAAO,CAAC,IAAI,KAAK,YAAY,CAAC,UAAU,EAAE;YAC1C,OAAO,sBAAsB,CAAC;SACjC;QACD,OAAO,aAAa,CAAC,OAAO,CAAC,CAAC;IAClC,CAAC,CAAC;IAEF,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC,EAAE;QACvB,IAAI,IAAI,IAAI,gBAAgB,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAE;YACrD,IAAI,SAAS,GAAG,MAAM,CAAC,SAAS,CAAC;YACjC,MAAM,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;YAC5E,UAAU,CAAC,IAAI,CAAC,CAAC;YACjB,IAAI,eAAe,IAAI,eAAe,EAAE;gBACpC,MAAM,cAAc,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;gBAC7D,IAAI,KAAK,GAAG;oBACR,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC;oBAC/C,KAAK,EAAE,SAAS,CAAC,MAAM;iBAC1B,CAAC;gBACF,IAAI,MAAM,CAAC,OAAO,CAAC,MAAM,EAAE,SAAS,CAAC,MAAM,EAAE,cAAc,CAAC,EAAE;oBAC1D,KAAK,GAAG;wBACJ,MAAM,EAAE,MAAM,CAAC,SAAS,CAAC,MAAM;wBAC/B,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,SAAS,CAAC;qBAChD,CAAC;iBACL;gBACD,UAAU,CAAC,MAAM,CAAC,MAAM,EAAE;oBACtB,EAAE,EAAE,KAAK;iBACZ,CAAC,CAAC;aACN;SACJ;aAAM;YACH,UAAU,CAAC,IAAI,CAAC,CAAC;SACpB;IACL,CAAC,CAAC;IAEF,MAAM,CAAC,SAAS,GAAG,CAAC,KAAoB,EAAE,EAAE;QACxC,MAAM,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;QAC7B,IAAI,CAAC,SAAS,IAAI,CAAC,SAAS,CAAC,MAAM,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE;YACrD,SAAS,CAAC,KAAK,CAAC,CAAC;YACjB,OAAO;SACV;QACD,MAAM,cAAc,GAAG,OAAO,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;QACrD,MAAM,aAAa,GAAG,OAAO,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACnD,MAAM,WAAW,GAAG,SAAS,IAAI,UAAU,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;QACnE,MAAM,YAAY,GAAG,gBAAgB,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;QACjE,IAAI,WAAW,IAAI,aAAa,EAAE;YAC9B,IAAI,kBAAkB,GAAG,KAAK,CAAC;YAC/B,IAAI,CAAC,YAAY,EAAE;gBACf,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,CAAC,KAAK,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;gBACjD,kBAAkB,GAAG,gBAAgB,CAAC,kBAAkB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;aAC1E;YACD,IAAI,YAAY,IAAI,kBAAkB,EAAE;gBACpC,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,CAAC,CAAC;gBAC5C,OAAO;aACV;SACJ;QACD,IAAI,WAAW,IAAI,cAAc,EAAE;YAC/B,IAAI,iBAAiB,GAAG,KAAK,CAAC;YAC9B,IAAI,CAAC,YAAY,EAAE;gBACf,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;gBAClD,iBAAiB,GAAG,gBAAgB,CAAC,kBAAkB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;aACzE;YACD,IAAI,YAAY,IAAI,iBAAiB,EAAE;gBACnC,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC;gBAC3D,OAAO;aACV;SACJ;QACD,SAAS,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC,CAAC;IAEF,MAAM,GAAG,oBAAoB,CAAC,EAAE,IAAI,EAAE,YAAY,CAAC,UAAU,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC;IACzE,OAAO,MAAM,CAAC;AAClB,CAAC,CAAC","sourcesContent":["import { Editor, Transforms } from 'slate';\nimport { hotkeys } from 'slate-angular';\nimport { ElementKinds, ZERO_WIDTH_CHAR } from '../../constants';\nimport { TheInlineCodeComponent } from './inline-code.component';\nimport { InlineCodeEditor } from './inline-code.editor';\nimport { withRemoveEmptyNodes } from '../normalizers/remove-empty-nodes';\nimport { InlineCodeElement } from '../../custom-types';\nimport * as TheQueries from '../../queries';\n\nexport const withInlineCode = (editor: Editor) => {\n    const { isInline, renderElement, insertText, onKeydown } = editor;\n\n    editor.isInline = (element: InlineCodeElement) => {\n        return element.type === ElementKinds.inlineCode ? true : isInline(element);\n    };\n\n    editor.renderElement = (element: InlineCodeElement) => {\n        if (element.type === ElementKinds.inlineCode) {\n            return TheInlineCodeComponent;\n        }\n        return renderElement(element);\n    };\n\n    editor.insertText = text => {\n        if (text && InlineCodeEditor.isInlineCodeActive(editor)) {\n            let selection = editor.selection;\n            const currentNodeText = Editor.string(editor, editor.selection.anchor.path);\n            insertText(text);\n            if (currentNodeText == ZERO_WIDTH_CHAR) {\n                const inlineCodePath = Editor.path(editor, editor.selection);\n                let range = {\n                    anchor: Editor.before(editor, selection.anchor),\n                    focus: selection.anchor\n                };\n                if (Editor.isStart(editor, selection.anchor, inlineCodePath)) {\n                    range = {\n                        anchor: editor.selection.anchor,\n                        focus: Editor.after(editor, editor.selection)\n                    };\n                }\n                Transforms.delete(editor, {\n                    at: range\n                });\n            }\n        } else {\n            insertText(text);\n        }\n    };\n\n    editor.onKeydown = (event: KeyboardEvent) => {\n        const { selection } = editor;\n        if (!selection || !selection.anchor || !selection.focus) {\n            onKeydown(event);\n            return;\n        }\n        const isMoveBackward = hotkeys.isMoveBackward(event);\n        const isMoveForward = hotkeys.isMoveForward(event);\n        const isCollapsed = selection && TheQueries.isCollapsed(selection);\n        const isInlineCode = InlineCodeEditor.isInlineCodeActive(editor);\n        if (isCollapsed && isMoveForward) {\n            let isInlineCodeBefore = false;\n            if (!isInlineCode) {\n                const { path } = Editor.after(editor, selection);\n                isInlineCodeBefore = InlineCodeEditor.isInlineCodeActive(editor, path);\n            }\n            if (isInlineCode || isInlineCodeBefore) {\n                event.preventDefault();\n                Transforms.move(editor, { unit: 'offset' });\n                return;\n            }\n        }\n        if (isCollapsed && isMoveBackward) {\n            let isInlineCodeAfter = false;\n            if (!isInlineCode) {\n                const { path } = Editor.before(editor, selection);\n                isInlineCodeAfter = InlineCodeEditor.isInlineCodeActive(editor, path);\n            }\n            if (isInlineCode || isInlineCodeAfter) {\n                event.preventDefault();\n                Transforms.move(editor, { unit: 'offset', reverse: true });\n                return;\n            }\n        }\n        onKeydown(event);\n    };\n\n    editor = withRemoveEmptyNodes({ type: ElementKinds.inlineCode })(editor);\n    return editor;\n};\n"]}
|
|
@@ -140,14 +140,26 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
|
140
140
|
args: ['click', ['$event']]
|
|
141
141
|
}] } });
|
|
142
142
|
export class TheLinkComponent extends TheBaseLinkComponent {
|
|
143
|
+
constructor() {
|
|
144
|
+
super(...arguments);
|
|
145
|
+
// Put this at the start and end of an inline component to work around this Chromium bug:
|
|
146
|
+
// https://bugs.chromium.org/p/chromium/issues/detail?id=1249405
|
|
147
|
+
this.inlineChromiumBugfix = '$' + String.fromCodePoint(160);
|
|
148
|
+
}
|
|
143
149
|
}
|
|
144
150
|
TheLinkComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheLinkComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
145
|
-
TheLinkComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheLinkComponent, selector: "span[theLink]", usesInheritance: true, ngImport: i0, template:
|
|
151
|
+
TheLinkComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheLinkComponent, selector: "span[theLink]", usesInheritance: true, ngImport: i0, template: `
|
|
152
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>
|
|
153
|
+
<slate-children [children]="children" [context]="childrenContext" [viewContext]="viewContext"></slate-children>
|
|
154
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>`, isInline: true, components: [{ type: i4.SlateChildrenComponent, selector: "slate-children", inputs: ["children", "context", "viewContext"] }] });
|
|
146
155
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheLinkComponent, decorators: [{
|
|
147
156
|
type: Component,
|
|
148
157
|
args: [{
|
|
149
158
|
selector: 'span[theLink]',
|
|
150
|
-
template:
|
|
159
|
+
template: `
|
|
160
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>
|
|
161
|
+
<slate-children [children]="children" [context]="childrenContext" [viewContext]="viewContext"></slate-children>
|
|
162
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>`
|
|
151
163
|
}]
|
|
152
164
|
}] });
|
|
153
165
|
export class TheReadonlyLinkComponent extends TheBaseLinkComponent {
|
|
@@ -165,4 +177,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
|
165
177
|
}
|
|
166
178
|
}]
|
|
167
179
|
}] });
|
|
168
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.component.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/link/link.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport { Component, OnInit, ElementRef, OnDestroy, ChangeDetectorRef, ViewContainerRef, HostListener, NgZone } from '@angular/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor, Element, Node as SlateNode, Transforms, Text } from 'slate';\nimport { ElementKinds } from '../../constants';\nimport { LinkElement } from '../../custom-types';\nimport { TheBaseElementComponent } from '../../interfaces';\nimport { LinkCloseTypes, LinkTags } from './link.types';\nimport { TheLinkHoverComponent } from './hover/link-hover.component';\nimport { TheLinkEditComponent } from './edit/link-edit.component';\nimport { ThyClickDispatcher } from 'ngx-tethys';\nimport { SlateElementContext } from 'slate-angular';\n\n@Component({\n    selector: '[TheBaseLinkComponent]',\n    template: ''\n})\nexport class TheBaseLinkComponent extends TheBaseElementComponent<LinkElement, Editor> implements OnInit, OnDestroy {\n    thyPopoverHoverRef: ThyPopoverRef<any>;\n    thyPopoverEditRef: ThyPopoverRef<any>;\n\n    get linkHoverOpened(): boolean {\n        return this.thyPopoverHoverRef && this.thyPopoverHoverRef.componentInstance;\n    }\n\n    get linkEditOpened(): boolean {\n        return this.thyPopoverEditRef && this.thyPopoverEditRef.componentInstance;\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        public cdr: ChangeDetectorRef,\n        private thyPopover: ThyPopover,\n        private overlay: Overlay,\n        private viewContainerRef: ViewContainerRef,\n        private thyClickDispatcher: ThyClickDispatcher\n    ) {\n        super(elementRef, cdr);\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n    }\n\n    closeHoverPopover() {\n        if (this.linkHoverOpened) {\n            this.thyPopoverHoverRef.close();\n        }\n    }\n\n    beforeContextChange = (value: SlateElementContext) => {\n        if (this.thyPopoverEditRef && this.thyPopoverEditRef.componentInstance) {\n            let { originText } = this.thyPopoverEditRef.componentInstance;\n            if (originText && originText !== (value.element.children[0] as Text).text) {\n                this.thyPopoverEditRef.componentInstance.originText = (value.element.children[0] as Text).text;\n            }\n        }\n    };\n\n    @HostListener('click', ['$event'])\n    mousedownHandle(event: MouseEvent) {\n        if (!this.readonly && !this.editor.disabled) {\n            this.openLinkHover();\n        }\n    }\n\n    openLinkEdit(tag: LinkTags) {\n        if (this.linkHoverOpened) {\n            this.thyPopoverHoverRef.afterClosed().subscribe(() => {\n                this.internalOpenLinkEdit(tag);\n            });\n            this.thyPopover.close();\n        } else {\n            this.internalOpenLinkEdit(tag);\n        }\n    }\n\n    isLinkEditOpenedByDom(dom: HTMLElement) {\n        return this.linkEditOpened && this.thyPopoverEditRef.componentInstance.dom === dom;\n    }\n\n    closeEditPopover(type?: string) {\n        if (this.linkEditOpened) {\n            this.thyPopoverEditRef.close(type);\n        }\n    }\n\n    openLinkHover() {\n        const dom = this.nativeElement;\n        const url = this.element.url;\n\n        if (this.linkHoverOpened) {\n            return;\n        }\n        this.thyPopoverHoverRef = this.thyPopover.open(TheLinkHoverComponent, {\n            initialState: {\n                link: url,\n                dom: dom,\n                editHandle: () => {\n                    this.openLinkEdit(LinkTags.edit);\n                },\n                deleteHandle: () => {\n                    Transforms.unwrapNodes(this.editor, { match: n => Element.isElement(n) && n.type === ElementKinds.link });\n                    this.closeHoverPopover();\n                }\n            },\n            origin: dom,\n            placement: 'bottomLeft',\n            offset: 8,\n            hasBackdrop: false,\n            outsideClosable: true,\n            viewContainerRef: this.viewContainerRef,\n            scrollStrategy: this.overlay.scrollStrategies.reposition(),\n            panelClass: 'the-link-over'\n        });\n    }\n\n    private internalOpenLinkEdit(tag: LinkTags) {\n        const link = this.element.url;\n        SlateNode.get(this.editor, this.editor.selection.focus.path);\n        this.thyPopoverEditRef = this.thyPopover.open(TheLinkEditComponent, {\n            initialState: {\n                tag,\n                editor: this.editor,\n                node: this.element,\n                text: SlateNode.string(this.element),\n                link,\n                originSelection: this.editor.selection\n            },\n            origin: this.elementRef.nativeElement,\n            backdropClosable: true,\n            placement: 'bottomLeft',\n            offset: 8,\n            hasBackdrop: false,\n            originActiveClass: null,\n            viewContainerRef: this.viewContainerRef,\n            scrollStrategy: this.overlay.scrollStrategies.reposition(),\n            panelClass: 'the-link-edit'\n        });\n        this.cdr.markForCheck();\n    }\n\n    close(type?: string) {\n        this.closeHoverPopover();\n        this.closeEditPopover(type);\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n        this.close(LinkCloseTypes.destroy);\n    }\n}\n\n@Component({\n    selector: 'span[theLink]',\n    template: `<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>`\n})\nexport class TheLinkComponent extends TheBaseLinkComponent {}\n\n@Component({\n    selector: 'a[theLink]',\n    template: `<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>`,\n    host: {\n        '[attr.href]': 'element.url',\n        target: '_blank'\n    }\n})\nexport class TheReadonlyLinkComponent extends TheBaseLinkComponent {}\n"]}
|
|
180
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link.component.js","sourceRoot":"","sources":["../../../../../packages/src/plugins/link/link.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport { Component, OnInit, ElementRef, OnDestroy, ChangeDetectorRef, ViewContainerRef, HostListener, NgZone } from '@angular/core';\nimport { ThyPopover, ThyPopoverRef } from 'ngx-tethys/popover';\nimport { Editor, Element, Node as SlateNode, Transforms, Text } from 'slate';\nimport { ElementKinds } from '../../constants';\nimport { LinkElement } from '../../custom-types';\nimport { TheBaseElementComponent } from '../../interfaces';\nimport { LinkCloseTypes, LinkTags } from './link.types';\nimport { TheLinkHoverComponent } from './hover/link-hover.component';\nimport { TheLinkEditComponent } from './edit/link-edit.component';\nimport { ThyClickDispatcher } from 'ngx-tethys';\nimport { SlateElementContext } from 'slate-angular';\n\n@Component({\n    selector: '[TheBaseLinkComponent]',\n    template: ''\n})\nexport class TheBaseLinkComponent extends TheBaseElementComponent<LinkElement, Editor> implements OnInit, OnDestroy {\n    thyPopoverHoverRef: ThyPopoverRef<any>;\n    thyPopoverEditRef: ThyPopoverRef<any>;\n\n    get linkHoverOpened(): boolean {\n        return this.thyPopoverHoverRef && this.thyPopoverHoverRef.componentInstance;\n    }\n\n    get linkEditOpened(): boolean {\n        return this.thyPopoverEditRef && this.thyPopoverEditRef.componentInstance;\n    }\n\n    constructor(\n        public elementRef: ElementRef,\n        public cdr: ChangeDetectorRef,\n        private thyPopover: ThyPopover,\n        private overlay: Overlay,\n        private viewContainerRef: ViewContainerRef,\n        private thyClickDispatcher: ThyClickDispatcher\n    ) {\n        super(elementRef, cdr);\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n    }\n\n    closeHoverPopover() {\n        if (this.linkHoverOpened) {\n            this.thyPopoverHoverRef.close();\n        }\n    }\n\n    beforeContextChange = (value: SlateElementContext) => {\n        if (this.thyPopoverEditRef && this.thyPopoverEditRef.componentInstance) {\n            let { originText } = this.thyPopoverEditRef.componentInstance;\n            if (originText && originText !== (value.element.children[0] as Text).text) {\n                this.thyPopoverEditRef.componentInstance.originText = (value.element.children[0] as Text).text;\n            }\n        }\n    };\n\n    @HostListener('click', ['$event'])\n    mousedownHandle(event: MouseEvent) {\n        if (!this.readonly && !this.editor.disabled) {\n            this.openLinkHover();\n        }\n    }\n\n    openLinkEdit(tag: LinkTags) {\n        if (this.linkHoverOpened) {\n            this.thyPopoverHoverRef.afterClosed().subscribe(() => {\n                this.internalOpenLinkEdit(tag);\n            });\n            this.thyPopover.close();\n        } else {\n            this.internalOpenLinkEdit(tag);\n        }\n    }\n\n    isLinkEditOpenedByDom(dom: HTMLElement) {\n        return this.linkEditOpened && this.thyPopoverEditRef.componentInstance.dom === dom;\n    }\n\n    closeEditPopover(type?: string) {\n        if (this.linkEditOpened) {\n            this.thyPopoverEditRef.close(type);\n        }\n    }\n\n    openLinkHover() {\n        const dom = this.nativeElement;\n        const url = this.element.url;\n\n        if (this.linkHoverOpened) {\n            return;\n        }\n        this.thyPopoverHoverRef = this.thyPopover.open(TheLinkHoverComponent, {\n            initialState: {\n                link: url,\n                dom: dom,\n                editHandle: () => {\n                    this.openLinkEdit(LinkTags.edit);\n                },\n                deleteHandle: () => {\n                    Transforms.unwrapNodes(this.editor, { match: n => Element.isElement(n) && n.type === ElementKinds.link });\n                    this.closeHoverPopover();\n                }\n            },\n            origin: dom,\n            placement: 'bottomLeft',\n            offset: 8,\n            hasBackdrop: false,\n            outsideClosable: true,\n            viewContainerRef: this.viewContainerRef,\n            scrollStrategy: this.overlay.scrollStrategies.reposition(),\n            panelClass: 'the-link-over'\n        });\n    }\n\n    private internalOpenLinkEdit(tag: LinkTags) {\n        const link = this.element.url;\n        SlateNode.get(this.editor, this.editor.selection.focus.path);\n        this.thyPopoverEditRef = this.thyPopover.open(TheLinkEditComponent, {\n            initialState: {\n                tag,\n                editor: this.editor,\n                node: this.element,\n                text: SlateNode.string(this.element),\n                link,\n                originSelection: this.editor.selection\n            },\n            origin: this.elementRef.nativeElement,\n            backdropClosable: true,\n            placement: 'bottomLeft',\n            offset: 8,\n            hasBackdrop: false,\n            originActiveClass: null,\n            viewContainerRef: this.viewContainerRef,\n            scrollStrategy: this.overlay.scrollStrategies.reposition(),\n            panelClass: 'the-link-edit'\n        });\n        this.cdr.markForCheck();\n    }\n\n    close(type?: string) {\n        this.closeHoverPopover();\n        this.closeEditPopover(type);\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n        this.close(LinkCloseTypes.destroy);\n    }\n}\n\n@Component({\n    selector: 'span[theLink]',\n    template: `\n    <span contenteditable=\"false\" style=\"font-size: 0;\">{{ inlineChromiumBugfix }}</span>\n    <slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>\n    <span contenteditable=\"false\" style=\"font-size: 0;\">{{ inlineChromiumBugfix }}</span>`\n})\nexport class TheLinkComponent extends TheBaseLinkComponent {\n    // Put this at the start and end of an inline component to work around this Chromium bug:\n    // https://bugs.chromium.org/p/chromium/issues/detail?id=1249405\n    inlineChromiumBugfix = '$' + String.fromCodePoint(160);\n}\n\n@Component({\n    selector: 'a[theLink]',\n    template: `<slate-children [children]=\"children\" [context]=\"childrenContext\" [viewContext]=\"viewContext\"></slate-children>`,\n    host: {\n        '[attr.href]': 'element.url',\n        target: '_blank'\n    }\n})\nexport class TheReadonlyLinkComponent extends TheBaseLinkComponent {}\n"]}
|
|
@@ -1779,8 +1779,12 @@ const InlineCodeEditor = {
|
|
|
1779
1779
|
unwrapInlineCode(editor) {
|
|
1780
1780
|
Transforms.unwrapNodes(editor, { match: n => Element$1.isElement(n) && n.type === ElementKinds.inlineCode });
|
|
1781
1781
|
},
|
|
1782
|
-
isInlineCodeActive(editor) {
|
|
1783
|
-
|
|
1782
|
+
isInlineCodeActive(editor, path) {
|
|
1783
|
+
var _a;
|
|
1784
|
+
const [inlineCode] = Editor.nodes(editor, {
|
|
1785
|
+
at: path ? path : (_a = editor.selection) === null || _a === void 0 ? void 0 : _a.anchor.path,
|
|
1786
|
+
match: n => Element$1.isElement(n) && n.type === ElementKinds.inlineCode
|
|
1787
|
+
});
|
|
1784
1788
|
return !!inlineCode;
|
|
1785
1789
|
}
|
|
1786
1790
|
};
|
|
@@ -4569,7 +4573,7 @@ const withBlockCard = (editor) => {
|
|
|
4569
4573
|
};
|
|
4570
4574
|
|
|
4571
4575
|
const withMoveSelection = (editor) => {
|
|
4572
|
-
const { onClick, deleteBackward } = editor;
|
|
4576
|
+
const { onClick, deleteBackward, onKeydown } = editor;
|
|
4573
4577
|
editor.onClick = (event) => {
|
|
4574
4578
|
const domSelection = window.getSelection();
|
|
4575
4579
|
if (domSelection && !domSelection.isCollapsed && event.detail >= 2 && editor.selection) {
|
|
@@ -7097,14 +7101,26 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImpo
|
|
|
7097
7101
|
args: ['click', ['$event']]
|
|
7098
7102
|
}] } });
|
|
7099
7103
|
class TheLinkComponent extends TheBaseLinkComponent {
|
|
7104
|
+
constructor() {
|
|
7105
|
+
super(...arguments);
|
|
7106
|
+
// Put this at the start and end of an inline component to work around this Chromium bug:
|
|
7107
|
+
// https://bugs.chromium.org/p/chromium/issues/detail?id=1249405
|
|
7108
|
+
this.inlineChromiumBugfix = '$' + String.fromCodePoint(160);
|
|
7109
|
+
}
|
|
7100
7110
|
}
|
|
7101
7111
|
TheLinkComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheLinkComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
7102
|
-
TheLinkComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheLinkComponent, selector: "span[theLink]", usesInheritance: true, ngImport: i0, template:
|
|
7112
|
+
TheLinkComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheLinkComponent, selector: "span[theLink]", usesInheritance: true, ngImport: i0, template: `
|
|
7113
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>
|
|
7114
|
+
<slate-children [children]="children" [context]="childrenContext" [viewContext]="viewContext"></slate-children>
|
|
7115
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>`, isInline: true, components: [{ type: i1.SlateChildrenComponent, selector: "slate-children", inputs: ["children", "context", "viewContext"] }] });
|
|
7103
7116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheLinkComponent, decorators: [{
|
|
7104
7117
|
type: Component,
|
|
7105
7118
|
args: [{
|
|
7106
7119
|
selector: 'span[theLink]',
|
|
7107
|
-
template:
|
|
7120
|
+
template: `
|
|
7121
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>
|
|
7122
|
+
<slate-children [children]="children" [context]="childrenContext" [viewContext]="viewContext"></slate-children>
|
|
7123
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>`
|
|
7108
7124
|
}]
|
|
7109
7125
|
}] });
|
|
7110
7126
|
class TheReadonlyLinkComponent extends TheBaseLinkComponent {
|
|
@@ -11200,30 +11216,29 @@ const InlineCodeOptions = [
|
|
|
11200
11216
|
];
|
|
11201
11217
|
|
|
11202
11218
|
class TheInlineCodeComponent extends TheBaseElementComponent {
|
|
11203
|
-
constructor(
|
|
11204
|
-
super(
|
|
11205
|
-
this
|
|
11206
|
-
|
|
11207
|
-
|
|
11208
|
-
ngOnInit() {
|
|
11209
|
-
super.ngOnInit();
|
|
11210
|
-
}
|
|
11211
|
-
ngOnDestroy() {
|
|
11212
|
-
super.ngOnDestroy();
|
|
11219
|
+
constructor() {
|
|
11220
|
+
super(...arguments);
|
|
11221
|
+
// Put this at the start and end of an inline component to work around this Chromium bug:
|
|
11222
|
+
// https://bugs.chromium.org/p/chromium/issues/detail?id=1249405
|
|
11223
|
+
this.inlineChromiumBugfix = '$' + String.fromCodePoint(160);
|
|
11213
11224
|
}
|
|
11214
11225
|
}
|
|
11215
|
-
TheInlineCodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheInlineCodeComponent, deps:
|
|
11216
|
-
TheInlineCodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheInlineCodeComponent, selector: "span[theInlineCode]", usesInheritance: true, ngImport: i0, template:
|
|
11226
|
+
TheInlineCodeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheInlineCodeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
11227
|
+
TheInlineCodeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.15", type: TheInlineCodeComponent, selector: "span[theInlineCode]", usesInheritance: true, ngImport: i0, template: ` <span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>
|
|
11228
|
+
<slate-children [children]="children" [context]="childrenContext" [viewContext]="viewContext"></slate-children>
|
|
11229
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>`, isInline: true, components: [{ type: i1.SlateChildrenComponent, selector: "slate-children", inputs: ["children", "context", "viewContext"] }] });
|
|
11217
11230
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.15", ngImport: i0, type: TheInlineCodeComponent, decorators: [{
|
|
11218
11231
|
type: Component,
|
|
11219
11232
|
args: [{
|
|
11220
11233
|
selector: 'span[theInlineCode]',
|
|
11221
|
-
template:
|
|
11234
|
+
template: ` <span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>
|
|
11235
|
+
<slate-children [children]="children" [context]="childrenContext" [viewContext]="viewContext"></slate-children>
|
|
11236
|
+
<span contenteditable="false" style="font-size: 0;">{{ inlineChromiumBugfix }}</span>`
|
|
11222
11237
|
}]
|
|
11223
|
-
}]
|
|
11238
|
+
}] });
|
|
11224
11239
|
|
|
11225
11240
|
const withInlineCode = (editor) => {
|
|
11226
|
-
const { isInline, renderElement, insertText } = editor;
|
|
11241
|
+
const { isInline, renderElement, insertText, onKeydown } = editor;
|
|
11227
11242
|
editor.isInline = (element) => {
|
|
11228
11243
|
return element.type === ElementKinds.inlineCode ? true : isInline(element);
|
|
11229
11244
|
};
|
|
@@ -11259,6 +11274,42 @@ const withInlineCode = (editor) => {
|
|
|
11259
11274
|
insertText(text);
|
|
11260
11275
|
}
|
|
11261
11276
|
};
|
|
11277
|
+
editor.onKeydown = (event) => {
|
|
11278
|
+
const { selection } = editor;
|
|
11279
|
+
if (!selection || !selection.anchor || !selection.focus) {
|
|
11280
|
+
onKeydown(event);
|
|
11281
|
+
return;
|
|
11282
|
+
}
|
|
11283
|
+
const isMoveBackward = hotkeys.isMoveBackward(event);
|
|
11284
|
+
const isMoveForward = hotkeys.isMoveForward(event);
|
|
11285
|
+
const isCollapsed$1 = selection && isCollapsed(selection);
|
|
11286
|
+
const isInlineCode = InlineCodeEditor.isInlineCodeActive(editor);
|
|
11287
|
+
if (isCollapsed$1 && isMoveForward) {
|
|
11288
|
+
let isInlineCodeBefore = false;
|
|
11289
|
+
if (!isInlineCode) {
|
|
11290
|
+
const { path } = Editor.after(editor, selection);
|
|
11291
|
+
isInlineCodeBefore = InlineCodeEditor.isInlineCodeActive(editor, path);
|
|
11292
|
+
}
|
|
11293
|
+
if (isInlineCode || isInlineCodeBefore) {
|
|
11294
|
+
event.preventDefault();
|
|
11295
|
+
Transforms.move(editor, { unit: 'offset' });
|
|
11296
|
+
return;
|
|
11297
|
+
}
|
|
11298
|
+
}
|
|
11299
|
+
if (isCollapsed$1 && isMoveBackward) {
|
|
11300
|
+
let isInlineCodeAfter = false;
|
|
11301
|
+
if (!isInlineCode) {
|
|
11302
|
+
const { path } = Editor.before(editor, selection);
|
|
11303
|
+
isInlineCodeAfter = InlineCodeEditor.isInlineCodeActive(editor, path);
|
|
11304
|
+
}
|
|
11305
|
+
if (isInlineCode || isInlineCodeAfter) {
|
|
11306
|
+
event.preventDefault();
|
|
11307
|
+
Transforms.move(editor, { unit: 'offset', reverse: true });
|
|
11308
|
+
return;
|
|
11309
|
+
}
|
|
11310
|
+
}
|
|
11311
|
+
onKeydown(event);
|
|
11312
|
+
};
|
|
11262
11313
|
editor = withRemoveEmptyNodes({ type: ElementKinds.inlineCode })(editor);
|
|
11263
11314
|
return editor;
|
|
11264
11315
|
};
|