@cocreate/text 1.18.4 → 1.18.6
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 +15 -0
- package/CoCreate.config.js +6 -22
- package/demo/custom-rich-text.html +3 -3
- package/demo/test-webpage.html +1 -1
- package/package.json +11 -11
- package/src/index.js +1 -1
- package/src/saveDomText.js +1 -1
- package/src/updateDom.js +11 -11
- package/src/updateText.js +6 -6
package/CHANGELOG.md
CHANGED
@@ -1,3 +1,18 @@
|
|
1
|
+
## [1.18.6](https://github.com/CoCreate-app/CoCreate-text/compare/v1.18.5...v1.18.6) (2022-11-23)
|
2
|
+
|
3
|
+
|
4
|
+
### Bug Fixes
|
5
|
+
|
6
|
+
* bumped [@cocreate](https://github.com/cocreate) dependencies ([2cc50ed](https://github.com/CoCreate-app/CoCreate-text/commit/2cc50ed12f4270b436c849e944b7eea175dd58d2))
|
7
|
+
|
8
|
+
## [1.18.5](https://github.com/CoCreate-app/CoCreate-text/compare/v1.18.4...v1.18.5) (2022-11-22)
|
9
|
+
|
10
|
+
|
11
|
+
### Bug Fixes
|
12
|
+
|
13
|
+
* apply src: {{source}} to CoCreate.config ([48985c6](https://github.com/CoCreate-app/CoCreate-text/commit/48985c6e4083b6b467ea683e781ab22e2f921ce7))
|
14
|
+
* workflow docs ([dda8f5d](https://github.com/CoCreate-app/CoCreate-text/commit/dda8f5d589b02d57e076da6abce70d82cb3c8702))
|
15
|
+
|
1
16
|
## [1.18.4](https://github.com/CoCreate-app/CoCreate-text/compare/v1.18.3...v1.18.4) (2022-11-21)
|
2
17
|
|
3
18
|
|
package/CoCreate.config.js
CHANGED
@@ -4,15 +4,15 @@ module.exports = {
|
|
4
4
|
"organization_id": "5ff747727005da1c272740ab",
|
5
5
|
"host": "general.cocreate.app"
|
6
6
|
},
|
7
|
-
|
8
|
-
|
7
|
+
"sources": [
|
8
|
+
{
|
9
9
|
"entry": "./docs/index.html",
|
10
10
|
"collection": "files",
|
11
|
-
"document_id": "60209cdc3c260207bf49cacc",
|
12
|
-
"key": "src",
|
13
11
|
"document": {
|
12
|
+
"_id": "60209cdc3c260207bf49cacc",
|
14
13
|
"name": "index.html",
|
15
14
|
"path": "/docs/text/index.html",
|
15
|
+
"src": "{{source}}",
|
16
16
|
"domains": [
|
17
17
|
"*",
|
18
18
|
"general.cocreate.app"
|
@@ -23,21 +23,5 @@ module.exports = {
|
|
23
23
|
"website_id": "5ffbceb7f11d2d00103c4535"
|
24
24
|
}
|
25
25
|
}
|
26
|
-
]
|
27
|
-
|
28
|
-
"extract": {
|
29
|
-
"directory": "./src/",
|
30
|
-
"extensions": [
|
31
|
-
"js",
|
32
|
-
"css",
|
33
|
-
"html"
|
34
|
-
],
|
35
|
-
"ignores": [
|
36
|
-
"node_modules",
|
37
|
-
"vendor",
|
38
|
-
"bower_components",
|
39
|
-
"archive"
|
40
|
-
]
|
41
|
-
}
|
42
|
-
}
|
43
|
-
|
26
|
+
]
|
27
|
+
}
|
@@ -76,7 +76,7 @@ img.intLink { border: 0; }
|
|
76
76
|
</style>
|
77
77
|
</head>
|
78
78
|
<body onload="initDoc();">
|
79
|
-
<form name="compForm" method="post" action="sample.php" onsubmit="if(validateMode()){this.myDoc.value=oDoc.innerHTML;return true;}return false;">
|
79
|
+
<form name="compForm" method="post" action="sample.php" onsubmit="if (validateMode()){this.myDoc.value=oDoc.innerHTML;return true;}return false;">
|
80
80
|
<input type="hidden" name="myDoc">
|
81
81
|
<div id="toolBar1">
|
82
82
|
<select onchange="formatDoc('formatblock',this[this.selectedIndex].value);this.selectedIndex=0;">
|
@@ -122,7 +122,7 @@ img.intLink { border: 0; }
|
|
122
122
|
</select>
|
123
123
|
</div>
|
124
124
|
<div id="toolBar2">
|
125
|
-
<img class="intLink" title="Clean" onclick="if(validateMode()&&confirm('Are you sure?')){oDoc.innerHTML=sDefTxt};" src="" />
|
125
|
+
<img class="intLink" title="Clean" onclick="if (validateMode()&&confirm('Are you sure?')){oDoc.innerHTML=sDefTxt};" src="" />
|
126
126
|
<img class="intLink" title="Print" onclick="printDoc();" src="">
|
127
127
|
<img class="intLink" title="Undo" onclick="formatDoc('undo');" src="" />
|
128
128
|
<img class="intLink" title="Redo" onclick="formatDoc('redo');" src="" />
|
@@ -138,7 +138,7 @@ img.intLink { border: 0; }
|
|
138
138
|
<img class="intLink" title="Quote" onclick="formatDoc('formatblock','blockquote');" src="" />
|
139
139
|
<img class="intLink" title="Delete indentation" onclick="formatDoc('outdent');" src="" />
|
140
140
|
<img class="intLink" title="Add indentation" onclick="formatDoc('indent');" src="" />
|
141
|
-
<img class="intLink" title="Hyperlink" onclick="var sLnk=prompt('Write the URL here','http:\/\/');if(sLnk&&sLnk!=''&&sLnk!='http://'){formatDoc('createlink',sLnk)}" src="" />
|
141
|
+
<img class="intLink" title="Hyperlink" onclick="var sLnk=prompt('Write the URL here','http:\/\/');if (sLnk&&sLnk!=''&&sLnk!='http://'){formatDoc('createlink',sLnk)}" src="" />
|
142
142
|
<img class="intLink" title="Cut" onclick="formatDoc('cut');" src="" />
|
143
143
|
<img class="intLink" title="Copy" onclick="formatDoc('copy');" src="" />
|
144
144
|
<img class="intLink" title="Paste" onclick="formatDoc('paste');" src="" />
|
package/demo/test-webpage.html
CHANGED
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@cocreate/text",
|
3
|
-
"version": "1.18.
|
3
|
+
"version": "1.18.6",
|
4
4
|
"description": "A simple text component in vanilla javascript. Easily configured using HTML5 attributes and/or JavaScript API.",
|
5
5
|
"keywords": [
|
6
6
|
"text",
|
@@ -61,15 +61,15 @@
|
|
61
61
|
"webpack-log": "^3.0.1"
|
62
62
|
},
|
63
63
|
"dependencies": {
|
64
|
-
"@cocreate/actions": "^1.5.
|
65
|
-
"@cocreate/crdt": "^1.14.
|
66
|
-
"@cocreate/crud-client": "^1.
|
67
|
-
"@cocreate/cursors": "^1.12.
|
68
|
-
"@cocreate/docs": "^1.
|
69
|
-
"@cocreate/hosting": "^1.
|
70
|
-
"@cocreate/observer": "^1.5.
|
71
|
-
"@cocreate/selection": "^1.4.
|
72
|
-
"@cocreate/utils": "^1.10.
|
73
|
-
"@cocreate/uuid": "^1.2.
|
64
|
+
"@cocreate/actions": "^1.5.20",
|
65
|
+
"@cocreate/crdt": "^1.14.5",
|
66
|
+
"@cocreate/crud-client": "^1.14.0",
|
67
|
+
"@cocreate/cursors": "^1.12.5",
|
68
|
+
"@cocreate/docs": "^1.4.2",
|
69
|
+
"@cocreate/hosting": "^1.6.1",
|
70
|
+
"@cocreate/observer": "^1.5.25",
|
71
|
+
"@cocreate/selection": "^1.4.29",
|
72
|
+
"@cocreate/utils": "^1.10.21",
|
73
|
+
"@cocreate/uuid": "^1.2.23"
|
74
74
|
}
|
75
75
|
}
|
package/src/index.js
CHANGED
package/src/saveDomText.js
CHANGED
package/src/updateDom.js
CHANGED
@@ -5,7 +5,7 @@ import {domParser} from '@cocreate/utils';
|
|
5
5
|
export function updateDom({domTextEditor, value, start, end, html}) {
|
6
6
|
if (!domTextEditor.htmlString)
|
7
7
|
domTextEditor.htmlString = html;
|
8
|
-
if(start < 0 || start > domTextEditor.htmlString.length)
|
8
|
+
if (start < 0 || start > domTextEditor.htmlString.length)
|
9
9
|
throw new Error('position is out of range');
|
10
10
|
|
11
11
|
let {element, path, position, type} = getElementPosition(domTextEditor.htmlString, start, end);
|
@@ -31,7 +31,7 @@ export function updateDom({domTextEditor, value, start, end, html}) {
|
|
31
31
|
} while (!newEl && index != -1)
|
32
32
|
}
|
33
33
|
|
34
|
-
if(!newEl){
|
34
|
+
if (!newEl){
|
35
35
|
// console.log("no newEL", path)
|
36
36
|
newEl = domTextEditor.cloneNode(true);
|
37
37
|
if (html != undefined)
|
@@ -41,12 +41,12 @@ export function updateDom({domTextEditor, value, start, end, html}) {
|
|
41
41
|
domEl = domTextEditor;
|
42
42
|
type = 'innerHTML';
|
43
43
|
}
|
44
|
-
else if(element.tagName == 'HTML') {
|
44
|
+
else if (element.tagName == 'HTML') {
|
45
45
|
// console.log('element = html')
|
46
46
|
domEl = domTextEditor;
|
47
47
|
type = 'innerHTML';
|
48
48
|
}
|
49
|
-
else if(path) {
|
49
|
+
else if (path) {
|
50
50
|
// console.log("else path", path)
|
51
51
|
domEl = domTextEditor.querySelector(path);
|
52
52
|
// if (!domEl || !oldEl){
|
@@ -85,7 +85,7 @@ export function updateDom({domTextEditor, value, start, end, html}) {
|
|
85
85
|
}
|
86
86
|
}
|
87
87
|
|
88
|
-
if(domEl && newEl) {
|
88
|
+
if (domEl && newEl) {
|
89
89
|
let activeElement = domEl.ownerDocument.activeElement;
|
90
90
|
if (activeElement == domEl)
|
91
91
|
curCaret = getSelection(activeElement);
|
@@ -101,7 +101,7 @@ export function updateDom({domTextEditor, value, start, end, html}) {
|
|
101
101
|
|
102
102
|
// console.log('domEl', domEl)
|
103
103
|
// console.log('newEl', newEl)
|
104
|
-
if(start != end && type == 'innerHTML') {
|
104
|
+
if (start != end && type == 'innerHTML') {
|
105
105
|
domTextEditor.htmlString = html;
|
106
106
|
if (domEl.tagName != 'HTML'){
|
107
107
|
if (newEl.parentElement) {
|
@@ -134,7 +134,7 @@ export function updateDom({domTextEditor, value, start, end, html}) {
|
|
134
134
|
// console.log('insertAdjacent', domEl, value)
|
135
135
|
}
|
136
136
|
else if (type == 'textNode'){
|
137
|
-
if(start != end)
|
137
|
+
if (start != end)
|
138
138
|
domTextEditor.htmlString = html;
|
139
139
|
domEl.innerHTML = newEl.innerHTML;
|
140
140
|
// console.log('textnode', domEl.innerHTML, newEl.innerHTML)
|
@@ -146,7 +146,7 @@ export function updateDom({domTextEditor, value, start, end, html}) {
|
|
146
146
|
}
|
147
147
|
domTextEditor.htmlString = html;
|
148
148
|
|
149
|
-
if(curCaret && start >= 0 && end >= 0) {
|
149
|
+
if (curCaret && start >= 0 && end >= 0) {
|
150
150
|
if (curCaret.range && curCaret.range.startContainer == domEl)
|
151
151
|
if (curCaret.start >= curCaret.range.startOffset) {
|
152
152
|
let p = processSelection(domEl, value, curCaret.start, curCaret.end, start, end, curCaret.range);
|
@@ -188,7 +188,7 @@ function parseHtml(domTextEditor, html) {
|
|
188
188
|
function assignAttributes(newEl, oldEl, domEl) {
|
189
189
|
if (!oldEl) return;
|
190
190
|
for(let newElAtt of newEl.attributes) {
|
191
|
-
if(!oldEl.attributes[newElAtt.name] || oldEl.attributes[newElAtt.name].value !== newElAtt.value)
|
191
|
+
if (!oldEl.attributes[newElAtt.name] || oldEl.attributes[newElAtt.name].value !== newElAtt.value)
|
192
192
|
try {
|
193
193
|
domEl.setAttribute(newElAtt.name, newElAtt.value);
|
194
194
|
}
|
@@ -197,10 +197,10 @@ function assignAttributes(newEl, oldEl, domEl) {
|
|
197
197
|
}
|
198
198
|
}
|
199
199
|
|
200
|
-
if(newEl.attributes.length !== oldEl.attributes.length) {
|
200
|
+
if (newEl.attributes.length !== oldEl.attributes.length) {
|
201
201
|
for(let i = 0, len = oldEl.attributes.length; i < len; i++) {
|
202
202
|
let oldElAtt = oldEl.attributes[i];
|
203
|
-
if(!newEl.attributes[oldElAtt.name]) {
|
203
|
+
if (!newEl.attributes[oldElAtt.name]) {
|
204
204
|
domEl.removeAttribute(oldElAtt.name);
|
205
205
|
i--, len--;
|
206
206
|
}
|
package/src/updateText.js
CHANGED
@@ -3,7 +3,7 @@ import crdt from '@cocreate/crdt';
|
|
3
3
|
import {getStringPosition} from '@cocreate/selection';
|
4
4
|
|
5
5
|
let crud
|
6
|
-
if(CRUD && CRUD.default)
|
6
|
+
if (CRUD && CRUD.default)
|
7
7
|
crud = CRUD.default
|
8
8
|
else
|
9
9
|
crud = CRUD
|
@@ -12,7 +12,7 @@ export function insertAdjacentElement({ domTextEditor, target, position, element
|
|
12
12
|
let remove;
|
13
13
|
if (element && !elementValue) {
|
14
14
|
remove = getStringPosition({ string: domTextEditor.htmlString, target: element });
|
15
|
-
if(!remove.start && !remove.end)
|
15
|
+
if (!remove.start && !remove.end)
|
16
16
|
throw new Error('insertAdjacentElement: element not found');
|
17
17
|
elementValue = domTextEditor.htmlString.substring(remove.start, remove.end);
|
18
18
|
}
|
@@ -69,16 +69,16 @@ export function updateDomText({ domTextEditor, target, position, element, elemen
|
|
69
69
|
start += pos.start;
|
70
70
|
end += pos.end;
|
71
71
|
}
|
72
|
-
if(start != end)
|
72
|
+
if (start != end)
|
73
73
|
_updateText({domTextEditor, start, end});
|
74
|
-
if(attribute && remove != 'true' || attribute && value)
|
74
|
+
if (attribute && remove != 'true' || attribute && value)
|
75
75
|
_updateText({ domTextEditor, value: ` ${attribute}="${newValue}"`, start });
|
76
|
-
else if(value)
|
76
|
+
else if (value)
|
77
77
|
_updateText({ domTextEditor, value, start });
|
78
78
|
}
|
79
79
|
|
80
80
|
function _updateText({ domTextEditor, value, start, end}) {
|
81
|
-
if(domTextEditor.tagName =='HTML')
|
81
|
+
if (domTextEditor.tagName =='HTML')
|
82
82
|
domTextEditor = domTextEditor.ownerDocument.defaultView.frameElement;
|
83
83
|
const { collection, document_id, name, isCrud } = crud.getAttributes(domTextEditor);
|
84
84
|
crdt.updateText({ collection, document_id, name, value, start, length: end - start, crud: isCrud });
|