jodit 4.12.15 → 4.12.17
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/CHANGELOG.md +12 -0
- package/es2015/jodit.css +1 -1
- package/es2015/jodit.fat.min.js +4 -4
- package/es2015/jodit.js +38 -2
- package/es2015/jodit.min.js +4 -4
- package/es2015/plugins/debug/debug.css +1 -1
- package/es2015/plugins/debug/debug.js +1 -1
- package/es2015/plugins/debug/debug.min.js +1 -1
- package/es2015/plugins/speech-recognize/speech-recognize.css +1 -1
- package/es2015/plugins/speech-recognize/speech-recognize.js +1 -1
- package/es2015/plugins/speech-recognize/speech-recognize.min.js +1 -1
- package/es2018/jodit.fat.min.js +4 -4
- package/es2018/jodit.min.js +4 -4
- package/es2018/plugins/debug/debug.min.js +1 -1
- package/es2018/plugins/speech-recognize/speech-recognize.min.js +1 -1
- package/es2021/jodit.css +1 -1
- package/es2021/jodit.fat.min.js +4 -4
- package/es2021/jodit.js +38 -2
- package/es2021/jodit.min.js +4 -4
- package/es2021/plugins/debug/debug.css +1 -1
- package/es2021/plugins/debug/debug.js +1 -1
- package/es2021/plugins/debug/debug.min.js +1 -1
- package/es2021/plugins/speech-recognize/speech-recognize.css +1 -1
- package/es2021/plugins/speech-recognize/speech-recognize.js +1 -1
- package/es2021/plugins/speech-recognize/speech-recognize.min.js +1 -1
- package/es2021.en/jodit.css +1 -1
- package/es2021.en/jodit.fat.min.js +4 -4
- package/es2021.en/jodit.js +38 -2
- package/es2021.en/jodit.min.js +5 -5
- package/es2021.en/plugins/debug/debug.css +1 -1
- package/es2021.en/plugins/debug/debug.js +1 -1
- package/es2021.en/plugins/debug/debug.min.js +1 -1
- package/es2021.en/plugins/speech-recognize/speech-recognize.css +1 -1
- package/es2021.en/plugins/speech-recognize/speech-recognize.js +1 -1
- package/es2021.en/plugins/speech-recognize/speech-recognize.min.js +1 -1
- package/es5/jodit.css +2 -2
- package/es5/jodit.fat.min.js +2 -2
- package/es5/jodit.js +41 -2
- package/es5/jodit.min.css +2 -2
- package/es5/jodit.min.js +2 -2
- package/es5/plugins/debug/debug.css +1 -1
- package/es5/plugins/debug/debug.js +1 -1
- package/es5/plugins/debug/debug.min.js +1 -1
- package/es5/plugins/speech-recognize/speech-recognize.css +1 -1
- package/es5/plugins/speech-recognize/speech-recognize.js +1 -1
- package/es5/plugins/speech-recognize/speech-recognize.min.js +1 -1
- package/es5/polyfills.fat.min.js +1 -1
- package/es5/polyfills.js +1 -1
- package/es5/polyfills.min.js +1 -1
- package/esm/core/constants.js +1 -1
- package/esm/plugins/dtd/after-insert/remove-extra-br.js +6 -0
- package/esm/plugins/select/select.d.ts +6 -0
- package/esm/plugins/select/select.js +32 -0
- package/package.json +1 -1
- package/types/plugins/select/select.d.ts +6 -0
package/es5/polyfills.fat.min.js
CHANGED
package/es5/polyfills.js
CHANGED
package/es5/polyfills.min.js
CHANGED
package/esm/core/constants.js
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
* Released under MIT see LICENSE.txt in the project root for license information.
|
|
4
4
|
* Copyright (c) 2013-2026 Valerii Chupurnov. All rights reserved. https://xdsoft.net
|
|
5
5
|
*/
|
|
6
|
-
export const APP_VERSION = "4.12.
|
|
6
|
+
export const APP_VERSION = "4.12.17";
|
|
7
7
|
// prettier-ignore
|
|
8
8
|
export const ES = "es2020";
|
|
9
9
|
export const IS_ES_MODERN = true;
|
|
@@ -27,6 +27,12 @@ export function removeExtraBr(jodit, node) {
|
|
|
27
27
|
if (!Dom.isTag(br, 'br')) {
|
|
28
28
|
return;
|
|
29
29
|
}
|
|
30
|
+
// Only a trailing `<br>` is "extra". If meaningful content follows it,
|
|
31
|
+
// the `<br>` is a real line break and removing it would merge two lines
|
|
32
|
+
// (e.g. toggling a style on an empty line), so keep it (#1302).
|
|
33
|
+
if (Dom.findNotEmptySibling(br, false)) {
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
30
36
|
jodit.s.setCursorBefore(br);
|
|
31
37
|
Dom.safeRemove(br);
|
|
32
38
|
}
|
|
@@ -33,6 +33,12 @@ export declare class select extends Plugin {
|
|
|
33
33
|
protected onOutsideClick(e: MouseEvent): void;
|
|
34
34
|
protected beforeCommandCut(): void | false;
|
|
35
35
|
protected beforeCommandSelectAll(): false;
|
|
36
|
+
/**
|
|
37
|
+
* Fix caret position when clicking to the right of a list item that has a
|
|
38
|
+
* nested list. Blink/WebKit place the caret at the start of the line instead
|
|
39
|
+
* of the end (#1296); move it to the end of the item's own text.
|
|
40
|
+
*/
|
|
41
|
+
protected onClickRightOfNestedListItem(e: MouseEvent): void;
|
|
36
42
|
/**
|
|
37
43
|
* Normalize selection after triple click
|
|
38
44
|
*/
|
|
@@ -92,6 +92,35 @@ export class select extends Plugin {
|
|
|
92
92
|
s.expandSelection();
|
|
93
93
|
return false;
|
|
94
94
|
}
|
|
95
|
+
/**
|
|
96
|
+
* Fix caret position when clicking to the right of a list item that has a
|
|
97
|
+
* nested list. Blink/WebKit place the caret at the start of the line instead
|
|
98
|
+
* of the end (#1296); move it to the end of the item's own text.
|
|
99
|
+
*/
|
|
100
|
+
onClickRightOfNestedListItem(e) {
|
|
101
|
+
const { s } = this.j;
|
|
102
|
+
const range = s.range;
|
|
103
|
+
if (!range.collapsed ||
|
|
104
|
+
range.startOffset !== 0 ||
|
|
105
|
+
!Dom.isText(range.startContainer)) {
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
const text = range.startContainer;
|
|
109
|
+
const li = text.parentNode;
|
|
110
|
+
// The text must be the direct content of a list item that has a nested
|
|
111
|
+
// list (the last level has no nested list and behaves correctly).
|
|
112
|
+
if (!Dom.isTag(li, 'li') ||
|
|
113
|
+
!(li.querySelector('ul') || li.querySelector('ol'))) {
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
const measure = this.j.ed.createRange();
|
|
117
|
+
measure.selectNodeContents(text);
|
|
118
|
+
const rect = measure.getBoundingClientRect();
|
|
119
|
+
// Only when the click happened to the right of the text.
|
|
120
|
+
if (e.clientX > rect.right) {
|
|
121
|
+
s.setCursorAfter(text);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
95
124
|
/**
|
|
96
125
|
* Normalize selection after triple click
|
|
97
126
|
*/
|
|
@@ -132,6 +161,9 @@ __decorate([
|
|
|
132
161
|
__decorate([
|
|
133
162
|
watch([':beforeCommandSelectall'])
|
|
134
163
|
], select.prototype, "beforeCommandSelectAll", null);
|
|
164
|
+
__decorate([
|
|
165
|
+
watch([':click'])
|
|
166
|
+
], select.prototype, "onClickRightOfNestedListItem", null);
|
|
135
167
|
__decorate([
|
|
136
168
|
watch([':click'])
|
|
137
169
|
], select.prototype, "onTripleClickNormalizeSelection", null);
|
package/package.json
CHANGED
|
@@ -33,6 +33,12 @@ export declare class select extends Plugin {
|
|
|
33
33
|
protected onOutsideClick(e: MouseEvent): void;
|
|
34
34
|
protected beforeCommandCut(): void | false;
|
|
35
35
|
protected beforeCommandSelectAll(): false;
|
|
36
|
+
/**
|
|
37
|
+
* Fix caret position when clicking to the right of a list item that has a
|
|
38
|
+
* nested list. Blink/WebKit place the caret at the start of the line instead
|
|
39
|
+
* of the end (#1296); move it to the end of the item's own text.
|
|
40
|
+
*/
|
|
41
|
+
protected onClickRightOfNestedListItem(e: MouseEvent): void;
|
|
36
42
|
/**
|
|
37
43
|
* Normalize selection after triple click
|
|
38
44
|
*/
|